LazMapViewer: Replace TMarkerEditorPlugin properties ClickMode and ExtendSelection by key combinations in Shift* properties. Update demp.
git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@9701 8e941d3f-bd1b-0410-a28a-d453659cc2b4
This commit is contained in:
parent
7677def6cf
commit
0c94a4cd90
@ -1,18 +1,18 @@
|
|||||||
object MainForm: TMainForm
|
object MainForm: TMainForm
|
||||||
Left = 513
|
Left = 513
|
||||||
Height = 566
|
Height = 690
|
||||||
Top = 157
|
Top = 157
|
||||||
Width = 833
|
Width = 908
|
||||||
Caption = 'Marker Editor Demo'
|
Caption = 'Marker Editor Demo'
|
||||||
ClientHeight = 566
|
ClientHeight = 690
|
||||||
ClientWidth = 833
|
ClientWidth = 908
|
||||||
LCLVersion = '4.99.0.0'
|
LCLVersion = '4.99.0.0'
|
||||||
OnCreate = FormCreate
|
OnCreate = FormCreate
|
||||||
object MapView: TMapView
|
object MapView: TMapView
|
||||||
Left = 0
|
Left = 0
|
||||||
Height = 423
|
Height = 468
|
||||||
Top = 0
|
Top = 0
|
||||||
Width = 833
|
Width = 908
|
||||||
Align = alClient
|
Align = alClient
|
||||||
DownloadEngine = MapView.BuiltInDLE
|
DownloadEngine = MapView.BuiltInDLE
|
||||||
DrawingEngine = MapView.BuiltInDE
|
DrawingEngine = MapView.BuiltInDE
|
||||||
@ -21,11 +21,12 @@ object MainForm: TMainForm
|
|||||||
MapProvider = 'Open Topo Map'
|
MapProvider = 'Open Topo Map'
|
||||||
PluginManager = PluginManager
|
PluginManager = PluginManager
|
||||||
POIImages = POI_Images
|
POIImages = POI_Images
|
||||||
|
TabOrder = 0
|
||||||
end
|
end
|
||||||
object Bevel1: TBevel
|
object Bevel1: TBevel
|
||||||
AnchorSideLeft.Control = Owner
|
AnchorSideLeft.Control = Owner
|
||||||
AnchorSideLeft.Side = asrCenter
|
AnchorSideLeft.Side = asrCenter
|
||||||
Left = 413
|
Left = 451
|
||||||
Height = 50
|
Height = 50
|
||||||
Top = 108
|
Top = 108
|
||||||
Width = 6
|
Width = 6
|
||||||
@ -33,14 +34,14 @@ object MainForm: TMainForm
|
|||||||
end
|
end
|
||||||
object Panel1: TPanel
|
object Panel1: TPanel
|
||||||
Left = 0
|
Left = 0
|
||||||
Height = 143
|
Height = 222
|
||||||
Top = 423
|
Top = 468
|
||||||
Width = 833
|
Width = 908
|
||||||
Align = alBottom
|
Align = alBottom
|
||||||
AutoSize = True
|
AutoSize = True
|
||||||
BevelOuter = bvNone
|
BevelOuter = bvNone
|
||||||
ClientHeight = 143
|
ClientHeight = 222
|
||||||
ClientWidth = 833
|
ClientWidth = 908
|
||||||
TabOrder = 1
|
TabOrder = 1
|
||||||
object cgPointTypes: TCheckGroup
|
object cgPointTypes: TCheckGroup
|
||||||
AnchorSideLeft.Control = Panel1
|
AnchorSideLeft.Control = Panel1
|
||||||
@ -109,100 +110,51 @@ object MainForm: TMainForm
|
|||||||
ParentColor = False
|
ParentColor = False
|
||||||
ParentFont = False
|
ParentFont = False
|
||||||
end
|
end
|
||||||
object rgClickMode: TRadioGroup
|
|
||||||
AnchorSideLeft.Control = cgPointTypes
|
|
||||||
AnchorSideLeft.Side = asrBottom
|
|
||||||
AnchorSideTop.Control = Panel1
|
|
||||||
AnchorSideBottom.Control = cbExtendSelection
|
|
||||||
AnchorSideBottom.Side = asrBottom
|
|
||||||
Left = 387
|
|
||||||
Height = 127
|
|
||||||
Top = 8
|
|
||||||
Width = 196
|
|
||||||
AutoFill = True
|
|
||||||
AutoSize = True
|
|
||||||
BorderSpacing.Right = 8
|
|
||||||
BorderSpacing.Around = 8
|
|
||||||
Caption = 'Click mode'
|
|
||||||
ChildSizing.LeftRightSpacing = 12
|
|
||||||
ChildSizing.TopBottomSpacing = 6
|
|
||||||
ChildSizing.EnlargeHorizontal = crsHomogenousChildResize
|
|
||||||
ChildSizing.EnlargeVertical = crsHomogenousChildResize
|
|
||||||
ChildSizing.ShrinkHorizontal = crsScaleChilds
|
|
||||||
ChildSizing.ShrinkVertical = crsScaleChilds
|
|
||||||
ChildSizing.Layout = cclLeftToRightThenTopToBottom
|
|
||||||
ChildSizing.ControlsPerLine = 1
|
|
||||||
ClientHeight = 107
|
|
||||||
ClientWidth = 192
|
|
||||||
ItemIndex = 1
|
|
||||||
Items.Strings = (
|
|
||||||
'Create new point'
|
|
||||||
'Select point'
|
|
||||||
'Select points of shape'
|
|
||||||
'Toggle selected point'
|
|
||||||
'Select by dragging rectangle'
|
|
||||||
)
|
|
||||||
TabOrder = 1
|
|
||||||
OnClick = rgClickModeClick
|
|
||||||
end
|
|
||||||
object cbExtendSelection: TCheckBox
|
|
||||||
AnchorSideLeft.Control = rgNewPointType
|
|
||||||
AnchorSideTop.Control = rgNewPointType
|
|
||||||
AnchorSideTop.Side = asrBottom
|
|
||||||
Left = 599
|
|
||||||
Height = 19
|
|
||||||
Top = 83
|
|
||||||
Width = 103
|
|
||||||
Caption = 'Extend selection'
|
|
||||||
TabOrder = 2
|
|
||||||
OnChange = cbExtendSelectionChange
|
|
||||||
end
|
|
||||||
object btnDeleteSelection: TButton
|
object btnDeleteSelection: TButton
|
||||||
AnchorSideLeft.Control = rgNewPointType
|
AnchorSideLeft.Control = rgNewPointType
|
||||||
AnchorSideLeft.Side = asrBottom
|
AnchorSideLeft.Side = asrBottom
|
||||||
AnchorSideTop.Control = rgClickMode
|
Left = 503
|
||||||
Left = 715
|
|
||||||
Height = 25
|
Height = 25
|
||||||
Top = 8
|
Top = 8
|
||||||
Width = 109
|
Width = 109
|
||||||
AutoSize = True
|
AutoSize = True
|
||||||
Caption = 'Delete selection'
|
Caption = 'Delete selection'
|
||||||
TabOrder = 3
|
TabOrder = 1
|
||||||
OnClick = btnDeleteSelectionClick
|
OnClick = btnDeleteSelectionClick
|
||||||
end
|
end
|
||||||
object btnConvertToTrack: TButton
|
object btnConvertToTrack: TButton
|
||||||
AnchorSideLeft.Control = btnDeleteSelection
|
AnchorSideLeft.Control = btnDeleteSelection
|
||||||
AnchorSideTop.Control = btnDeleteSelection
|
AnchorSideTop.Control = btnDeleteSelection
|
||||||
AnchorSideTop.Side = asrBottom
|
AnchorSideTop.Side = asrBottom
|
||||||
Left = 715
|
Left = 503
|
||||||
Height = 25
|
Height = 25
|
||||||
Top = 33
|
Top = 33
|
||||||
Width = 111
|
Width = 111
|
||||||
AutoSize = True
|
AutoSize = True
|
||||||
Caption = 'Convert to track'
|
Caption = 'Convert to track'
|
||||||
TabOrder = 4
|
TabOrder = 2
|
||||||
OnClick = btnConvertToTrackClick
|
OnClick = btnConvertToTrackClick
|
||||||
end
|
end
|
||||||
object btnConvertToArea: TButton
|
object btnConvertToArea: TButton
|
||||||
AnchorSideLeft.Control = btnDeleteSelection
|
AnchorSideLeft.Control = btnDeleteSelection
|
||||||
AnchorSideTop.Control = btnConvertToTrack
|
AnchorSideTop.Control = btnConvertToTrack
|
||||||
AnchorSideTop.Side = asrBottom
|
AnchorSideTop.Side = asrBottom
|
||||||
Left = 715
|
Left = 503
|
||||||
Height = 25
|
Height = 25
|
||||||
Top = 58
|
Top = 58
|
||||||
Width = 107
|
Width = 107
|
||||||
AutoSize = True
|
AutoSize = True
|
||||||
Caption = 'Convert to area'
|
Caption = 'Convert to area'
|
||||||
TabOrder = 5
|
TabOrder = 3
|
||||||
OnClick = btnConvertToAreaClick
|
OnClick = btnConvertToAreaClick
|
||||||
end
|
end
|
||||||
object rgNewPointType: TRadioGroup
|
object rgNewPointType: TRadioGroup
|
||||||
AnchorSideLeft.Control = rgClickMode
|
AnchorSideLeft.Control = cgPointTypes
|
||||||
AnchorSideLeft.Side = asrBottom
|
AnchorSideLeft.Side = asrBottom
|
||||||
AnchorSideTop.Control = Panel1
|
AnchorSideTop.Control = Panel1
|
||||||
AnchorSideBottom.Control = btnConvertToArea
|
AnchorSideBottom.Control = btnConvertToArea
|
||||||
AnchorSideBottom.Side = asrBottom
|
AnchorSideBottom.Side = asrBottom
|
||||||
Left = 599
|
Left = 387
|
||||||
Height = 67
|
Height = 67
|
||||||
Top = 8
|
Top = 8
|
||||||
Width = 100
|
Width = 100
|
||||||
@ -226,9 +178,20 @@ object MainForm: TMainForm
|
|||||||
'TGPSPoint'
|
'TGPSPoint'
|
||||||
'TMapPoint'
|
'TMapPoint'
|
||||||
)
|
)
|
||||||
TabOrder = 6
|
TabOrder = 4
|
||||||
OnClick = rgNewPointTypeClick
|
OnClick = rgNewPointTypeClick
|
||||||
end
|
end
|
||||||
|
object Label3: TLabel
|
||||||
|
AnchorSideLeft.Control = Label1
|
||||||
|
AnchorSideTop.Control = Label1
|
||||||
|
AnchorSideTop.Side = asrBottom
|
||||||
|
Left = 8
|
||||||
|
Height = 105
|
||||||
|
Top = 109
|
||||||
|
Width = 437
|
||||||
|
BorderSpacing.Bottom = 8
|
||||||
|
Caption = 'Select a single point --> Left-click'#13#10'Select all points of track or area --> SHIFT+left-click'#13#10'Select all points contained in dragged rectangle --> ALT + left-click'#13#10'Create a new point --> Right-click'#13#10'Extend selection --> Hold CTRL key down'#13#10'Delete selection --> DEL key (or click "Delete selection" button'#13#10'Move selection --> Drag with mouse(left button down) or press arrow keys (+/- 1°)'
|
||||||
|
end
|
||||||
end
|
end
|
||||||
object PluginManager: TMvPluginManager
|
object PluginManager: TMvPluginManager
|
||||||
Left = 401
|
Left = 401
|
||||||
|
@ -19,25 +19,24 @@ type
|
|||||||
btnConvertToTrack: TButton;
|
btnConvertToTrack: TButton;
|
||||||
btnConvertToArea: TButton;
|
btnConvertToArea: TButton;
|
||||||
cgPointTypes: TCheckGroup;
|
cgPointTypes: TCheckGroup;
|
||||||
cbExtendSelection: TCheckBox;
|
|
||||||
Label1: TLabel;
|
Label1: TLabel;
|
||||||
Label2: TLabel;
|
Label2: TLabel;
|
||||||
|
Label3: TLabel;
|
||||||
Panel1: TPanel;
|
Panel1: TPanel;
|
||||||
POI_Images: TImageList;
|
POI_Images: TImageList;
|
||||||
MapView: TMapView;
|
MapView: TMapView;
|
||||||
PluginManager: TMvPluginManager;
|
PluginManager: TMvPluginManager;
|
||||||
rgNewPointType: TRadioGroup;
|
rgNewPointType: TRadioGroup;
|
||||||
rgClickMode: TRadioGroup;
|
|
||||||
procedure btnDeleteSelectionClick(Sender: TObject);
|
procedure btnDeleteSelectionClick(Sender: TObject);
|
||||||
procedure btnConvertToTrackClick(Sender: TObject);
|
procedure btnConvertToTrackClick(Sender: TObject);
|
||||||
procedure btnConvertToAreaClick(Sender: TObject);
|
procedure btnConvertToAreaClick(Sender: TObject);
|
||||||
procedure cgPointTypesItemClick(Sender: TObject; Index: integer);
|
procedure cgPointTypesItemClick(Sender: TObject; Index: integer);
|
||||||
procedure cbExtendSelectionChange(Sender: TObject);
|
|
||||||
procedure FormCreate(Sender: TObject);
|
procedure FormCreate(Sender: TObject);
|
||||||
procedure rgClickModeClick(Sender: TObject);
|
|
||||||
procedure rgNewPointTypeClick(Sender: TObject);
|
procedure rgNewPointTypeClick(Sender: TObject);
|
||||||
private
|
private
|
||||||
Plugin: TMarkerEditorPlugin;
|
Plugin: TMarkerEditorPlugin;
|
||||||
|
procedure MapViewKeyDownHandler(Sender: TObject; var Key: Word;
|
||||||
|
Shift: TShiftState);
|
||||||
procedure NewPointHandler(AMapView: TMapView; APoint: TGPSPoint);
|
procedure NewPointHandler(AMapView: TMapView; APoint: TGPSPoint);
|
||||||
public
|
public
|
||||||
|
|
||||||
@ -174,13 +173,38 @@ begin
|
|||||||
Plugin := TMarkerEditorPlugin.Create(PluginManager);
|
Plugin := TMarkerEditorPlugin.Create(PluginManager);
|
||||||
Plugin.OnNewPoint := @NewPointHandler;
|
Plugin.OnNewPoint := @NewPointHandler;
|
||||||
|
|
||||||
|
MapView.TabStop := true;
|
||||||
|
MapView.OnKeyDown := @MapViewKeydownHandler;
|
||||||
|
|
||||||
for i := 0 to cgPointTypes.Items.Count-1 do
|
for i := 0 to cgPointTypes.Items.Count-1 do
|
||||||
cgPointTypes.Checked[i] := true;
|
cgPointTypes.Checked[i] := true;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TMainForm.rgClickModeClick(Sender: TObject);
|
procedure TMainForm.MapViewKeyDownHandler(Sender: TObject; var Key: Word;
|
||||||
|
Shift: TShiftState);
|
||||||
begin
|
begin
|
||||||
Plugin.ClickMode := TMarkerClickMode(rgClickMode.ItemIndex);
|
if MapView.Focused then
|
||||||
|
case Key of
|
||||||
|
VK_DELETE:
|
||||||
|
if (Plugin.Selection.Count > 0) and
|
||||||
|
(MessageDlg('Delete selected points?', mtConfirmation, [mbYes, mbNo], 0) = mrYes) then
|
||||||
|
begin
|
||||||
|
Plugin.DeleteSelectedPoints(MapView);
|
||||||
|
end;
|
||||||
|
VK_LEFT:
|
||||||
|
Plugin.MoveSelectionBy(MapView, -1.0, 0.0);
|
||||||
|
VK_RIGHT:
|
||||||
|
Plugin.MoveSelectionBy(MapView, +1.0, 0.0);
|
||||||
|
VK_UP:
|
||||||
|
Plugin.MoveSelectionBy(MapView, 0.0, 1.0);
|
||||||
|
VK_DOWN:
|
||||||
|
Plugin.MoveSelectionBy(MapView, 0.0, -1.0);
|
||||||
|
else
|
||||||
|
inherited;
|
||||||
|
exit;
|
||||||
|
end;
|
||||||
|
MapView.Invalidate;
|
||||||
|
Key := 0;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TMainForm.rgNewPointTypeClick(Sender: TObject);
|
procedure TMainForm.rgNewPointTypeClick(Sender: TObject);
|
||||||
@ -247,11 +271,6 @@ begin
|
|||||||
inc(counter);
|
inc(counter);
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TMainForm.cbExtendSelectionChange(Sender: TObject);
|
|
||||||
begin
|
|
||||||
Plugin.ExtendSelection := cbExtendSelection.Checked;
|
|
||||||
end;
|
|
||||||
|
|
||||||
procedure TMainForm.NewPointHandler(AMapView: TMapView; APoint: TGPSPoint);
|
procedure TMainForm.NewPointHandler(AMapView: TMapView; APoint: TGPSPoint);
|
||||||
begin
|
begin
|
||||||
if (Plugin.NewPointType = nptMapPoint) and (APoint is TGPSPointOfInterest) then
|
if (Plugin.NewPointType = nptMapPoint) and (APoint is TGPSPointOfInterest) then
|
||||||
|
@ -154,6 +154,11 @@ type
|
|||||||
DEFAULT_RUBBERBAND_BORDERCOLOR = clGray;
|
DEFAULT_RUBBERBAND_BORDERCOLOR = clGray;
|
||||||
DEFAULT_RUBBERBAND_FILLCOLOR = clWhite;
|
DEFAULT_RUBBERBAND_FILLCOLOR = clWhite;
|
||||||
DEFAULT_RUBBERBAND_OPACITY = 0.55;
|
DEFAULT_RUBBERBAND_OPACITY = 0.55;
|
||||||
|
DEFAULT_SHIFT_FOR_NEW_POINT = [ssRight];
|
||||||
|
DEFAULT_SHIFT_TO_SELECT_POINT = [ssLeft];
|
||||||
|
DEFAULT_SHIFT_TO_SELECT_SHAPE = [ssLeft, ssShift];
|
||||||
|
DEFAULT_SHIFT_TO_SELECT_BY_RUBBERBAND = [ssLeft, ssAlt];
|
||||||
|
DEFAULT_SHIFT_TO_EXTEND_SELECTION = [ssCtrl]; // to be used in addition to the others
|
||||||
private
|
private
|
||||||
FClickMode: TMarkerClickMode;
|
FClickMode: TMarkerClickMode;
|
||||||
FDragCursor: TCursor;
|
FDragCursor: TCursor;
|
||||||
@ -167,6 +172,11 @@ type
|
|||||||
FRubberbandStartPt: TPoint;
|
FRubberbandStartPt: TPoint;
|
||||||
FRubberbandEndPt: TPoint;
|
FRubberbandEndPt: TPoint;
|
||||||
FSelection: TGPSPointList;
|
FSelection: TGPSPointList;
|
||||||
|
FShiftForNewPoint: TShiftState;
|
||||||
|
FShiftToSelectPoint: TShiftState;
|
||||||
|
FShiftToSelectShape: TShiftState;
|
||||||
|
FShiftToSelectByRubberband: TShiftState;
|
||||||
|
FShiftToExtendSelection: TShiftState;
|
||||||
FOrigSelection: array of TRealPoint; // Selection before dragging starts
|
FOrigSelection: array of TRealPoint; // Selection before dragging starts
|
||||||
FOnDrawPoint: TMarkerDrawPointEvent;
|
FOnDrawPoint: TMarkerDrawPointEvent;
|
||||||
FOnNewPoint: TMarkerNewPointEvent;
|
FOnNewPoint: TMarkerNewPointEvent;
|
||||||
@ -188,6 +198,7 @@ type
|
|||||||
procedure DrawSelection(AMapView: TMapView);
|
procedure DrawSelection(AMapView: TMapView);
|
||||||
procedure FindContainerOfPoint(AMapView: TMapView; APoint: TGPSPoint; var AContainer: TGPSObj; var AIndex: Integer);
|
procedure FindContainerOfPoint(AMapView: TMapView; APoint: TGPSPoint; var AContainer: TGPSObj; var AIndex: Integer);
|
||||||
procedure FindMapCollection(AMapView: TMapView; APoint: TGPSPoint; var ACollection: TMapCollectionBase; var AIndex: Integer);
|
procedure FindMapCollection(AMapView: TMapView; APoint: TGPSPoint; var ACollection: TMapCollectionBase; var AIndex: Integer);
|
||||||
|
function IsShiftOfClickMode(AShift: TShiftState; AClickMode: TMarkerClickMode): Boolean;
|
||||||
function RubberbandRect: TRect;
|
function RubberbandRect: TRect;
|
||||||
procedure RubberbandStart(AMapView: TMapView; X, Y: Integer);
|
procedure RubberbandStart(AMapView: TMapView; X, Y: Integer);
|
||||||
procedure RubberbandTo(AMapView: TMapView; X, Y: Integer);
|
procedure RubberbandTo(AMapView: TMapView; X, Y: Integer);
|
||||||
@ -216,14 +227,23 @@ type
|
|||||||
procedure SelectInRubberband(AMapView: TMapView);
|
procedure SelectInRubberband(AMapView: TMapView);
|
||||||
property Selection: TGPSPointList read FSelection;
|
property Selection: TGPSPointList read FSelection;
|
||||||
published
|
published
|
||||||
property ClickMode: TMarkerClickMode read FClickMode write FClickMode default DEFAULT_CLICKMODE;
|
// property ClickMode: TMarkerClickMode read FClickMode write FClickMode default DEFAULT_CLICKMODE;
|
||||||
property DragCursor: TCursor read FDragCursor write FDragCursor default crSizeAll;
|
property DragCursor: TCursor read FDragCursor write FDragCursor default crSizeAll;
|
||||||
property ExtendSelection: Boolean read FExtendSelection write SetExtendSelection default false;
|
// property ExtendSelection: Boolean read FExtendSelection write SetExtendSelection default false;
|
||||||
property NewPointType: TMarkerNewPointType read FNewPointType write FNewPointType default nptGPSPoint;
|
property NewPointType: TMarkerNewPointType read FNewPointType write FNewPointType default nptGPSPoint;
|
||||||
property RubberbandBorderColor: TColor read FRubberbandBorderColor write FRubberbandBorderColor default DEFAULT_RUBBERBAND_BORDERCOLOR;
|
property RubberbandBorderColor: TColor read FRubberbandBorderColor write FRubberbandBorderColor default DEFAULT_RUBBERBAND_BORDERCOLOR;
|
||||||
property RubberbandFillColor: TColor read FRubberbandFillColor write FRubberbandFillColor default DEFAULT_RUBBERBAND_FILLCOLOR;
|
property RubberbandFillColor: TColor read FRubberbandFillColor write FRubberbandFillColor default DEFAULT_RUBBERBAND_FILLCOLOR;
|
||||||
property RubberbandOpacity: Single read FRubberbandOpacity write FRubberbandOpacity stored IsOpacityStored;
|
property RubberbandOpacity: Single read FRubberbandOpacity write FRubberbandOpacity stored IsOpacityStored;
|
||||||
property Shift;
|
property ShiftForNewPoint: TShiftState read FShiftForNewPoint write FShiftForNewPoint
|
||||||
|
default DEFAULT_SHIFT_FOR_NEW_POINT;
|
||||||
|
property ShiftToExtendSelection: TShiftState read FShiftToExtendSelection write FShiftToExtendSelection
|
||||||
|
default DEFAULT_SHIFT_TO_EXTEND_SELECTION;
|
||||||
|
property ShiftToSelectPoint: TShiftState read FShiftToSelectPoint write FShiftToSelectPoint
|
||||||
|
default DEFAULT_SHIFT_TO_SELECT_POINT;
|
||||||
|
property ShiftToSelectShape: TShiftState read FShiftToSelectShape write FShiftToSelectShape
|
||||||
|
default DEFAULT_SHIFT_TO_SELECT_SHAPE;
|
||||||
|
property ShiftToSelectByRubberband: TShiftState read FShiftToSelectByRubberband write FShiftToSelectByRubberband
|
||||||
|
default DEFAULT_SHIFT_TO_SELECT_BY_RUBBERBAND;
|
||||||
property OnDrawPoint: TMarkerDrawPointEvent read FOnDrawPoint write FOnDrawPoint;
|
property OnDrawPoint: TMarkerDrawPointEvent read FOnDrawPoint write FOnDrawPoint;
|
||||||
property OnEndDrag: TNotifyEvent read FOnEndDrag write FOnEndDrag;
|
property OnEndDrag: TNotifyEvent read FOnEndDrag write FOnEndDrag;
|
||||||
property OnNewPoint: TMarkerNewPointEvent read FOnNewPoint write FOnNewPoint;
|
property OnNewPoint: TMarkerNewPointEvent read FOnNewPoint write FOnNewPoint;
|
||||||
@ -477,6 +497,11 @@ begin
|
|||||||
FRubberbandFillColor := DEFAULT_RUBBERBAND_FILLCOLOR;
|
FRubberbandFillColor := DEFAULT_RUBBERBAND_FILLCOLOR;
|
||||||
FRubberbandOpacity := DEFAULT_RUBBERBAND_OPACITY;
|
FRubberbandOpacity := DEFAULT_RUBBERBAND_OPACITY;
|
||||||
FSelection := TGPSPointList.Create(false); // false = do not free objects
|
FSelection := TGPSPointList.Create(false); // false = do not free objects
|
||||||
|
FShiftForNewPoint := DEFAULT_SHIFT_FOR_NEW_POINT;
|
||||||
|
FShiftToSelectPoint := DEFAULT_SHIFT_TO_SELECT_POINT;
|
||||||
|
FShiftToSelectShape := DEFAULT_SHIFT_TO_SELECT_SHAPE;
|
||||||
|
FShiftToSelectByRubberband := DEFAULT_SHIFT_TO_SELECT_BY_RUBBERBAND;
|
||||||
|
FShiftToExtendSelection := [ssCtrl]; // modifier to the others to add point(s) to current selection
|
||||||
end;
|
end;
|
||||||
|
|
||||||
destructor TMarkerEditorPlugin.Destroy;
|
destructor TMarkerEditorPlugin.Destroy;
|
||||||
@ -889,7 +914,26 @@ begin
|
|||||||
Result := FRubberbandOpacity <> DEFAULT_RUBBERBAND_OPACITY;
|
Result := FRubberbandOpacity <> DEFAULT_RUBBERBAND_OPACITY;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
{ Moves the selection by the given amound of pixels in x and y direction. }
|
function TMarkerEditorPlugin.IsShiftOfClickMode(AShift: TShiftState;
|
||||||
|
AClickMode: TMarkerClickMode): Boolean;
|
||||||
|
begin
|
||||||
|
case AClickMode of
|
||||||
|
cmNewPoint:
|
||||||
|
Result := (AShift = FShiftForNewPoint) or
|
||||||
|
(AShift = FShiftForNewPoint + FShiftToExtendSelection);
|
||||||
|
cmSelectPoint:
|
||||||
|
Result := (AShift = FShiftToSelectPoint) or
|
||||||
|
(AShift = FShiftToSelectPoint + FShiftToExtendSelection);
|
||||||
|
cmSelectShape:
|
||||||
|
Result := (AShift = FShiftToSelectShape) or
|
||||||
|
(AShift = FShiftToSelectShape + FShiftToExtendSelection);
|
||||||
|
cmRubberband:
|
||||||
|
Result := (AShift = FShiftToSelectByRubberband) or
|
||||||
|
(AShift = FShiftToSelectByRubberBand + FShiftToExtendSelection);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ Moves the selection by the given pixel count in x and y direction. }
|
||||||
procedure TMarkerEditorPlugin.MoveSelectionBy(AMapView: TMapView; dx, dy: Integer);
|
procedure TMarkerEditorPlugin.MoveSelectionBy(AMapView: TMapView; dx, dy: Integer);
|
||||||
var
|
var
|
||||||
i: Integer;
|
i: Integer;
|
||||||
@ -906,7 +950,7 @@ begin
|
|||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
{ Moves the selection by the given amound of degrees in x and y direction }
|
{ Moves the selection by the given amount of degrees in x and y direction }
|
||||||
procedure TMarkerEditorPlugin.MoveSelectionBy(AMapView: TMapView; dx, dy: Double);
|
procedure TMarkerEditorPlugin.MoveSelectionBy(AMapView: TMapView; dx, dy: Double);
|
||||||
var
|
var
|
||||||
i: Integer;
|
i: Integer;
|
||||||
@ -918,10 +962,6 @@ begin
|
|||||||
rPt := FSelection[i].RealPoint;
|
rPt := FSelection[i].RealPoint;
|
||||||
rPt.Lon := FSelection[i].Lon + dX;
|
rPt.Lon := FSelection[i].Lon + dX;
|
||||||
rPt.Lat := FSelection[i].Lat + dY;
|
rPt.Lat := FSelection[i].Lat + dY;
|
||||||
if rPt.Lat > 90 then
|
|
||||||
rPt.Lat := rPt.Lat - 180;
|
|
||||||
if rPt.Lon < -90 then
|
|
||||||
rPt.Lon := rPt.Lon + 180;
|
|
||||||
P := AMapView.LatLonToScreen(rPt);
|
P := AMapView.LatLonToScreen(rPt);
|
||||||
rPt := AMapView.ScreenToLatLon(P);
|
rPt := AMapView.ScreenToLatLon(P);
|
||||||
FSelection[i].MoveTo(rPt.Lon, rPt.Lat);
|
FSelection[i].MoveTo(rPt.Lon, rPt.Lat);
|
||||||
@ -932,6 +972,31 @@ procedure TMarkerEditorPlugin.MouseDown(AMapView: TMapView;
|
|||||||
{%H-}Button: TMouseButton; {%H-}AShift: TShiftState;
|
{%H-}Button: TMouseButton; {%H-}AShift: TShiftState;
|
||||||
X, Y: Integer; var Handled: Boolean);
|
X, Y: Integer; var Handled: Boolean);
|
||||||
begin
|
begin
|
||||||
|
if IsShiftOfClickMode(AShift, cmNewPoint) then
|
||||||
|
begin
|
||||||
|
FClickMode := cmNewPoint;
|
||||||
|
Shift := FShiftForNewPoint;
|
||||||
|
end else
|
||||||
|
if IsShiftOfClickMode(AShift, cmRubberband) then
|
||||||
|
begin
|
||||||
|
FClickMode := cmRubberband;
|
||||||
|
Shift := FShiftToSelectPoint;
|
||||||
|
end else
|
||||||
|
if IsShiftOfClickMode(AShift, cmSelectShape) then
|
||||||
|
begin
|
||||||
|
FClickMode := cmSelectShape;
|
||||||
|
Shift := FShiftToSelectShape;
|
||||||
|
end else
|
||||||
|
if IsShiftOfClickMode(AShift, cmSelectPoint) then
|
||||||
|
begin
|
||||||
|
FClickMode := cmSelectPoint;
|
||||||
|
Shift := FShiftToSelectPoint;
|
||||||
|
end else
|
||||||
|
exit;
|
||||||
|
|
||||||
|
FExtendSelection := (AShift * FShiftToExtendSelection = FShiftToExtendSelection);
|
||||||
|
if FExtendSelection then Shift := Shift + FShiftToExtendSelection;
|
||||||
|
|
||||||
inherited;
|
inherited;
|
||||||
|
|
||||||
if FMouseDownOnMarker then
|
if FMouseDownOnMarker then
|
||||||
@ -989,7 +1054,7 @@ begin
|
|||||||
DragTo(AMapView, X, Y);
|
DragTo(AMapView, X, Y);
|
||||||
Handled := true;
|
Handled := true;
|
||||||
end else
|
end else
|
||||||
if not FDragging and (FClickMode = cmRubberband) and (Shift = AShift) then
|
if not FDragging and (FClickMode = cmRubberband) and IsShiftOfClickMode(AShift, cmRubberband) then
|
||||||
begin
|
begin
|
||||||
if not FRubberbandMode then
|
if not FRubberbandMode then
|
||||||
RubberbandStart(AMapView, X, Y)
|
RubberbandStart(AMapView, X, Y)
|
||||||
|
Loading…
Reference in New Issue
Block a user