LazMapViewer: Fix TMapView.Font streaming.
git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@9706 8e941d3f-bd1b-0410-a28a-d453659cc2b4
This commit is contained in:
		
							parent
							
								
									5932f46825
								
							
						
					
					
						commit
						e92d81a180
					
				| @ -556,7 +556,6 @@ type | ||||
|       FDebugTiles: Boolean; | ||||
|       FDefaultTrackColor: TColor; | ||||
|       FDefaultTrackWidth: Integer; | ||||
|       FFont: TFont; | ||||
|       FPOIImages: TCustomImageList; | ||||
|       FPOIImagesWidth: Integer; | ||||
|       FCacheOnDisk: Boolean; | ||||
| @ -609,7 +608,6 @@ type | ||||
|       function IsCacheMaxAgeStored: Boolean; | ||||
|       function IsCacheMemMaxItemCountStored : Boolean; | ||||
|       function IsCachePathStored: Boolean; | ||||
|       function IsFontStored: Boolean; | ||||
|       function IsLayersStored: Boolean; | ||||
|       procedure SetActive(AValue: boolean); | ||||
|       procedure SetCacheLocation(AValue: TCacheLocation); | ||||
| @ -625,7 +623,6 @@ type | ||||
|       procedure SetDownloadEngine(AValue: TMvCustomDownloadEngine); | ||||
|       procedure SetDrawingEngine(AValue: TMvCustomDrawingEngine); | ||||
|       procedure SetDrawPreviewTiles(AValue: Boolean); | ||||
|       procedure SetFont(AValue: TFont); | ||||
|       procedure SetInactiveColor(AValue: TColor); | ||||
|       procedure SetLayers(const ALayers: TMapLayers); | ||||
|       procedure SetMapProvider(AValue: String); | ||||
| @ -646,7 +643,6 @@ type | ||||
|       procedure SetZoomMax(AValue: Integer); | ||||
|       procedure SetZoomMin(AValue: Integer); | ||||
|       procedure SetZoomToCursor(AValue: Boolean); | ||||
|       procedure UpdateFont(Sender: TObject); | ||||
|       procedure UpdateImage(Sender: TObject); | ||||
| 
 | ||||
|     protected | ||||
| @ -669,6 +665,8 @@ type | ||||
|       procedure DoZoomChanging(Sender: TObject; NewZoom: Integer; var Allow: Boolean); | ||||
|       function FindObjsAtScreenPt(X, Y: Integer; ATolerance: Integer; | ||||
|         AVisibleOnly: Boolean; AClass: TGPSObjClass = nil): TGPSObjArray; | ||||
|       procedure FontChanged(Sender: TObject); override; | ||||
|       procedure FontToDrawingEngine; | ||||
|       function IsActive: Boolean; inline; | ||||
|       procedure MouseDown(Button: TMouseButton; Shift: TShiftState; | ||||
|         X, Y: Integer); override; | ||||
| @ -770,11 +768,12 @@ type | ||||
|       property DrawPreviewTiles: Boolean read GetDrawPreviewTiles write SetDrawPreviewTiles default true; | ||||
|       property Options: TMapViewOptions read FOptions write SetOptions default DefaultMapViewOptions; | ||||
|       property Layers: TMapLayers read GetLayers write SetLayers stored IsLayersStored; | ||||
|       property Font: TFont read FFont write SetFont stored IsFontStored; | ||||
|       property Font; | ||||
|       property Height default 150; | ||||
|       property InactiveColor: TColor read GetInactiveColor write SetInactiveColor default clWhite; | ||||
|       property MapProvider: String read GetMapProvider write SetMapProvider; | ||||
|       property MapCenter: TMapCenter read FCenter write FCenter; | ||||
|       property ParentFont; | ||||
|       property PluginManager: TMvCustomPluginManager read FPluginManager write SetPluginManager; | ||||
|       property POIImage: TCustomBitmap read FPOIImage write SetPOIImage; | ||||
|       property POIImages: TCustomImageList read FPOIImages write SetPOIImages; | ||||
| @ -2656,12 +2655,6 @@ begin | ||||
|   Result := not SameText(CachePath, 'cache/'); | ||||
| end; | ||||
| 
 | ||||
| function TMapView.IsFontStored: Boolean; | ||||
| begin | ||||
|   Result := SameText(FFont.Name, 'default') and (FFont.Size = 0) and | ||||
|     (FFont.Style = []) and (FFont.Color = clBlack); | ||||
| end; | ||||
| 
 | ||||
