Package org.ka2ddo.yaac.core
Interface FullGeoMapIfc
- All Superinterfaces:
GeoMapIfc
- All Known Implementing Classes:
GeographicalMap
This interface defines GUI-platform-independent methods for manipulating a fully-detailed map display in YAAC.
- Author:
- Andrew Pavlin, KA2DDO
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addSpecificTrackStripe
(String identifier) Add the identifier of a single station or object whose track stripe is to be plotted.void
Clear the plotting of all specific station/object track stripes.void
copyLocationToClipboard
(int mouseX, int mouseY) Copy the mouse cursor's position on the map to the system clipboard as a CSV-formatted latitude,longitude string in fractional degrees North,East.void
Display the Locate Amenity dialog, and handle user input to it.void
Display the Severe Weather dialog.void
Invoke an editor for adjusting the colors and elevation thresholds used to render topographic map layers.long
Return the amount of time (in milliseconds) for the last station render.int
Return the number of Objects (non-transmitters) rendered in the last station render.int
Return the number of stations (transmitters) rendered in the last station render.double[]
getLatLonOfMouseClick
(int mouseX, int mouseY) Convert pixel coordinates on the map window into a latitude and longitude value pair.long
Get the maximum time that dead reckoning will be projected for an object (non-self-transmitter).long
long
Get the maximum time that dead reckoning will be projected for a station (self-transmitter).long
Get the maximum duration of a track stripe in milliseconds.boolean
Report whether the time interval since last receipt of a message from or about a station or object is plotted below the station/object's name.boolean
Indicate whether all moving stations should have track stripes plotted.boolean
Report whether aloha circles (optimal maximum RF transmission range for the local station before causing excessive collisions) are plotted on the map.boolean
Report whether Objects that have been "killed" are plotted on the map.boolean
Report whether deadreckoning position updates for moving stations and objects are calculated and the positions offset and deadreckoning vectors plotted when the stations and objecfts are drawn.boolean
isDrawDF()
Report whether direction-finding cones are plotted from stations reporting DFS vector informationboolean
Report if digipeater hop paths are drawn for stations.boolean
Report if heat maps are drawn for stations.boolean
Report whether encoded polylines (generally used for National Weather Service severe weather regions) are plotted on the map.boolean
Report whether the motion speed and bearing of a station or object should be plotted below the station/object's name.boolean
Report whether weather stations are drawn as old-style weather map circles with a flagged barb indicating wind direction and speed.boolean
Indicate whether the graticule (latitude/longitude grid lines) are displayed on the map.boolean
Report whether the map should auto-pan to keep specifically tracked mobile stations on the map.boolean
Indicate whether severe weather zone boundaries should be drawn on the map.boolean
Report whether the topographic map should be rendered as contour lines.boolean
Report whether the topographic map overlay should be displayed as filled regions.boolean
isSpecificallyTracked
(String identifier) Test if a given identifier is on the tracking list.boolean
Test if any identifiers are on the tracking list.void
Load drawing overlay.void
moveObject
(StationState ss, ObjectReport or, MoveObjectListener moveObjectListener) Graphically drag a station or object across the map to a new location, updating the object's position appropriately and converting a station to an object if needed.void
panZoomToWeatherZone
(int zoneRowIndex) Pan and zoom the map to show a specific severe weather zone.void
Force the topographic layer to regenerate its overlay immediately.boolean
removeSpecificTrackStripe
(String identifier) Remove the identifier of a single station or object whose track stripe is no longer to be plotted.void
setDrawAge
(boolean drawAge) Specify whether the time interval since last receipt of a message from or about a station or object should be plotted below the station/object's name.void
setDrawAllTrackStripes
(boolean drawAllTrackStripes) Specify whether all moving stations should have track stripes plotted.void
setDrawAlohaCircle
(boolean drawAlohaCircle) Specify whether aloha circles (optimal maximum RF transmission range for the local station before causing excessive collisions) should be plotted on the map.void
setDrawDeadObjects
(boolean drawDeadObjects) Specify whether Objects that have been "killed" should still be plotted on the map.void
setDrawDeadReckoning
(boolean drawDeadReckoning) Specify whether deadreckoning position updates for moving stations and objects should be calculated and the positions offset and deadreckoning vectors plotted when the stations and objecfts are drawn.void
setDrawDF
(boolean drawDF) Specify whether direction-finding cones should be plotted from stations reporting DFS vector informationvoid
setDrawDigipeatHops
(boolean drawDigipeatHops) Specify whether digipeater hop paths should be drawn for stations.void
setDrawHeatMap
(boolean drawHeatMap) Specify whether heat maps should be drawn for stations.void
setDrawNWSMultiLine
(boolean drawNWSMultiLine) Specify whether encoded polylines (generally used for National Weather Service severe weather regions) should be plotted on the map.void
setDrawSpeed
(boolean drawSpeed) Specify whether the motion speed and bearing of a station or object should be plotted below the station/object's name.void
setDrawToolBarVisibility
(boolean isVisible) Specify whether the toolbar for the drawing tools should be visible or not.void
setDrawWeatherAsWeather
(boolean drawWeatherAsWeather) Specify whether weather stations should be drawn as old-style weather map circles with a flagged barb indicating wind direction and speed.void
setGraticuleVisible
(boolean visible) Specify whether the graticule (latitude/longitude grid lines) are displayed on the map.void
setKeepSpecificallyTrackedStationsOnScreen
(boolean keepSpecificallyTrackedStationsOnScreen) Specify whether the map should auto-pan to keep specifically tracked mobile stations on the map.void
setMaxAgeDRObject
(long maxAgeDRObject) Set the maximum time that dead reckoning will be projected for an object (non-self-transmitter).void
setMaxAgeDRSpecialObject
(long maxAgeDRSpecialObject) void
setMaxAgeDRStation
(long maxAgeDRStation) Set the maximum time that dead reckoning will be projected for a station (self-transmitter).void
setMaxTrackDuration
(long maxTrackDuration) Set the maximum duration of a track stripe in milliseconds.void
setShowSevereWeatherZones
(boolean showSevereWeatherZones) Specify whether severe weather zone boundaries should be drawn on the map.void
setShowTopoContours
(boolean visible) Specify whether the topographic map overlay should be rendered as contour lines.void
setShowTopoRegions
(boolean visible) Specify whether the topographic map overlay should be rendered as filled region.void
Display the dialog for selecting which parts of the OpenStreetMap database should be rendered on the map.void
Display the dialog for managing raster map images overlays on the map window.void
Enable defining a line of sight between two points on the map.void
startLineOfSightFromHere
(int mouseX, int mouseY) Enable defining a line of sight starting at the specified position on the map.void
startLineOfSightFromMe
(int mouseX, int mouseY) Show the line of sight between this station's position and the position clicked on the map, updating this station's end of the line if it moves.void
Show the line of sight between this station's position and the station or object clicked on the map, updating both ends of the line if either moves.Methods inherited from interface org.ka2ddo.yaac.core.GeoMapIfc
displayAttentionAlert, flushFileCache, getBottomLatitude, getCenterLatitude, getCenterLongitude, getLeftLongitude, getRightLongitude, getScale, getTopLatitude, getZoomScale, isAutoLoadMapTiles, isDontRotateIcons, isDrawAliasInsteadOfCallsign, isDrawAmbiguityCircle, isDrawCallsign, isDrawDoubleSizedSymbols, isDrawItemStatus, isDrawMicEStatusCircles, isDrawRangeCircles, isDrawSelf, isDrawSelfLikeOther, isMapAutoCentered, isMapCenteredOnAlerts, isNightMode, isShowLabelsInEnglish, isShowUnlabeledWays, loadGpsLog, locateASpecificStation, refresh, regenerateStations, setAutoLoadMapTiles, setCenter, setCenter, setDontRotateIcons, setDrawAliasInsteadOfCallsign, setDrawAmbiguityCircle, setDrawCallsign, setDrawDoubleSizedSymbols, setDrawItemStatus, setDrawMicEStatusCircles, setDrawRangeCircles, setDrawSelf, setDrawSelfLikeOther, setMapAutoCentering, setMemoryGCPanelVisible, setNightMode, setScale, setShowLabelsInEnglish, setShowUnlabeledWays, setVisible, toFront, zoomPanToSelectedFeature
-
Method Details
-
showLayerSelectorTool
void showLayerSelectorTool()Display the dialog for selecting which parts of the OpenStreetMap database should be rendered on the map. -
showRasterMapDialog
void showRasterMapDialog()Display the dialog for managing raster map images overlays on the map window. -
regenerateTopo
void regenerateTopo()Force the topographic layer to regenerate its overlay immediately. -
displayLocateAmenityDialog
void displayLocateAmenityDialog()Display the Locate Amenity dialog, and handle user input to it. -
displayNWSActiveZonesDialog
void displayNWSActiveZonesDialog()Display the Severe Weather dialog. -
loadDrawing
void loadDrawing()Load drawing overlay. -
moveObject
Graphically drag a station or object across the map to a new location, updating the object's position appropriately and converting a station to an object if needed.- Parameters:
ss
- StationState object describing the station or objector
- ObjectReport to be modified by the movemoveObjectListener
- MoveObjectListener to inform when movement is over
-
setDrawToolBarVisibility
void setDrawToolBarVisibility(boolean isVisible) Specify whether the toolbar for the drawing tools should be visible or not.- Parameters:
isVisible
- boolean true if draw toolbar should be shown
-
isGraticuleVisible
boolean isGraticuleVisible()Indicate whether the graticule (latitude/longitude grid lines) are displayed on the map.- Returns:
- boolean true if graticule is displayed
-
setGraticuleVisible
void setGraticuleVisible(boolean visible) Specify whether the graticule (latitude/longitude grid lines) are displayed on the map.- Parameters:
visible
- boolean true if graticule is displayed
-
isShowTopoRegions
boolean isShowTopoRegions()Report whether the topographic map overlay should be displayed as filled regions.- Returns:
- boolean true if topographic overlay is displayed
-
setShowTopoRegions
void setShowTopoRegions(boolean visible) Specify whether the topographic map overlay should be rendered as filled region. Note this is independent of whether there actually is any topographic data to render.- Parameters:
visible
- boolean true if topographic layer should be rendered as regions
-
isShowTopoContours
boolean isShowTopoContours()Report whether the topographic map should be rendered as contour lines.- Returns:
- boolean true if topography should be rendered as contour lines
-
setShowTopoContours
void setShowTopoContours(boolean visible) Specify whether the topographic map overlay should be rendered as contour lines. Note this is independent of whether there actually is any topographic data to render.- Parameters:
visible
- boolean true if topographic layer should be rendered as contour lines
-
editTopoColors
void editTopoColors()Invoke an editor for adjusting the colors and elevation thresholds used to render topographic map layers. -
startLineOfSight
void startLineOfSight()Enable defining a line of sight between two points on the map. -
startLineOfSightFromMe
void startLineOfSightFromMe(int mouseX, int mouseY) Show the line of sight between this station's position and the position clicked on the map, updating this station's end of the line if it moves.- Parameters:
mouseX
- int horizontal pixel coordinate in mapmouseY
- int vertical pixel coordinate in map
-
startLineOfSightFromHere
void startLineOfSightFromHere(int mouseX, int mouseY) Enable defining a line of sight starting at the specified position on the map.- Parameters:
mouseX
- int horizontal pixel coordinate in mapmouseY
- int vertical pixel coordinate in map
-
startLineOfSightFromMe
Show the line of sight between this station's position and the station or object clicked on the map, updating both ends of the line if either moves.- Parameters:
ss
- StationState of station or object to trace the path to
-
isDrawWeatherAsWeather
boolean isDrawWeatherAsWeather()Report whether weather stations are drawn as old-style weather map circles with a flagged barb indicating wind direction and speed.- Returns:
- boolean true if weather stations should be plotted with weather map symbols, false if using APRS icon
-
setDrawWeatherAsWeather
void setDrawWeatherAsWeather(boolean drawWeatherAsWeather) Specify whether weather stations should be drawn as old-style weather map circles with a flagged barb indicating wind direction and speed.- Parameters:
drawWeatherAsWeather
- boolean true if weather stations should be plotted with weather map symbols, false if using APRS icon
-
isDrawAge
boolean isDrawAge()Report whether the time interval since last receipt of a message from or about a station or object is plotted below the station/object's name.- Returns:
- boolean true if age is to be plotted
-
setDrawAge
void setDrawAge(boolean drawAge) Specify whether the time interval since last receipt of a message from or about a station or object should be plotted below the station/object's name.- Parameters:
drawAge
- boolean true if age is to be plotted
-
isDrawSpeed
boolean isDrawSpeed()Report whether the motion speed and bearing of a station or object should be plotted below the station/object's name.- Returns:
- boolean true if speed is to be plotted
-
setDrawSpeed
void setDrawSpeed(boolean drawSpeed) Specify whether the motion speed and bearing of a station or object should be plotted below the station/object's name.- Parameters:
drawSpeed
- boolean true if mobile station speed and course is to be plotted
-
isDrawDeadObjects
boolean isDrawDeadObjects()Report whether Objects that have been "killed" are plotted on the map.- Returns:
- boolean true if "killed" Objects are plotted
-
setDrawDeadObjects
void setDrawDeadObjects(boolean drawDeadObjects) Specify whether Objects that have been "killed" should still be plotted on the map.- Parameters:
drawDeadObjects
- boolean true if "killed" Objects should be plotted
-
isDrawAlohaCircle
boolean isDrawAlohaCircle()Report whether aloha circles (optimal maximum RF transmission range for the local station before causing excessive collisions) are plotted on the map.- Returns:
- boolean true if aloha circles are drawn
-
setDrawAlohaCircle
void setDrawAlohaCircle(boolean drawAlohaCircle) Specify whether aloha circles (optimal maximum RF transmission range for the local station before causing excessive collisions) should be plotted on the map. Note these will only appear if the local station has RF ports that can have collisions.- Parameters:
drawAlohaCircle
- boolean true if aloha circles should be drawn
-
isDrawDeadReckoning
boolean isDrawDeadReckoning()Report whether deadreckoning position updates for moving stations and objects are calculated and the positions offset and deadreckoning vectors plotted when the stations and objecfts are drawn.- Returns:
- boolean true if deadreckoning is plotted
-
setDrawDeadReckoning
void setDrawDeadReckoning(boolean drawDeadReckoning) Specify whether deadreckoning position updates for moving stations and objects should be calculated and the positions offset and deadreckoning vectors plotted when the stations and objecfts are drawn.- Parameters:
drawDeadReckoning
- boolean true if deadreckoning should be plotted
-
getMaxAgeDRStation
long getMaxAgeDRStation()Get the maximum time that dead reckoning will be projected for a station (self-transmitter).- Returns:
- maximum dead reckon interval in milliseconds
-
setMaxAgeDRStation
void setMaxAgeDRStation(long maxAgeDRStation) Set the maximum time that dead reckoning will be projected for a station (self-transmitter).- Parameters:
maxAgeDRStation
- maximum dead reckon interval in milliseconds
-
getMaxAgeDRObject
long getMaxAgeDRObject()Get the maximum time that dead reckoning will be projected for an object (non-self-transmitter).- Returns:
- maximum dead reckon interval in milliseconds
-
setMaxAgeDRObject
void setMaxAgeDRObject(long maxAgeDRObject) Set the maximum time that dead reckoning will be projected for an object (non-self-transmitter).- Parameters:
maxAgeDRObject
- maximum dead reckon interval in milliseconds
-
getMaxAgeDRSpecialObject
long getMaxAgeDRSpecialObject() -
setMaxAgeDRSpecialObject
void setMaxAgeDRSpecialObject(long maxAgeDRSpecialObject) -
isDrawDF
boolean isDrawDF()Report whether direction-finding cones are plotted from stations reporting DFS vector information- Returns:
- boolean true if direction-finding cones are drawm
-
setDrawDF
void setDrawDF(boolean drawDF) Specify whether direction-finding cones should be plotted from stations reporting DFS vector information- Parameters:
drawDF
- boolean true if direction-finding cones should be drawm
-
isDrawNWSMultiLine
boolean isDrawNWSMultiLine()Report whether encoded polylines (generally used for National Weather Service severe weather regions) are plotted on the map.- Returns:
- boolean true if multilines are plotted
-
setDrawNWSMultiLine
void setDrawNWSMultiLine(boolean drawNWSMultiLine) Specify whether encoded polylines (generally used for National Weather Service severe weather regions) should be plotted on the map.- Parameters:
drawNWSMultiLine
- boolean true if multilines should be plotted
-
isShowSevereWeatherZones
boolean isShowSevereWeatherZones()Indicate whether severe weather zone boundaries should be drawn on the map.- Returns:
- boolean true if zones should be drawn
-
setShowSevereWeatherZones
void setShowSevereWeatherZones(boolean showSevereWeatherZones) Specify whether severe weather zone boundaries should be drawn on the map.- Parameters:
showSevereWeatherZones
- boolean true if zones should be drawn
-
isDrawAllTrackStripes
boolean isDrawAllTrackStripes()Indicate whether all moving stations should have track stripes plotted.- Returns:
- boolean true if all moving stations should have track stripes
-
setDrawAllTrackStripes
void setDrawAllTrackStripes(boolean drawAllTrackStripes) Specify whether all moving stations should have track stripes plotted.- Parameters:
drawAllTrackStripes
- boolean true if all moving stations should have track stripes
-
isKeepSpecificallyTrackedStationsOnScreen
boolean isKeepSpecificallyTrackedStationsOnScreen()Report whether the map should auto-pan to keep specifically tracked mobile stations on the map.- Returns:
- boolean true if map should pan to keep tracked stations on the map
-
setKeepSpecificallyTrackedStationsOnScreen
void setKeepSpecificallyTrackedStationsOnScreen(boolean keepSpecificallyTrackedStationsOnScreen) Specify whether the map should auto-pan to keep specifically tracked mobile stations on the map.- Parameters:
keepSpecificallyTrackedStationsOnScreen
- boolean true if map should pan to keep tracked stations on the map
-
clearAllSpecificTrackStripes
void clearAllSpecificTrackStripes()Clear the plotting of all specific station/object track stripes. -
addSpecificTrackStripe
Add the identifier of a single station or object whose track stripe is to be plotted.- Parameters:
identifier
- String station or object identifier
-
removeSpecificTrackStripe
Remove the identifier of a single station or object whose track stripe is no longer to be plotted.- Parameters:
identifier
- String station or object identifier- Returns:
- boolean true if identifier was removed
-
isSpecificallyTracked
Test if a given identifier is on the tracking list.- Parameters:
identifier
- String station or object identifier- Returns:
- boolean true if this identifier is marked for track stripe display
-
isSpecificallyTracking
boolean isSpecificallyTracking()Test if any identifiers are on the tracking list.- Returns:
- boolean true if any stations are specifically tagged for tracking
-
getMaxTrackDuration
long getMaxTrackDuration()Get the maximum duration of a track stripe in milliseconds.- Returns:
- maximum plotted track duration in milliseconds
-
setMaxTrackDuration
void setMaxTrackDuration(long maxTrackDuration) Set the maximum duration of a track stripe in milliseconds.- Parameters:
maxTrackDuration
- maximum plotted track duration in milliseconds
-
isDrawDigipeatHops
boolean isDrawDigipeatHops()Report if digipeater hop paths are drawn for stations.- Returns:
- boolean true if digipeater hop paths are drawn for stations
-
setDrawDigipeatHops
void setDrawDigipeatHops(boolean drawDigipeatHops) Specify whether digipeater hop paths should be drawn for stations.- Parameters:
drawDigipeatHops
- boolean true if digipeater hop paths should be drawn for stations
-
isDrawHeatMap
boolean isDrawHeatMap()Report if heat maps are drawn for stations.- Returns:
- boolean true if heat maps are drawn for stations
-
setDrawHeatMap
void setDrawHeatMap(boolean drawHeatMap) Specify whether heat maps should be drawn for stations.- Parameters:
drawHeatMap
- boolean true if heat maps should be drawn for stations
-
panZoomToWeatherZone
void panZoomToWeatherZone(int zoneRowIndex) Pan and zoom the map to show a specific severe weather zone.- Parameters:
zoneRowIndex
- zero-based row index into the table of severe weather zones
-
getLastElapsedPaintTime
long getLastElapsedPaintTime()Return the amount of time (in milliseconds) for the last station render.- Returns:
- elapsed time in milliseconds for last StationRenderer run
-
getLastNumDrawnObjects
int getLastNumDrawnObjects()Return the number of Objects (non-transmitters) rendered in the last station render.- Returns:
- count of rendered Objects
-
getLastNumDrawnStations
int getLastNumDrawnStations()Return the number of stations (transmitters) rendered in the last station render.- Returns:
- count of rendered stations
-
copyLocationToClipboard
void copyLocationToClipboard(int mouseX, int mouseY) Copy the mouse cursor's position on the map to the system clipboard as a CSV-formatted latitude,longitude string in fractional degrees North,East. If the current view is not a map, do nothing.- Parameters:
mouseX
- int pixel X coordinate of mouse clickmouseY
- int pixel Y coordinate of mouse click- Since:
- PROVIDER_API_VERSION == 45
-
getLatLonOfMouseClick
double[] getLatLonOfMouseClick(int mouseX, int mouseY) Convert pixel coordinates on the map window into a latitude and longitude value pair.- Parameters:
mouseX
- int zero-based X coordinate within the map widgetmouseY
- int zero-based Y coordinate within the map widget- Returns:
- array of latitude [0] and longitude [1] corresponding to the pixel coordinates
- Since:
- PROVIDER_API_VERSION == 45
-