Vector Drawing
Convert all 2D Drawing to Vector Drawing. Add vector pointer Add Load GPX button
This commit is contained in:
80
osm.pb
80
osm.pb
@@ -484,15 +484,17 @@ Module OSM
|
|||||||
|
|
||||||
LockMutex(OSM\DrawingMutex)
|
LockMutex(OSM\DrawingMutex)
|
||||||
If OSM\EmergencyQuit = 0 ;Quit before drawing
|
If OSM\EmergencyQuit = 0 ;Quit before drawing
|
||||||
StartDrawing(CanvasOutput(OSM\Gadget))
|
StartVectorDrawing(CanvasVectorOutput(OSM\Gadget))
|
||||||
If IsImage(*Tile\nImage)
|
If IsImage(*Tile\nImage)
|
||||||
DrawImage(ImageID(*Tile\nImage), x, y)
|
MovePathCursor(x,y)
|
||||||
DrawText( x, y, Str(x) + ", " + Str(y))
|
DrawVectorImage(ImageID(*Tile\nImage))
|
||||||
|
MovePathCursor(x,y)
|
||||||
|
DrawVectorText(Str(x) + ", " + Str(y))
|
||||||
Else
|
Else
|
||||||
Debug "Image missing"
|
Debug "Image missing"
|
||||||
OSM\Dirty = #True ;Signal that this image is missing so we should have to redraw
|
OSM\Dirty = #True ;Signal that this image is missing so we should have to redraw
|
||||||
EndIf
|
EndIf
|
||||||
StopDrawing()
|
StopVectorDrawing()
|
||||||
EndIf
|
EndIf
|
||||||
UnlockMutex(OSM\DrawingMutex)
|
UnlockMutex(OSM\DrawingMutex)
|
||||||
|
|
||||||
@@ -560,26 +562,41 @@ Module OSM
|
|||||||
|
|
||||||
EndProcedure
|
EndProcedure
|
||||||
|
|
||||||
Procedure DrawTrack()
|
Procedure DrawTrack()
|
||||||
|
Protected Pixel.Pixel
|
||||||
|
Protected Location.Location
|
||||||
|
If ListSize(OSM\track())>0
|
||||||
|
|
||||||
Protected Pixel.Pixel
|
ForEach OSM\track()
|
||||||
Protected Location.Location
|
If @OSM\TargetLocation\Latitude<>0 And @OSM\TargetLocation\Longitude<>0
|
||||||
Protected n.i = 0, x.i, y.i
|
getPixelCoorfromLocation(@OSM\track(),@Pixel)
|
||||||
|
If ListIndex(OSM\track())=0
|
||||||
|
MovePathCursor(Pixel\X,Pixel\Y)
|
||||||
|
Else
|
||||||
|
AddPathLine(Pixel\X,Pixel\Y)
|
||||||
|
EndIf
|
||||||
|
|
||||||
StartDrawing(CanvasOutput(OSM\Gadget))
|
|
||||||
ForEach OSM\track()
|
|
||||||
n=n+1
|
|
||||||
If @OSM\TargetLocation\Latitude<>0 And @OSM\TargetLocation\Longitude<>0
|
|
||||||
getPixelCoorfromLocation(@OSM\track(),@Pixel)
|
|
||||||
x=Pixel\x
|
|
||||||
y=Pixel\y
|
|
||||||
If x>0 And y>0 And x<GadgetWidth(OSM\Gadget) And y<GadgetHeight(OSM\Gadget)
|
|
||||||
Circle(x,y,2,#Green)
|
|
||||||
EndIf
|
EndIf
|
||||||
EndIf
|
|
||||||
Next
|
|
||||||
StopDrawing()
|
|
||||||
|
|
||||||
|
Next
|
||||||
|
VectorSourceColor(RGBA(0, 255, 0, 150))
|
||||||
|
StrokePath(10, #PB_Path_RoundEnd|#PB_Path_RoundCorner)
|
||||||
|
|
||||||
|
EndIf
|
||||||
|
EndProcedure
|
||||||
|
|
||||||
|
Procedure Pointer(x.l,y.l,color.l=#Red)
|
||||||
|
color=RGBA(255, 0, 0, 255)
|
||||||
|
VectorSourceColor(color)
|
||||||
|
MovePathCursor(x, y)
|
||||||
|
AddPathLine(-8,-16,#PB_Path_Relative)
|
||||||
|
AddPathCircle(8,0,8,180,0,#PB_Path_Relative)
|
||||||
|
AddPathLine(-8,16,#PB_Path_Relative)
|
||||||
|
;FillPath(#PB_Path_Preserve)
|
||||||
|
;ClipPath(#PB_Path_Preserve)
|
||||||
|
AddPathCircle(0,-16,5,0,360,#PB_Path_Relative)
|
||||||
|
VectorSourceColor(color)
|
||||||
|
FillPath(#PB_Path_Preserve):VectorSourceColor(RGBA(0, 0, 0, 255)):StrokePath(1)
|
||||||
EndProcedure
|
EndProcedure
|
||||||
|
|
||||||
Procedure DrawingThread(Null)
|
Procedure DrawingThread(Null)
|
||||||
@@ -595,10 +612,10 @@ Module OSM
|
|||||||
DrawTiles()
|
DrawTiles()
|
||||||
|
|
||||||
LockMutex(OSM\DrawingMutex)
|
LockMutex(OSM\DrawingMutex)
|
||||||
StartDrawing(CanvasOutput(OSM\Gadget))
|
StartVectorDrawing(CanvasVectorOutput(OSM\Gadget))
|
||||||
;DrawTrack()
|
DrawTrack()
|
||||||
Circle(CenterX, CenterY, 5, #Red)
|
Pointer(CenterX, CenterY, #Red)
|
||||||
StopDrawing()
|
StopVectorDrawing()
|
||||||
UnlockMutex(OSM\DrawingMutex)
|
UnlockMutex(OSM\DrawingMutex)
|
||||||
|
|
||||||
UnlockMutex(OSM\DrawingThreadMutex)
|
UnlockMutex(OSM\DrawingThreadMutex)
|
||||||
@@ -720,6 +737,9 @@ Module OSM
|
|||||||
EndProcedure
|
EndProcedure
|
||||||
EndModule
|
EndModule
|
||||||
|
|
||||||
|
|
||||||
|
;Demonstration
|
||||||
|
CompilerIf #PB_Compiler_IsMainFile
|
||||||
Enumeration
|
Enumeration
|
||||||
#Window_0
|
#Window_0
|
||||||
#Map
|
#Map
|
||||||
@@ -737,6 +757,7 @@ Enumeration
|
|||||||
#Text_4
|
#Text_4
|
||||||
#String_0
|
#String_0
|
||||||
#String_1
|
#String_1
|
||||||
|
#Gdt_LoadGpx
|
||||||
EndEnumeration
|
EndEnumeration
|
||||||
|
|
||||||
;- Main
|
;- Main
|
||||||
@@ -760,11 +781,12 @@ If OpenWindow(#Window_0, 260, 225, 700, 571, "OpenStreetMap", #PB_Window_System
|
|||||||
StringGadget(#String_0, 600, 230, 90, 20, "")
|
StringGadget(#String_0, 600, 230, 90, 20, "")
|
||||||
TextGadget(#Text_4, 530, 250, 60, 15, "Longitude : ")
|
TextGadget(#Text_4, 530, 250, 60, 15, "Longitude : ")
|
||||||
StringGadget(#String_1, 600, 250, 90, 20, "")
|
StringGadget(#String_1, 600, 250, 90, 20, "")
|
||||||
|
ButtonGadget(#Gdt_LoadGpx, 530, 280, 150, 30, "Load GPX")
|
||||||
|
|
||||||
Define Event.i, Gadget.i, Quit.b = #False
|
Define Event.i, Gadget.i, Quit.b = #False
|
||||||
Define pfValue.d
|
Define pfValue.d
|
||||||
OSM::SetLocation(49.04599, 2.03347, 17)
|
OSM::SetLocation(49.04599, 2.03347, 17)
|
||||||
;OSM::SetLocation(49.0361165, 2.0456982)
|
|
||||||
|
|
||||||
Repeat
|
Repeat
|
||||||
Event = WaitWindowEvent()
|
Event = WaitWindowEvent()
|
||||||
@@ -779,14 +801,16 @@ If OpenWindow(#Window_0, 260, 225, 700, 571, "OpenStreetMap", #PB_Window_System
|
|||||||
OSM::SetZoom(1)
|
OSM::SetZoom(1)
|
||||||
Case #Button_5
|
Case #Button_5
|
||||||
OSM::SetZoom( - 1)
|
OSM::SetZoom( - 1)
|
||||||
|
Case #Gdt_LoadGpx
|
||||||
|
OSM::LoadGpxFile(OpenFileRequester("Choisissez un fichier à charger", "", "*.gpx", 0))
|
||||||
EndSelect
|
EndSelect
|
||||||
EndSelect
|
EndSelect
|
||||||
Until Quit = #True
|
Until Quit = #True
|
||||||
EndIf
|
EndIf
|
||||||
|
CompilerEndIf
|
||||||
; IDE Options = PureBasic 5.42 LTS (Windows - x86)
|
; IDE Options = PureBasic 5.42 LTS (Windows - x86)
|
||||||
; CursorPosition = 250
|
; CursorPosition = 783
|
||||||
; FirstLine = 231
|
; FirstLine = 759
|
||||||
; Folding = -----
|
; Folding = -----
|
||||||
; EnableUnicode
|
; EnableUnicode
|
||||||
; EnableThread
|
; EnableThread
|
||||||
|
Reference in New Issue
Block a user