powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Microsoft Access [игнор отключен] [закрыт для гостей] / Визуализация карт
19 сообщений из 44, страница 2 из 2
Визуализация карт
    #32839967
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Victosha авторВремя мало зависит от вида отрисовки, видимо больше от количества ('DrawManyLines (аналог "Draw700Lines")
yt dblz rjlf е видя кода сказать трудно. Почему-то думаю, что цикл
обработки рекордсета оптимизировать надо. Пока кажется, что 7 сек чрезмерно многовато...

автор к тому же не производит обратного перевода точек из класса с точками в массив - т.ч. с классом точек бороться пока не буду).

что-то я совсем не понял, про что это...

вот
7.37537500000326 5.86649999995279
2-я цифирь - сумма чистого времени только на вызовах "отрисовки" (350 раз вызвал - <~0.02 на вызов -в пределах ваших 4 сотых. (правда есть контура и из 7-ми точек и из >700). Т.ч прогон рекордсета -1.5, из которых, на самом деле 1.203125 - до завершения открытие рекордсета (есть еще кое что).

а "не понял " - см DrawPolygon в первоисточнике
...
Рейтинг: 0 / 0
Визуализация карт
    #32840072
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
все-таки не могу понять характерные размеры - общее к-во точек, например...

если действительно контура и замкнутые - полигон, если не замкнутые полилайн.

если хочешь - попробуй выложить тестовые данные любой длины или покажи структуру таблиц в которых хранишь описания.

все-таки я пока не понимаю, откуда 5-7 сек берутся...



(с выражением лица)
...
Рейтинг: 0 / 0
Визуализация карт
    #32840292
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
тест:
20 000 точек
в 367 контуров. (340 объектов из 1 и более контуров)
Данные не мои

если сделать:
Set pb = Nothing
(процедура отработает - т.к. On error resume next, только вызовы методов обрабатываться не будут)
1.6414999999979 0.168500000007043
0.168500000007043 - это сумма времени по вызовам методов отсутствующего объекта.
т.е. 5.8 сек набегает на DrawPoligon (он, в отличии от полилинии еще и поля красит, но замыкает разомкнутые контура (если таковые есть - придется линией))


Если включить отрисовку (.Repaint) после каждого вызова метода то из 7 сек непринужденно получаем >11 (4 - 350 перерисовок экрана).


ну, и чтоб не быть голословным (не причесывая):
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
Private Sub cmdDrawLine_Click()

Dim X As Double, Y As Double
Dim X1 As Double, Y1 As Double, ouid1 As Long
Dim xX As Double, yX As Double
Dim xN As Double, yN As Double
Dim dx As Double, dy As Double
Dim rX As Long, rY As Long

Dim rst As DAO.Recordset
Dim plid0 As Long, ouid As Long, plid As Long

Dim vVer As New clsVertices, i As Long
Dim lngColor As Long
Dim t As Double, tP As Double, sP As Double

    On Error Resume Next
    DoCmd.Hourglass True
    StopDrow = False
    pb.Clear
    DoEvents
    plid0 = - 1 
    plid0 = Me.plid
    
    t = Timer
    'pl_MinMaxXY
    Set rst = CurrentDb.OpenRecordset("pl_MinMaxXY", dbOpenSnapshot)
    With rst
        If .EOF Or .BOF Then
            .Close
            Exit Sub
        End If
        xN = .Collect("xN"): xX = .Collect("xX")
        yN = .Collect("yN"): yX = .Collect("yX")
        .Close
    End With
    dx = xX - xN: dy = yX - yN
    rX = pb.dib_width 'Me.Image0.Width:
    rY = pb.dib_width 'Me.Image0.Height
    Set rst = CurrentDb.OpenRecordset("pl_dots", dbOpenSnapshot)
    Debug.Print Timer - t
    With rst
        If .EOF Or .BOF Then
            .Close
            Exit Sub
        End If
        Do While Not .EOF
            X1 = X: Y1 = Y: ouid1 = ouid
            X = .Collect("dx") - xN: Y = .Collect("dy") - yN
            ouid = .Collect("ouid")
            plid = .Collect("plid")
            X = (X / dx) * rX: Y = (Y / dy) * rY
            If plid = plid0 Then
                pb.DrawWidth =  25 
            Else
                pb.DrawWidth =  1 
            End If
            If ouid1 = ouid Then
                'продолжение контура
                i = i +  1 
                vVer.NumVertices = i +  1 
                vVer.SetVertsX i, (X)
                vVer.SetVertsY i, (Y)
                'pb.DrawLine (X), (Y), (X1), (Y1), lngColor 'Color
            Else
                'начало контура
                If i >  0  Then
                    'рисуем предыдущий
                    tP = Timer
                    pb.DrawPolygon vVer, lngColor
                    'pb.DrawManyLines vVer, lngColor
                    'pb.DrawPolyLine vVer, lngColor
                    sP = sP + Timer - tP
                End If
                i =  0 
                vVer.NumVertices = i +  1 
                vVer.SetVertsX i, (X)
                vVer.SetVertsY i, (Y)
                lngColor = RGB((( 45  * ouid) Mod  122 ) +  122 , _
                    ( 122  - (( 45  * ouid) Mod  122 )) +  122 , (( 125  +  45  * ouid) Mod  255 ) +  122 )
                'lngColor = RGB(((62 * ouid) Mod 122), _
                     122  - (( 62  * ouid) Mod  122 ), ( 125  +  123  * ouid) Mod  255 )
                'lngColor = RGB(0, 0, 0)
                'lngColor = RGB(255, 255, 255)
            End If
            'DoEvents
            'Me.Repaint
            If StopDrow Then Exit Do
            .MoveNext
        Loop
        .Close
    End With
    'рисуем последний
    pb.DrawPolygon vVer, lngColor
    sP = sP + Timer - tP
    'pb.DrawManyLines vVer, lngColor
    'pb.DrawPolyLine vVer, lngColor
    Debug.Print Timer - t, sP
    DoCmd.Hourglass False