| function TMapView.IsLayersStored: Boolean; | ||||
| begin | ||||
|   Result := True;  | ||||
| @ -2748,7 +2741,8 @@ begin | ||||
|     FDrawingEngine.CreateBuffer(ClientWidth, ClientHeight); | ||||
|     FEngine.CacheItemClass := FDrawingEngine.GetCacheItemClass; | ||||
|   end; | ||||
|   UpdateFont(nil); | ||||
|   FontToDrawingEngine; | ||||
|   Invalidate; | ||||
| end; | ||||
| 
 | ||||
| procedure TMapView.SetDrawPreviewTiles(AValue: Boolean); | ||||
| @ -2757,12 +2751,6 @@ begin | ||||
|   Invalidate; | ||||
| end; | ||||
| 
 | ||||
| procedure TMapView.SetFont(AValue: TFont); | ||||
| begin | ||||
|   FFont.Assign(AValue); | ||||
|   UpdateFont(nil); | ||||
| end; | ||||
| 
 | ||||
| procedure TMapView.SetInactiveColor(AValue: TColor); | ||||
| begin | ||||
|   Engine.BkColor := TColorToFPColor(AValue); | ||||
| @ -3571,6 +3559,9 @@ begin | ||||
|       DrawingEngine.PenColor := ptColor; | ||||
|     end; | ||||
| 
 | ||||
|     // Prepare text font | ||||
|     FontToDrawingEngine; | ||||
| 
 | ||||
|     // Prepare point text | ||||
|     txt := APt.Name; | ||||
|     if FPOITextBgColor <> clNone then | ||||
| @ -3822,13 +3813,6 @@ begin | ||||
|   FBuiltinPluginManager := TMvCustomPluginManager.Create(Self); | ||||
|   FBuiltinPluginManager.Name := 'BuiltinPM'; | ||||
| 
 | ||||
|   FFont := TFont.Create; | ||||
|   FFont.Name := 'default'; | ||||
|   FFont.Size := 0; | ||||
|   FFont.Style := []; | ||||
|   FFont.Color := clBlack; | ||||
|   FFont.OnChange := @UpdateFont; | ||||
| 
 | ||||
|   FPOIImage := TPortableNetworkGraphic.Create; //TBitmap.Create; | ||||
|   FPOIImage.OnChange := @UpdateImage; | ||||
|   FPOITextBgColor := clNone; | ||||
| @ -3853,7 +3837,6 @@ var | ||||
| begin | ||||
|   Active := False; | ||||
|   Engine.Jobqueue.RemoveAsyncCalls(Self); | ||||
|   FFont.Free; | ||||
|   FreeAndNil(FPOIImage); | ||||
|   FLayers.Free; | ||||
|   for I := 0 to High(FGPSItems) do | ||||
| @ -4229,16 +4212,22 @@ begin | ||||
|   DrawingEngine.CreateBuffer(ClientWidth, ClientHeight);       // ??? | ||||
| end; | ||||
| 
 | ||||
| procedure TMapView.UpdateFont(Sender: TObject); | ||||
| procedure TMapView.FontChanged(Sender: TObject); | ||||
| begin | ||||
|   inherited; | ||||
|   FontToDrawingEngine; | ||||
|   Invalidate; | ||||
| end; | ||||
| 
 | ||||
| procedure TMapView.FontToDrawingEngine; | ||||
| var | ||||
|   fd: TFontData; | ||||
| begin | ||||
|   fd := GetFontData(FFont.Handle); | ||||
|   fd := GetFontData(Font.Handle); | ||||
|   DrawingEngine.FontName := fd.Name; | ||||
|   DrawingEngine.FontSize := abs(round(fd.Height / FFont.PixelsPerInch * 72)); | ||||
|   DrawingEngine.FontStyle := FFont.Style; | ||||
|   DrawingEngine.FontColor := ColorToRGB(FFont.Color); | ||||
|   Invalidate; | ||||
|   DrawingEngine.FontSize := abs(round(fd.Height / Font.PixelsPerInch * 72)); | ||||
|   DrawingEngine.FontStyle := Font.Style; | ||||
|   DrawingEngine.FontColor := ColorToRGB(Font.Color); | ||||
| end; | ||||
| 
 | ||||
| procedure TMapView.UpdateImage(Sender: TObject); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 wp_xxyyzz
						wp_xxyyzz