End Sub
практически то же самое рисуется Line-ами в отчетах (там где 'pb.DrawLine ...) чутка быстрее. (но уже не в разы и не на порядки)
...
Рейтинг: 0 / 0
Визуализация карт
    #32840785
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
извини, вчера не увидел.
для начала - раздели DrawPologon на 2 метода -
PreparePoligon + UpdateScreen

PreparePoligon = DrawPoligon без последней команды -

' Update the display
Me.DIBtoPictureData

Это вынеси в отдельный метод - UpdateScreen
и применяй его после последней отрисовки

End With
'рисуем последний
' pb.DrawPolygon vVer, lngColor
pb.PreparePolygon vVer, lngColor
pb.UpdateScreen



Если не затруднит - скажи - ускорило ли это что-нибудь?
...
Рейтинг: 0 / 0
Визуализация карт
    #32841134
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
вот посмотрел чуть внимательнее и не понял
как это
автор If ouid1 = ouid Then
'продолжение контура
i = i + 1
vVer.NumVertices = i + 1
vVer.SetVertsX i, (X)
vVer.SetVertsY i, (Y)

работает без изменений в clsVertices?


По коду похоже, что почти все время из наблюденного съедает обращение к
vVer.

Мораль - надо приводить clsVertices к пригодному для работы виду.
...
Рейтинг: 0 / 0
Визуализация карт
    #32841403
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Victoshaвот посмотрел чуть внимательнее и не понял
как это
автор If ouid1 = ouid Then
'продолжение контура
i = i + 1
vVer.NumVertices = i + 1
vVer.SetVertsX i, (X)
vVer.SetVertsY i, (Y)

работает без изменений в clsVertices?

оно и не работает. см в 1200294 :
1200294
(пришлось Preserve добавить в clcVertices Property Let NumVertices ...

Victosha
По коду похоже, что почти все время из наблюденного съедает обращение к
vVer.

Мораль - надо приводить clsVertices к пригодному для работы виду.
см там же (думал вабше сбавиться от класса, оставив паблик массив, чтобы не перекидывать массивы туда-сюда, но там трабла с явной передачей массива пользовательских типов в методы классов - передача вариантом выигрыша не даст (помнится смотрели как то) - массив будет "размещаться" в вариант - а это время).


Код: plaintext
PreparePoligon + UpdateScreen 
- думал и об энтом, к тому же метод типа UpdateScreen (или даже именно одноименный) там ужо есть (и даже по началу пытался это же с дролайнами проделать - влет не получилось). Разгребусь с текучкой - проверю и то и сё.
...
Рейтинг: 0 / 0
Визуализация карт
    #32841431
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ззы

сообразил:
процедура при дропнутом объекте рисования точки в класс все равно размещает, при этом времена (см выше):
1.6414999999979 0.168500000007043
~1.2 сек до цикла (открытие обоих рекордстеов).
т.ч. заполнение класса, кажется не шибко ест время (<~0.5 s) суммарно на все проходы цикла.
Видимо и четние - не многим более. (ReDim-ов при этом не происходит).
...
Рейтинг: 0 / 0
Визуализация карт
    #32842541
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
посмотрел UpdateScreen из класса картинки - то что надо.

вот придумался вариант clsVertices2 - рабочий в том смысле, что сам класс работает.

и вариант метода PreparePoligon для класса картнинки.

метод отрисовки набора случайных полигонов в цикле на 700 оборотов
работает 0.3 сек

вот текст тестового метода


Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
Private Sub cmdPolygons_Click()
' Draw random Polygons
    Dim X As Long, Y As Long, X2 As Long, Y2 As Long
    Dim Color As Long
    Dim varTemp As Variant
    
    'Dim pts(2) As POINTAPI
    Dim pts As clsVertices2
    
    Set pts = New clsVertices2
    Dim iNdex As Long
    Dim tt As Single
    tt = Timer
    
    For iNdex =  1  To  700 
    
    pts.NumVertices = RndInt( 16 )
    'Debug.Print "NumVertices:" & pts.NumVertices
    'DoEvents
    ' Limit our random values<grin>
    For X =  0  To pts.NumVertices -  1 
     pts.SetVertsX X, RndInt(pb.dib_width)
     pts.SetVertsY X, RndInt(pb.dib_height)
    Next X
    
    'pts(1).x = RndInt(pb.dib_width)
    'pts(1).y = RndInt(pb.dib_height)
    'pts(2).x = RndInt(pb.dib_width)
    'pts(2).y = RndInt(pb.dib_height)
    
    'varTemp = pts
    
    'pb.PolygonVertices = varTemp
     Color = RGB(RndInt( 256 ), RndInt( 256 ), RndInt( 256 ))
    '
    ' Call the Polygon Method to draw some random Polygons
    pb.PreparePolygon2 pts, Color
    pts.ClearArrayContent
    
    'pb.DrawPolygon pts, Color
    
    Next
    
    pb.UpdateScreen
    DoEvents
    Set pts = Nothing
    MsgBox Timer - tt
End Sub

выкладывать ли clsVertices2 и .PreparePolygon2
??
...
Рейтинг: 0 / 0
Визуализация карт
    #32842587
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
сделал ~
PreparePoligon + UpdateScreen

(Вернее сделал:
Код: plaintext
1.
2.
3.
Public Sub DrawPolygon(pts As clsVertices, _
Optional TempFillColor As Long =  0 , _
Optional TempColor As Long =  0 , _
Optional OnlyPrepare As Boolean = False)


Время на прорисовку сущ-нно снизилось :
(2 пробы)
Код: plaintext
1.
2.
3.
4.
 0 . 71912500000326  
  1 . 56287500000326              0 . 325374999898486  

 0 . 703249999998661  
  1 . 54699999999866              0 . 247250000007625  
от ~0.19 до ~0.33 (на одних и тех же данных)

теперь можно и рекордсеты пооптимизировать. И с многократными передачами массивов побороться.

(Хотя от изначальной идеи дать каждому объекту его рисунок в ленточной имеет смысл отказатья - долговато будет). А жаль.

Большой сенька в реке мяч 2 Мшсещырф.
...
Рейтинг: 0 / 0
Визуализация карт
    #32842601
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Не видел предыдущего.


Любопытно посмотреть на отличия clsVertices и их вызовов из PreParePolygon2 от исходных

(т.е. есть ли за что бороться).
...
Рейтинг: 0 / 0
Визуализация карт
    #32842623
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
4321Не видел предыдущего.


Любопытно посмотреть на отличия clsVertices и их вызовов из PreParePolygon2 от исходных

(т.е. есть ли за что бороться).

вот как раз это и проверил на длине pts.NumVertices = RndInt(320)
в цикле на 700 оборотов
так вот однократный апдейт экрана дает более чем трех-кратный выигрыш.
а модифицированный clsVertices2 всего 3 - 12% за счет исключения
повторного копирования массива точек.
При этом несколько меняется Declare

ЗЫ
выложу чуть позже...
...
Рейтинг: 0 / 0
Визуализация карт
    #32842708
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
вот текст класса


Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
123.
124.
125.
126.
127.
128.
129.
130.
131.
132.
133.
134.
135.
136.
137.
138.
139.
140.
141.
142.
143.
144.
145.
146.
147.
148.
149.
150.
151.
152.
153.
154.
155.
156.
157.
158.
159.
160.
161.
' clsVertices2
' Required for Polygon API call

'Updated by Victosha 23.12.2004

Option Compare Binary
Option Explicit


Private Declare Sub CopyMemory Lib "kernel32" Alias _
    "RtlMoveMemory" (pDst As Any, pSrc As Any, _
    ByVal ByteLen As Long)
    
'Описание ZeroMemory в WinAPI32.txt неправльное. Потерял некоторое время, пока понял это:
Private Declare Sub ZeroMemory Lib "kernel32" Alias "RtlZeroMemory" (dest As Any, _
    ByVal numBytes As Long)

'структура для хранения информации о размерности
Private Type SAFEARRAYBOUND
    cElements As Long
    lLbound As Long
End Type

'описатель одномерного массива
Private Type SAFEARRAY1D
    cDims As Integer
    fFeatures As Integer
    cbElements As Long
    cLocks As Long
    pvData As Long
    Bounds( 0  To  0 ) As SAFEARRAYBOUND
End Type


'Шаг увеличения длины массива
'для экономии к-ва редимов
'здесь надо установить размер наиболее вероятного
'размера массива точек
'очень слабо - почти незаметно влияние на общую скорость
'
Const CChunkSize As Long =  50 &


' Number of vertices for our Polygon
Private m_NumVertices As Long

' Array to hold the vertices
' тип массива пришлось сменить, иначе проблема с определением адресов
Private m_pts() As Currency 'POINTAPI

'просто текущая длина массива
Private uArrayBound As Long

'описатель массива
Private pSaPtr As SAFEARRAY1D


Private Function VarPtrArray(arr As Variant) As Long
'функция для определения адреса массива
  CopyMemory VarPtrArray, ByVal VarPtr(arr) +  8 &,  4 &
End Function

Private Sub GetArrPtr()
'формирует описатель массива точек
  Dim arrPtr As Long
  Dim saPtr As Long
  
  arrPtr = VarPtrArray(m_pts)
  
  ' восстанавливаем адрес описателя
  CopyMemory ByVal VarPtr(saPtr), ByVal arrPtr,  4 &
  
  'копируем информацию в описатель массива
  CopyMemory pSaPtr, ByVal saPtr, _
        Len(pSaPtr) ' - 8 * (60 - cDims)
        
End Sub

Private Sub reserveArray(ByVal x As Long)
'выделяет память под массив
  If x <  1 & Then x =  1 &
  If x > uArrayBound Then
    ReDim Preserve m_pts((x -  1 &) + CChunkSize) As Currency
    uArrayBound = UBound(m_pts)
    GetArrPtr
  End If
End Sub

Friend Sub ClearArrayContent()
'очищает массив, заполняя его нулями
Dim numElems As Long
  numElems = pSaPtr.cbElements * pSaPtr.Bounds( 0 ).cElements
  ZeroMemory m_pts( 0 &), ByVal numElems
  GetArrPtr
  m_NumVertices =  0 &
End Sub


Property Get getPointerToArray() As Long
'возвращает указатель на первый элемент массива
'для последующего использования функциями отрисовки
'в соответствующих декларациях нужно подправить x as POINTAPI на ByVal x As Long
  getPointerToArray = pSaPtr.pvData
End Property



Friend Property Let NumVertices(ByVal x As Long)
' Erase m_pts
' Zero based index
  If x =  0  Then x =  1 
  
  If x > uArrayBound Then
    reserveArray x
  End If
  
  m_NumVertices = x -  1 
End Property

Friend Property Get NumVertices() As Long
  NumVertices = m_NumVertices
End Property

Friend Property Get VertsX(x) As Long
  CopyMemory ByVal VarPtr(VertsX), ByVal (pSaPtr.pvData + x *  8 &),  4 &
End Property

Friend Property Get VertsY(x) As Long
  CopyMemory ByVal VarPtr(VertsY), ByVal (pSaPtr.pvData + x *  8 & +  4 &),  4 &
End Property


Friend Function SetVertsX(inDex As Long, x As Long)
  CopyMemory ByVal pSaPtr.pvData + inDex *  8 &, ByVal VarPtr(x),  4 &
'm_pts(inDex).X = X
End Function

Friend Function SetVertsY(inDex As Long, x As Long)
  CopyMemory ByVal pSaPtr.pvData + inDex *  8 & +  4 &, ByVal VarPtr(x),  4 &
'm_pts(inDex).Y = X
End Function

Friend Function SetVertsXY(inDex As Long, x As Long, y As Long)
'предпочтительно устанавлиать точки ею, единицы процентов на этом выиграются
   CopyMemory ByVal pSaPtr.pvData + inDex *  8 &, ByVal VarPtr(x),  4 &
   CopyMemory ByVal pSaPtr.pvData + inDex *  8 & +  4 &, ByVal VarPtr(y),  4 &
End Function

Private Sub Class_Initialize()
' To reduce errors setup as 2 vertices
  'firstStart = True
  NumVertices =  1 &
End Sub

Private Sub Terminate()
On Error Resume Next
    Erase m_pts
End Sub

Private Sub Class_Terminate()
  Terminate
End Sub
...
Рейтинг: 0 / 0
Визуализация карт
    #32842716
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
в clsPictureBox
надо добавить декларацию
Код: plaintext
1.
Private Declare Function Polygon2 Lib "gdi32" Alias "Polygon" _
(ByVal hdc As Long, ByVal lpPoint As Long, ByVal nCount As Long) As Long

тогда медод "подготовки полигона" будет таким

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
Friend Sub PreparePolygon2(pts As clsVertices2, Optional TempFillColor As Long =  0 )
    
    Dim hNewBrush As Long
    Dim hOldBrush As Long
    'Dim pt() As POINTAPI
    'Dim x As Long
    
On Error GoTo Exit_Err
    
   'ReDim pt(pts.NumVertices)
    
   'For X = 0 To pts.NumVertices
   '  pt(X).X = pts.VertsX(X)
   '  pt(X).Y = pts.VertsY(X)
   'Next
   
    If TempFillColor <>  0  Then
        hNewBrush = apiCreateSolidBrush(TempFillColor)
    Else
    ' Use FillColor Prop
        hNewBrush = apiCreateSolidBrush(m_FillColor)
    End If
    
    ' Select new brush onto our DC
    hOldBrush = SelectObject(m_hDC, hNewBrush)
    
    ' Draw the Polygon
    Call Polygon2(m_hDC, ByVal pts.getPointerToArray, pts.NumVertices)
    
    Call SelectObject(m_hDC, hOldBrush)
    Call DeleteObject(hNewBrush)
    
    '' Update the display
    'Me.DIBtoPictureData


Exit_OK:
Exit Sub

Exit_Err:

MsgBox Err.Description, vbCritical, "Error Number:" & Err.Number
GoTo Exit_OK:
End Sub

ЗЫ1
с полилайном все тоже самое.

(с выражением лица)
...
Рейтинг: 0 / 0
Визуализация карт
    #32842770
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
виноват
методы доступа должны быть такими

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
Friend Property Get VertsX(X) As Long
  Dim adr As Long
  adr = pSaPtr.pvData + X *  8 &
  CopyMemory ByVal VarPtr(VertsX), ByVal adr,  4 &
End Property

Friend Property Get VertsY(X) As Long
  Dim adr As Long
  adr = pSaPtr.pvData + X *  8 & +  4 &
  CopyMemory ByVal VarPtr(VertsY), ByVal adr,  4 &
End Property
(с выражением лица)
...
Рейтинг: 0 / 0
Визуализация карт
    #32842875
Фотография GUESТ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
я смотрю ты серьезно завелся на эту тему...

респект
...
Рейтинг: 0 / 0
Визуализация карт
    #32842880
Фотография Rafa
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
может чего не понимаю, с наскоку то, но попробуй шрифты True Type они масштабируются до любого размера, нарисуй свой какой нужен в смысле фигуры и растаскивай в лабелях фоть по форме, хоть по отчету.....
где -то на hiprog.ru я давно выкладывал способ создания интерфейсов вместо картинок были как раз символы шрифта. Весит фигня знакомест море до 65535
Извините если не в тему попал....
...
Рейтинг: 0 / 0
Визуализация карт
    #32842928
Фотография Victosha
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Попробовал, как это выглядит на «другой» машине.

При том, что она номинально слабее, результат, с одной стороны лучше по
времени (первая П4-1700, вторая - Атлон1400, атлон получился «лучше»), а с
другой модифицированный clsVertices дает более стабильную и лучше
измеримую разницу в 7-10%. На П4 3-12%.

Думается, что - теоретически это не все, что можно выжать из вба,но у меня
больше нет лимита времени и интереса, к сожалению.


Одна из причин формулируется так. Подкрутить подготовку массива в рамках
вба, как будто еще возможно, и, может оказаться, что существенно .
Вот с отрисовкой на этой дороге применительно к скорости, кажется делать
больше нечего. Дальше можно бороться за мировые преобразования,
сглаживание, завершение маршрутов и масштабирование.

К этому выводу пришел на основании наблюдения относительных времен
подготовки массива данных и их отрисовки на виртуальном устройстве.


В широком диапазоне длин цепочек – от 150 до 700 элементов,
отношение времени подготовки массива к времени рисовки остается
практически неизменным и колеблется в районе 53:47 – 56:44.

В лоб время заполнения массива можно улучшить не менее, чем на
полпорядка, вынеся соответствующий класс в Актив-Икс длл.

Но на времени рисовки при аналогичном движении так существенно, думаю,
не выиграть – предполагаю, что там речь на длинных цепочках пойдет о
десятке-другом процентов.

Таким образом, граница снизу по улучшению скорости – время выполнения
АПИ-функций отрисовки множества точек. Можно поиграть стилями
наложения картинки («видеорежимами»). Однако, это немного другое поле для
экспериментов, и вне задачи, я нос ни ковырять, ни пудрить не буду на эту
тему.
:)

Ускоряться в смысле рисовки можно на дороге прямой манипуляции битовыми
массивами. Но, до опыта (и вне специфики задачи, позволяющей что-то
докрутить по месту), это кажется смелым начинанием на ВБА.
Впрочем – посмотрим – охота пуще неволи…



На ВБ я бы не стал бы в этом месте опускать флага :)


ЗЫ
А что там с очередями – входят и выходят?
...

(с выражением лица)
...
Рейтинг: 0 / 0
Визуализация карт
    #32843265
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
хм, а вот к очередям мы туточки и возвратились. Есть ли красивое решение с отрезанием от массива первых элементов (без ручного передвигания задних элементов вперед)? И как красиво сшить два массива в один. (вариант - Вшить один вунутрь второго?)


Хотя меня это интересует не в смысле очередей, а в смысле контуров, которые, в некотором роде, "очереди". И манипуляции с ними весьма сродни очередям ("уточннение" контура - суть вставка одного массива в некоторый другой, возможно на место вырезаемого участок другого (другой длины), -т.е. чаще всего с изменением нумерации хвоста массива-назначения. Понятно, что можно так оперировать с коллекциями - благо текстовый индекс позволяет вставлять без переиндексации хвостов, но коллекция видимо потяжельше массива будет). Есть маза работать со строками - (Replace). Но массив на строку надо отображать (CopyMem ByRef ?) как впрочем и взад (после преобразования). Будет ли это шустро? (Думается подсобрав с энтого форума старые опусы на тему CopyMem я таки разберусь, но если есть интерес - могу и просто понаблюдать за полетом.)




ЗЗЗЫ Чисто очереди (сами по себе в БД) интересовали некоего ораклиста. Я просто заметил, что "списки" неудобны тем, что надо следить за образованием паразитных колец по ссылкам (выпадением части очереди из общей - из за того, что кто-то перезаймет где то в хвосте). И делать в аксессе это придется не встроенными средствами контроля правил/целостности (а правилами перестройки списков приложением). То же относится и к (кустящимся) деревьям, построенным как списки (по ссылкам на нижеторчащего).
...
Рейтинг: 0 / 0
Визуализация карт
    #32843328
интов
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
про отображение строк на массив интов я тут пытался изголиться.
http://www.sql.ru/forum/actualthread.aspx?tid=98800&hl=%ec%e0%f1%f1%e8%e2+%e8%ed%f2%ee%e2#729963
...
Рейтинг: 0 / 0
19 сообщений из 44, страница 2 из 2
Форумы / Microsoft Access [игнор отключен] [закрыт для гостей] / Визуализация карт
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]