Browse samples per component: All installed
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to decode vector data in various formats and export them as a GeoJson file.
Run the sample using the shell script in the samples
folder:
encoder.geojson.bat <input_vector_data> <output_geojson>
The input consists of two parameters: (1) the path to the input vector file (for example, in SHP format), and (2), the path of the output GeoJson file.
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to decode vector data in various formats and export them as a MIF file.
Run the sample using the shell script in the samples
folder:
encoder.mif.bat <input_vector_data> <output_mif>
The input consists of two parameters: (1) the path to the input vector file (for example, in SHP format), and (2), the path of the output MIF file.
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to decode rasters in various format and encode them in GeoTIFF format, using a TLcdGeoTIFFModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.raster.geotiff.bat [options] <input_raster> [...] <output_geotiff>
The input can be a single raster or a list of rasters that lie on a regular grid. The sample automatically figures out the structure of the grid and creates a composite raster that can be saved. The code may be generally useful for creating such composite rasters. They are more efficient to work with than the original unstructured list of rasters, for instance for analysis or for visualization.
The output GeoTIFFs are tiled and multi-leveled, and optionally compressed with JPEG compression. The default tile size is 256x256 pixels. The default number of levels is 5. The JPEG compression quality is a specified value between 0 and 1.
The supported options are:
-levels <n> -tilesize <n> -jpeg <f> -bigtiff
This sample demonstrates how to create your own balloons. Just click any of the domain objects to see an example of a balloon in action. Of the 4 domain objects 3 have a balloon attached to them.
This sample demonstrates how to create your own balloons. Select a domain object to see an example of a balloon in action. Balloons are only shown when one domain object is selected.
One of the objects contains a balloon with a button that can be used to close itself. Another balloon shows an image, and another one shows a text label. The last domain object doesn't have a balloon attached to it.
You can move around balloons by dragging near their border. Balloons can be rescaled by dragging their lower right corner. The can also be closed by clicking the exit icon in the upper right corner.
This sample shows you how to map raster data values to colors using TLcdColorMap
, and how
to interactively customize such a map using TLcdColorMapCustomizer
.
The sample shows elevation data that can be customized using the configuration panel.
The color map customizer allows configuring the following:
This sample demonstrates the ability to paint asynchronously. It shows how to instantiate an asynchronously painted layer and a paint queue that handles the actual painting. The layer is then painted in the background, in a separate thread, so the painting no longer blocks the user interface.
It also illustrates how to automatically assign paint queues to the asynchronous layers by using several paint queue managers which can be activated one-by-one:
The sample shows a number of layers that are painted asynchronously. Layers sharing a paint queue have the same color in the layer control. For illustration purposes, some layers have a fixed paint time, which is indicated in between square brackets.
Try panning and zooming with the mouse wheel. New layer contents are added after the operations. The layer control coloring shows which layers use the same paint queue. Switch the paint manager, and notice how the paint queue assignments change. The synchronous layers (in black) and the unmanaged layer stay the same.
The Translucent checkbox to the right on the map renders all content with a translucency of 0.5. This demonstrates how to modify the state of the wrapped layer.
This sample demonstrates how to calculate and visualize terrain contours as polylines and complex polygons.
Four different contour layers are available:
This sample demonstrates the ability to load and visualize data from sources in
different formats by making use of ILcdModelDecoder
and ILcdGXYLayerFactory
.
A File and a URL action are configured to load data in almost every available format.
The sample uses a composite ILcdModelDecoder
to decode the data into an ILcdModel
.
After this, a composite ILcdGXYLayerFactory
creates a layer that controls how
the ILcdModel
of the loaded data is displayed.
The model decoders and layer factories are retrieved using a service look-up mechanism, and
contain both built-in and sample implementations.
The sample supports images that are not georeferenced if the images are described in a small *.rst
meta-file (see TLcdRasterModelDecoder
).
The sample also includes a custom format (see the package samples.decoder.custom1
) to show how to implement
your own model decoder.
A save action, only available when the sample is run standalone, allows you to save an
ILcdModel
to its file if an ILcdModelEncoder
is set to the ILcdModel
.
Currently this is only done for the custom format.
Open a file or URL by clicking the appropriate toolbar button or by dragging a file or URL onto the map. Load Washington DC spot satellite image ( .rst format ) and Washington DC streets ( .shp format ) and notice how the data overlap. Load mixed.txt, edit the shapes and save the model (only when run standalone).
This sample demonstrates how to display color-coded densities of data, by
means of a TLcdGXYDensityLayer
.
The applet shows a set of flight trajectories above USA, with colors ranging from blue, for quiet regions, to bright white, for busy regions.
Pan and zoom around. Notice that asynchronous painting ensures that the view stays responsive.
This sample demonstrates how to interactively create and edit ILcdShape
objects in an ILcdGXYView
.
The toolbar contains buttons that create several shapes, by using different instances of
the TLcdGXYNewController2
controller.
Each controller has its own controller model, defining the type of
shape to create, in which ILcdGXYLayer to add it and how to add it.
The layers provide the necessary ILcdGXYPainter
and ILcdGXYEditor
instances to properly
render, create and edit any ILcdShape it contains.
Next to this, the panel at the right has the following configuration options:
This sample shows how to implement a multi-mode edit controller i.e. a controller that changes its state when you click on an already selected object. The controller is used in a painter/editor wrapper to change the painter/editor, allowing different editing behavior.
The controller supports 2 modes:
To add the rotation behavior, a support class defines a number of abstract methods that need to be implemented for a specific shape:
The sample shows two polygons that can be rotated in their respective model references. To activate the rotation mode, select an object, and click once more on the object. Rotate the shape by grabbing and dragging one of the rotation handles. Click again on the object to cycle through the available modes. Click on a previously unselected object to reset the editing mode.
This sample illustrates support in LuciadLightspeed for geoids. It shows an image containing the geoid heights of the EGM2008 datum (Earth Gravity Model, 2008). Blue colors indicate that the geoid heights are negative (geoid below the ellipsoid of the WGS84 datum). Green colors indicate that the geoid heights are positive (geoid above the ellipsoid).
The geoid heights are also displayed in a label on the toolbar.
Geoid heights are typically used behind the screens, in calculations with references that have geodetic datums based on geoids. They are relevant for elevation data, for instance, which are commonly defined with respect to a few standardized geoid models. For accurate computations, elevations above a geoid can then be transformed to elevations above an ellipsoid.
Move the mouse and see how the geoid height changes.
This sample demonstrates how to display grid layers in a GXY view.
The following grid layers are included:
ILcdXYWorldReference
. The labels denote meters.
This sample illustrates the use of height providers in LuciadLightspeed. It shows a raster containing height data. The height values of the data under the mouse cursor are displayed in a label on the toolbar.
The sample uses a view height provider to retrieve height values.
Move the mouse over the raster and see how the height values change. Moving the mouse outside the raster will indicate that no height data could be found.
This sample demonstrates how to highlight domain objects. A custom controller looks at the domain objects under the mouse cursor and informs the relevant layer that an object should be highlighted.
Hover above the cities and states. The city or state under the mouse will change color.
This sample contains an implementation of the ILcdGXYPainter
and
ILcdGXYEditor
interfaces for a new shape, a hippodrome,
which consists of two half circles connected by two lines. Instead of
using composition this sample demonstrates how to create a painter/editor
from scratch.
Note that this is sample code to demonstrate writing painters. If you need to model a hippodrome,
please refer to our ILcdGeoBuffer
implementations.
The shape is defined by two points and a width. An XY and a lonlat shape is provided both of which can be handled by the painter/editor taking into account some precaution for the geodetic shape.
The painter supports painting in the following modes:
This sample is mainly intended as a developer's guide to construct painters and editors from scratch. To create a new hippodrome, click on either of the two buttons in the toolbar. To edit a hippodrome,
This sample demonstrates LuciadLightspeed's abilities to display icons. These icons, painted by
a TLcdGXYIconPainter
can be scaled using a world or pixel scaling mode. They can also
return an anchor point, which gives them an offset. The sample also demonstrates oriented
icons.
You can dynamically change the scale and scale mode by using the controls in the 'Icon scaling options' panel. The pin icons represent cities. Notice how the tip of the pin is anchored to the city. Notice how every airplane has a different rotation: the rotation is automatically retrieved from the domain object.
This sample demonstrates the creation and usage of labeling algorithms and labeling algorithm
wrappers. MyLabelingAlgorithm
is a labeling algorithm that tries to place all labels on the
domain object's anchor point.
There are three wrappers that can be combined with this algorithm and each other.
RotationAlgorithmWrapper
: Rotates all labels
MorePositionsAlgorithmWrapper
: Creates extra label placements to be tried by offsetting the label by a few
pixels in each direction.
LabelDetailAlgorithmWrapper
: Adjusts the size of the font and amount of information to create more label
placement possibilities.
After starting the sample, it is possible to choose between two labeling algorithms:
The sample algorithm SampleLabelingAlgorithm
and a default labeling algorithm. Use the
check boxes to enable/disable using more possible positions or changing the font size
during labeling. Also moving the slider adjusts the rotation of all labels.
This sample demonstrates how labels can be made interactive. The labels can be edited in the sense that they can be moved to a new location, as well as in the sense that they offer the user an interactive component that can be used to edit information related to the domain objects.
Move the mouse over a label of a city. An interactive, editable label will be shown instead of the regular label. You can enter a comment for the labeled city in the text field. To apply the changes, press the Enter key or press the green tick mark at the top of the interactive label. To cancel the outstanding changes, press the red 'cancel' icon at the top of the label or press the Escape key.
The interactive label can be moved by clicking and dragging on the title bar of the interactive label.
This sample demonstrates LuciadLightspeed's abilities to display icons at a certain offset. These
icons, painted by a regular ILcdGXYPainter
, are offset with respect to the domain object.
This offset can be dynamically changed using the mouse.
It also shows how the used labeling algorithm can be configured to drop labels together.
You can dynamically change the offset of the icon by selecting a city, and then dragging the icon while keeping the 'Control' button pressed.
This sample demonstrates the asynchronous label placer and the default labeling algorithms.
Labeling algorithms take into account the
labels that are already placed to avoid overlap.
An ILcdGXYLayer
will therefore most likely have less labels painted
when it is at the bottom than when it is at the top of the ILcdGXYView
.
To see the effects of the labeling algorithms select a layer, by clicking it in the layer control and:
This sample demonstrates LuciadLightspeed's abilities to paint and label streets. Highways are labeled using an icon, while city streets (zoom in on Washington DC) are labeled using text labels.
Zoom in and out to see multiple levels of detail on the map. The USA region contains highway data, and the Washington DC region contains streets data.
This sample shows you LuciadLightspeed's capabilities regarding the magnetic north.
The magnetic north does not coincide with the true north. The difference between the magnetic and true north is called magnetic declination and depends on your position in space and time. There are different mathematical models to calculate and predict the magnetic north, each with their own lifespan. LuciadLightspeed comes with the two most popular models: WMM and IGRF.
The sample shows a compass control for the magnetic north, and iso lines of constant magnetic north declination.
Click on any place on the map to center on that point and rotate the map so that the top points towards the magnetic north. Notice that the magnetic north compass will point straight up. Right-click to reset the custom rotation again. Zoom in on a magnetic declination line. The readout at the bottom of the map shows the exact declination value for the mouse location. The magnetic value at the center of the map should be the difference between both compasses.
This sample demonstrates how to create, customize, add on map navigation controls over a 2D view.
The default controls are in the top right corner when you run the sample. Drag the outer ring of the upper part to rotate the view (you can hold down the CTRL (CMD on Mac OS) button to constrain rotation to multiples of 15 degrees). Click on the North symbol of the outer ring to return the view to the original rotation. Press and hold anywhere in the circle with the hand symbol to pan the view. The lower part allows you to zoom in and out.
On the left you can find a customized configuration. In the alternative configuration, the controls are split and the two sub-components are added in different places. Furthermore, the zoom component is now always emphasized, not only when the mouse is over it and the compass component can be relocated by dragging it with the right mouse button pressed.
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to create an off-screen view, display some decoded data in it, and save the result as a GeoTIFF file.
Run the sample using the shell script in the samples
folder:
gxy.offscreen.bat <input_file> <output_geotiff>
The input data can be in a variety of formats: SHP, MIF, MAP, GeoTIFF, etc. The output GeoTIFFs are 1024x1024 pixels, tiled (256x256 pixels) and multi-leveled (3 levels), and compressed with a lossless compression scheme. All of these settings can be changed in the sample code.
This sample demonstrates the use of a TLcdGXYOverviewController
and the
sharing of layers between multiple ILcdGXYView objects.
It consists of one main ILcdGXYView
(TLcdMapJPanel
) in the center and an overview map
(TLcdMapJPanel
) in the top right. The overview map remains focused on the USA and
also displays a Rectangle that corresponds as much as possible to the area visible
in the main view. Dragging the Rectangle in the overview or creating a new one makes
the main view display data that are in the Rectangle. This Rectangle is updated
each time the visible area in the main view changes (e.g. when panning or zooming).
The overview displays the same ILcdModels
using the same ILcdGXYLayers
used in the main view.
Since an ILcdGXYView
automatically listens to any property change of its
ILcdGXYLayer objects, any change of those properties via the layer control
will show in both views.
Drag the Rectangle in the overview or create a new one. Pan and zoom in the main view: the Rectangle overview will update itself automatically. Remove a layer and notice that it is removed from both views.
This sample shows how to paint polylines and polygons with rounded corners and how to change the stroke and fill style.
The functionality to paint a polyline or polygon with rounded corners is provided by
TLcdGXYRoundedPointListPainter
.
To fill shapes with a solid color, TLcdGXYPainterColorStyle
is used.
To fill shapes with a hatched pattern, TLcdGXYHatchedFillStyle
is used.
To render outlines with a simple, dashed stroke, TLcdStrokeLineStyle
is used.
To render the shapes with a pattern-based stroke, TLcdGXYComplexStroke
is used.
This java.awt.Stroke
implementation allows to use an AWT Shape array as pattern to
render a shape.
The sample also illustrates halo effects.
A halo is an outline of constant width and color around shapes or text, which is typically drawn in
a contrasting color to ensure that the shapes or text are clearly visible on any background.
For shapes, the halo effect is obtained by wrapping an ILcdGXYPainter
(in this case,
the TLcdGXYRoundedPointListPainter
) into a TLcdGXYHaloPainter
.
This sample demonstrates how to print a component containing a view,
using the TLcdGXYViewComponentPrintable
.
The sample creates a page layout containing the view and some decorations. You can preview the page or print it directly using the buttons in the toolbar.
This sample demonstrates the ability to combine parametric rectification - using camera and terrain information - and non-parametric rectification - using user-defined tie-points.
The left panel displays a non-modified version of the image currently being processed, together with a set of tie points. The right panel displays several layers, from bottom to top:
The default data is a simulated satellite photo of the city of Ithaca, NY. Due to the slanted viewing direction, the position of the original picture is distorted by a variable amount compared to the real position. The size of the distortion depends on the local terrain elevation - this can be verified by comparing the position of roads in the original raster with their actual position displayed by layer "109rds".
By taking into account the viewing direction and the variable terrain elevation, the sample creates an initial orthorectified version of the raster, which corrects most of the positioning errors. The user may further correct a copy of this raster by fine-tuning a set of tie points.
An initial set of tie points are shown in the left and in the right panels. Selecting a point in one panel will display the corresponding tie point in the other panel. Tie points in both panels can be dragged to other locations. This will trigger a remapping of the corrected image in the right panel, so that the tie points appear in approximately the same location relative to the raster.
New tie points can be added in the left panel by selecting the "Create new tie point" controller. Every time a new point is added in the left panel, a corresponding tie point is added to the right panel, at approximately the same raster coordinates (a small difference may be observed for highly warped rasters).
Existing tie points can be deleted by right-clicking on them and choosing "Delete" from the context menu. If fewer than 3 points are available, the raster is no longer updated.
By default, the mapping is done using a polynomial function. You may choose a rational function or a projective function instead, by selecting the "Edit raster projection parameters" action. You can also choose the maximum degree of the polynomial(s) used by the selected function. Note that polynomials of higher degree (3 or 4) are highly unstable and may produce strange warping effects. The number of required tie point pairs varies with the degree of the polynomial(s). If an insufficient number of tie points is defined, the function will automatically decrease the degree(s) used.
When you are satisfied with the rectification you may save a re-sampled version of the raster using the reference of the right-panel view using the "Save the raster in view's reference" button.
The sample can open existing single-level referenced GeoTIFF files, or non-referenced images (tif, png, gif, bmp, jpg). If the image is not georeferenced, it is placed at a default location, together with four initial tie points in the corners.
The open and save options are not available when the sample is running in a browser.
This sample shows how to programmatically create and display a model.
It reveals how to create an ILcdModel
, how to populate it with ILcdShape
objects,
and how to display that data in an ILcdGXYLayer
on the ILcdGXYView
.
The sample shows a polyline, a polygon, and a point visualized by an icon. Try selecting and editing the shapes.
This sample demonstrates how to create a composite ILcd2DEditableShape
and a
suitable ILcdGXYPainter
and ILcdGXYEditor
for that ILcd2DEditableShape
.
The class ShortestDistanceShape
is a composition of a TLcdLonLatPolyline
and
a TLcdLonLatPoint
around this polyline. The class ShortestDistanceShape
knows
how to calculate the ILcdPoint
on the geodesic TLcdLonLatPolyline that is the
closest to the TLcdLonLatPoint
.
The class ShortestDistancePainter implements ILcdGXYPainter
and ILcdGXYEditor
and is used for painting and editing ShortestDistanceShape
objects.
Existing painters for the composed shape object are used for painting,
TLcdGXYIconPainter
for the TLcdLonLatPoint
and TLcdGXYPointListPainter
for
the TLcdLonLatPolyline
. For painting the shortest distance path of the
TLcdLonLatPoint
to the TLcdLonLatPolyline
the utility ILcdGXYPen
is used.
The painter-editor allows to move the TLcdLonLatPoint
or a point of the
TLcdLonLatPolyline
of the ShortestDistanceShape
object to any location while
constantly showing the shortest distance path of the TLcdLonLatPoint
to
the TLcdLonLatPolyline
.
This sample shows how to visualize shapes based on their domain object properties. A custom painter provider displays counties as polygons that are colored according to population density. Icon-based labels show different size rectangles depending on the population change.
You can verify the visualization by double-clicking on a shape to examine its properties.
This is a sample for displaying an ILcdModel
's elements in a JTable
.
All the domain objects implement ILcdDataObject
, which means they have a data type with
a set of properties associated to each of them.
We load several ILcdModel
which are displayed/represented in both
the TLcdMapJPanel
and the JTabbedPane
(i.e. each ILcdModel
is represented
in 2 different views). For each ILcdModel
, there is a
corresponding ILcdGXYLayer
in the map and a JTable
in the JTabbedPane
.
The column names of each JTable
correspond to the attributes names,
the rows correspond to the attribute values.
A mediator is used to synchronize the map and table selections.
This sample contains a custom implementation of ILcdGXYController
, which
displays tooltips for objects under the cursor. The text of the tooltips is
obtained via the ILcdDataObject
interface. The applyOnInteract2DBounds()
method of ILcd2DBoundsIndexedModel
is used to locate the object under the
mouse cursor.
Hover over a city or state and a tooltip will pop up after a short while.
This sample demonstrates the touch-based navigation, selection and ruler controllers in a GXY view. The controllers are shown in the toolbar at the top. The leftmost controller is a context sensitive selection and navigation controller.
The second controller only deals with navigation. It features one finger panning, and two finger panning, zooming and rotating (at the same time).
The third is a ruler controller. It works similar to the mouse based ruler controller, creating a polyline on the map that will display the length of each segment as well as the total length.
This sample features large buttons to allow easy manipulation with fingers instead of a mouse as input device.
Using the select controller, you can touch objects to select them, pan around by dragging the map, or zoom and pan by dragging two fingers. A number of modifier buttons are available to change the selection behavior:
For the pan controller, drag one finger to pan, and two fingers to simultaneously pan, zoom and rotate the map.
To add points to the ruler controller's measurement, touch and lift your finger. Here as well a number of buttons are added to the map:
This sample demonstrates how to create new ILcdShape objects and edit
existing ILcdShape
objects in an ILcdGXYView
using a touch device.
The functionality available here is very similar to the functionality demonstrated by the editing sample. The main difference is that the controllers now interpret touch input instead of mouse input. This allows you for instance to translate an object using the edit controller with one finger and pan the view with another finger at the same time. The same goes for the controllers creating objects. Another issue is the lack of modifier buttons (on keyboard and mouse). To compensate the touch controllers have been extended with some on-map buttons. The edit controller has:
This sample demonstrates how TLcdTouchEvents
can be created from hardware events. The sample
simulates touch hardware generating hardware events. These events are intercepted and
converted into touch events that can be used by LuciadLightspeed. After that they are dispatched.
After opening the sample, touch events will be generated automatically. They pan, zoom and rotate the view.
This sample demonstrates the ability to display a geodetic location which can
be expressed based on different ILcdGeodeticDatum
and express its coordinates
in some commonly used grid reference systems and some lon lat formats.
Move the displayed icon and see how its coordinates change.
There are two text fields which contain the geodetic latitude and longitude respectively. The latitude and the longitude are represented in a certain format which can be changed. Values have to be entered in this format too. The geodetic coordinate is with respect to a certain geodetic datum which can be altered. In the grid coordinates panel are the (x,y) grid coordinates of this geodetic LatLon coordinate according to some commonly used grid coordinate systems.
Changing the geodetic datum or the UTM zone will affect only the geodetic coordinate or the UTM coordinate. Since the geodetic datum of the projection in the map component is kept the same as the geodetic datum of the grid calculator, the icon will move slightly too.
This sample contains a custom implementation of ILcdGXYController
, which
transforms a rectangle dragged by the user (in view coordinates) into
model coordinates. The mouse location is also
converted into an arbitrary model reference (a grid reference with a
polar projection for the north pole).
Drag a rectangle on the map, and see the coordinates of its counter part in model coordinates, below the map. The last mouse drag or mouse click location is also expressed in another model reference.
This sample demonstrates the undo support of LuciadLightspeed. It is based on the "shapes" sample and makes it possible to undo changes made to the domain objects.
To witness the undo support, perform the following steps:
This sample demonstrates the use of the vertical view package. The 2D view in the upper part contains two layers: a background layer with a map of the world countries and a layer that contains two flights. Each flight is modeled as a list of 3D points. The 2D view only uses the first two coordinates(X,Y) of each of the points.
The vertical view in the lower part is used to display the vertical profile of
the flight that is selected in the 2D view. Apart from this profile,
a number of sub-profiles associated to it can be shown in a vertical view.
In this case, only one sub-profile is associated to the view: the air route.
FlightVVModel
, an implementation of ILcdVVModel
holds the main-profile points
and the information about the sub-profile.
Select a flight. A vertical marker is shown in both views. Change the height of the flight by dragging its points up or down. You can zoom the X and Y axes by using the sliders to the right and at the bottom. You can disregard flight points at the left or right of the flight using the sliders at the top. Finally, the panel at the right allows you to select the altitude unit.
This sample demonstrates the use of TLcdEarthTileRepositoryPreprocessor
. This sample
provides a simple user interface for creating, loading and saving 3D terrain
metadata and preprocessing it to an Earth tile repository.
To preprocess data as a 3D terrain to an Earth tile repository you need to:
The terrain metadata consists of a number of assets (that is source data files) and a geographic reference. Add some assets to the metadata by using the button at the bottom of the panel. You can either select individual files that need to be preprocessed or a directory that contains the files that need to be preprocessed. Once the assets are loaded they will appear in the metadata panel and their bounding box will appear on the map. For image assets you can also optionally set a clipping shape to limit the preprocessed part. This can for example be used avoid preprocessing a border that is present in the asset. You can save the terrain metadata (for example for using with the Earth On-the-fly sample) using the button below the map. Finally you can change the geographic reference of the terrain using the combo box at the top of the metadata panel. Typically this geographic reference is the one that will most often be used when visualizing the terrain repository.
The repository where the assets should be preprocessed to must be configured before the preprocessor can be started. You can optionally also change the data type that must be preprocessed and enable texture transparency. After pressing the start button the preprocessing progress can be tracked in the progress panel and on the map. The preprocessor can be stopped at any time and resumed again using the buttons in the progress panel.
This applet demonstrates the ability to filter data using the OGC Filter API. A layer showing earthquakes is added to the view on which a filter is configured. The layer filter is created from an OGC filter, which is created from a combination of three OGC conditions: 'a less than' for the magnitude, a temporal for the time period and a bounding box condition of a country.
The OGC conditions are expressed programmatically using the OGC Filter API. The creation of the OGC conditions is done in EarthQuakeFilterModel#createCombinedCondition. If there is a change in one of the parameters for the OGC conditions, a new OGC filter is created and converted to an ILcdFiltered by means of a filter evaluator. This conversion code can be found in MainPanel#addData.
Use the controls in the filter configuration panel to adjust the different parameters of the filter.
This applet demonstrates the ability to filter GML data using the OGC Filter XML decoding and evaluation facilities.
It displays all the countries of the world and the same data, with a filter applied in another layer.
Enter a filter manually in the text area at the bottom or click the load button to load a predefined filter from the list.
Click the apply button to apply the filter to the countries layer. The filtered layer will display all countries that pass the filter.
Double-click on a country in order to view its related features and compare them to the filter.
This is a command-line sample. Click More info for run instructions.
This sample illustrates how to data in SHP, MIF or MAP formats can be transformed and exported as GML31 data.
Run the sample using the shell script in the samples
folder:
encoder.gml3.bat [-gmlschema gmlSchema] [-xmlschema xmlSchema] [-namespace namespace] vectorFile resultFile
These are the parameters to pass:
This is a command-line sample. Click More info for run instructions.
This sample uses the FlightPlan data model from the LuciadLightspeed fundamentals as source model. It shows how this data model can be transformed into a GML data model. It shows how the GML application schema can be generated. It then encodes a model containing flight plans as a GML document. Then this document is decoded back into a model containing flight plans.
Run the sample using the shell script in the samples
folder:
transformation.gml.bat
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to decode rasters in various formats and encode them in JPEG2000 format, using a TLcdJPEG2000ModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.raster.jpeg2000.bat [options] <input_raster> <output_jpeg2000>
The supported options are:
-levels <n> -layers <n> -quality <f> -lossless -tilesize <width> <height>
This sample demonstrates how to load and display KML data on a map.
The sample will automatically load a basic KML file containing most KML features, and fit the map on the data.
The model content tree next to the map is a tree-based structure showing the contents of all KML files that are currently displayed on the map.
Objects can be selected either via the map or via the model content tree. When an object is selected a balloon will pop-up, displaying additional information on the object.
The sample will automatically resolve network links in KML files, and refresh the model contents if a refresh mode is specified in the link.
When KML files containing time information (timestamp, timespan) are loaded, a time toolbar will become visible, showing the time interval for which data is available. The time slider can be used to control which data should be shown on the map.
This sample demonstrates how to load and display KML data on a map.
The sample will automatically load two KML files:
The model content tree next to the map is a tree-based structure showing the contents of all KML files that are currently displayed on the map.
Objects can be selected either via the map or via the model content tree. When an object is selected a balloon will pop-up, displaying additional information on the object.
The sample will automatically resolve network links in KML files, and refresh the model contents if a refresh mode is specified in the link.
When KML files containing time information (timestamp, timespan) are loaded, a time toolbar will become visible, showing the time interval for which data is available. The time slider can be used to control which data should be shown on the map.
This is a command-line sample. Click More info for run instructions.
This sample demonstrates how to convert models into KML. The KML format is particularly useful for sharing a situational map with a broader set of stakeholders, who do not necessarily have access to LuciadLightspeed, but can open KML data in other map visualization tools. LuciadLightspeed allows you to convert map data into KML. This sample illustrates one way to convert vector data into KML and customize the conversion. It gives you full control of the style and the geometry information that will be converted in the KML model. The model encoder TLcdKML22ModelEncoder can then export the KML model.
Run the sample using the shell script in the samples
folder:
encoder.kml22.bat
Run the sample to convert the files and the in-memory model into KML. The three new KML files are located in the Kml directory inside the data resources folder for the samples. You can visualize the KML files in the general decoder samples, the KML decoder samples, or any KML visualization tool.
First, the KML encoding sample decodes a SHP file representing tracks, and converts a subset of the tracks into a KML model. The KML model is then encoded in a file. Another SHP file representing the USA states is also decoded, and some states are encoded in KML. Next, the sample creates an in-memory model of airspaces. Each airspace is an extruded shape with a circle or a polygon as its base shape. The airspace model is also converted into KML and encoded.
This sample illustrates how Lidar data from .las files can be visualized in a Lightspeed view.
With this sample, you can open one or more .las files and apply different styling.
The following styling options are available if at least one layer supports it:
Additionally, a shading technique to enhance depth perception is enabled by default. Using the controls in the panel, the settings can be changed:
Open .las files using the "Open File" icon, or by dragging files onto the sample.
Change the styling and filtering using the panel on the right. The styling will be applied to the layers that support it. Layers that don't support it use Height styling.
Change the depth perception settings using the panel on the right. The settings will be applied to all layers.
This sample demonstrates how to introduce clustering in a GXY application
using
TLcdTransformingModelFactory
and
TLcdClusteringTransformer
.
The sample contains a large number of recorded humanitarian events in Africa. When a number of events are close together (in view-space), they become hard to distinguish. Therefore a cluster is shown instead of the individual events.
This sample uses two different clustering strategies:
ILcdClassifier
on the transformer.
This scale-dependent clustering behavior is created by calling the
TLcdClusteringTransformer.createScaleDependent
method.
Navigate around the map and see the clusters update when necessary.
This sample demonstrates how to display balloons in an
ILspView
using
TLspBalloonManager
.
The sample generates four icons, each of which contains a balloon. A balloon is made visible when a single object is selected. The balloon contains an icon and an editable text field containing the position of the icon in geodetic coordinates.
For a more extensive description of the balloon manager API see the developers' guide.
Select one of the icons. A balloon will appear. Editing the coordinate panel in the balloon and hitting return will change the location of the icon. The balloon arrow also gets relocated with this operation. Balloons are only shown when one domain object is selected.
This sample demonstrates how to introduce clustering in a Lightspeed application
using
TLcdTransformingModelFactory
and
TLcdClusteringTransformer
.
The sample contains a large number of recorded humanitarian events in Africa. When a number of events are close together (in view-space), they become hard to distinguish. Therefore a cluster is shown instead of the individual events. Selecting a cluster also selects and displays its contained elements.
This sample uses two different clustering strategies:
ILcdClassifier
on the transformer.
This scale-dependent clustering behavior is created by calling the
TLcdClusteringTransformer.createScaleDependent
method.
Navigate around the map and see the clusters update when necessary. A cluster's contained elements can be displayed by selecting it. Moving a cluster also moves the contained elements.
This sample demonstrates how to implement and use a custom controller. The first controller (active by default) shows an information panel when hovering over an object. The second controller allows you to navigate using arrow and other keys.
When using the first controller, use the mouse to hover over some of the counties in the USA and an information panel will pop-up with some information about the county. When using the second controller, the following keys can be used:
This sample demonstrates how to add support for painting and editing a custom shape: the hippodrome. The hippodrome consists of two 180 degrees arcs and two lines connecting these arcs and at a given distance from the line between the center points (width).
Please refer to the documented sample code and the developer's guide for more information.
This sample is an adaptation of the Editing sample (which illustrates the editing and creation capabilities of the editors that are available in the Lightspeed API).
The Shapes layer in this sample has a regular shape painter (TLspShapePainter
) to
paint the
shapes' bodies.
In addition, this sample adds another shape painter with a different styler that
is identified by a
custom paint representation. This special styler provides the painter with the bounds
of the shape as opposed to the shape itself. Hence, each shape is painted twice: once
using its own geometry and once using the bounds geometry.
For more detailed information on how to create an application which uses custom paint representations, see the developer's guide or the documented source code of this sample.
Try editing and creating new shapes and notice how both paint representations (the shape itself and its bounds) are painted and updated.
This sample demostrates how LuciadLightspeed's animation framework can be used to animate the style of an object. The animation is implemented in AnimatedAreaStyler, a custom ILspStyler implementation which uses an ILcdAnimation to update style properties and fire style change events when needed.
When the sample is started, the style of one of the countries should automatically be animated.
This sample illustrates how to customize the visualization of editing handles using some custom stylers. This sample uses two stylers to:
Select an ellipse in the sample. This should activate editing on that shape, and you should see the following customizations:
This sample demonstrates how LuciadLightspeed's animation and style frameworks can be used to highlight and show custom animations for the object under the cursor.
The sample consists of a layer containing shapes for each country. When the mouse is moved over a country, a pie chart appears showing the demographic distribution in that country.
This layer has two stylers:
AnimatedHighlightAreaShapeStyler
which takes care of the styling of the countries/pie charts themselves ( fill/line colors )
AnimatedHighlightAreaLabelStyler
which takes care of the styling of the labels of the countries/pie charts
ALcdAnimationManager
and
ALcdAnimation
in combination with a mouse
adapter to progressively adjust the styles of each object.
The pie charts are created and styled by passing their style and geometry to a
ALspStyleCollector
along with the object to which they belong.
Move your cursor over the different countries of the world. When the cursor is on top of a country, a pie chart will gradually rise and display population statistics specific of that country. When the cursor moves away from the highlighted country, the pie chart for that country will gradually vanish.
This sample demonstrates how to implement "thematic mapping", i.e. to adjust the style of an object to that object's attributes.
The sample consists of a layer of country shapes on which custom colors are being styled.
The colors for the countries are linearly interpolated between a minimum color and a maximum color
chosen by the user, with the population of each country as a weight for the interpolation.
More populated areas will therefore tend towards the maximum color, while less populated
areas will tend towards the minimum color. This styling is accomplished by using a custom
styler implementation, namely a
samples.lightspeed.customization.style.thematic.CountryStyler
Click on either the left or right gradient button on the toolbar to set the lowest or highest population color respectively. You will notice that the color of the countries is an interpolated value between those two colors, based on their population.
This sample adds functionality to view the TLcdDataModel of an ILcdModel that has an ILcdDataModelDescriptor as a model descriptor.
The 'Data Model Tree' is visible on start-up, showing the data model tree for the currently selected layer.
The data model tree contains all declared TLcdDataType instances of the TLcdDataModel. Each TLcdDataType contains a series of properties and TLcdDataProperties.
All TLcdDataTypes that are also model element TLcdDataType instances are highlighted in a special color.
Note that TLcdDataModel instances can define data types that are cyclical. There is no explicit check for this issue in the sample code, as it was not needed for this special case.
Open some random files and see how the data model tree gets updated each time you select a new layer which has an ILcdModelDescriptor as model descriptor on its model.
This sample shows how to create a day/night map in a Lightspeed view. The areas in civil/nautical/astronomical twilight and night are drawn in progressively darker shades. An icon on the map indicates the point where the sun is directly overhead. The day/night map animates in fast time over a period of 1 year.
The day/night map is constructed as follows:
The sample automatically shows an animated day/night map. A label on the top edge of the map shows the current date and time of the map.
The hardware capability report sample generates a detailed list of the hardware related
capabilities of the device running the sample. The sample generates a hardware
report with the OpenGL and OpenCL capabilities of the system using the
com.luciad.view.lightspeed.util.TLspPlatformInfo
utility class.
Reported capabilities include:
When contacting Luciad support about any Lightspeed-related problems, it is always appreciated if you include the report generated by this sample.
This sample demonstrates the ability to load and visualize data from sources in different formats
on a Lightspeed map using ILcdModelDecoder
and ILspLayerFactory
.
A File and a URL action are configured to load data in almost every available format.
The sample uses a composite ILcdModelDecoder
to decode the data into anILcdModel
.
After this, a composite ILspLayerFactory
creates a layer that controls how
the model of the loaded data is displayed.
The model decoders and layer factories are retrieved using a service look-up mechanism, and
contain both built-in and sample implementations.
The toolbar includes several controllers to visually compare layers.
Add new data by pressing the appropriate toolbar button or by dragging and dropping files or URLs on the map. Not all styled LuciadLightspeed formats have a dedicated Lightspeed layer factory (an example of this is DGN), in which case a fallback layer factory is used. As a result, the visualization of some data might not be correctly styled. The data shown in the highlighted sample screenshot is an OGC 3D Tiles mesh data set for Marseille, located at https://sampleservices.luciad.com/ogc/3dtiles/marseille-mesh/tileset.json.
The toolbar allows selecting the following visual inspection controllers:
This sample illustrates the editing and creation capabilities of the editors that are available in the Lightspeed API. The sample contains one shape layer for both editing and creation. Shape creation is performed using TLspCreateController. Shape editing is performed using TLspEditController.
Consult the developer's guide or the documented source code of this sample for detailed information on how to create an application that uses Lightspeed editors.
To edit one of the shapes, click on the shape and interact with one of its edit handles. Please refer to the javadoc of the different editor classes in the com.luciad.view.lightspeed.editor package to see what functionality is provided by each of the handles.
To create a new shape, activate one of the create controllers in the toolbar. Most of the controllers also have an extruded creation variant. This variant creates an extruded shape with the base shape that is created by the normal editor. For instance, the ellipse create controller creates an extruded ellipse when extrusion is activated. Extrusion can be activated by the extrusion button in the creation toolbar.
For most shapes creation is simply performed by a sequence of mouse clicks or taps. Some additional instructions for special cases:
When creating or editing shapes you can disable snapping by pressing the control key (cmd on macOS). Insert or remove a point from a polyline or polygon by holding down the control key (cmd on macOS) while pressing. Select multiple shapes by holding the shift while pressing. Use the delete key to remove selected shapes.
This sample visualizes the EGM2008 geoid in 3D. The geoid heights are exaggerated; they actually vary between -110m and +90m. Blue colors indicate that the geoid heights are negative (geoid below the ellipsoid of the WGS84 datum). Green colors indicate that the geoid heights are positive (geoid above the ellipsoid).
Geoid heights are typically used behind the screens, in calculations with references that have geodetic datums based on geoids. They are relevant for elevation data, for instance, which are commonly defined with respect to a few standardized geoid models. For accurate computations, elevations above a geoid can then be transformed to elevations above an ellipsoid.
The geoid heights are retrieved from the geodetic datum that is created by the TLcdGeoidGeodeticDatumFactory.
This sample demonstrates how to display grid layers in a Lightspeed view.
The following grid layers are included:
In addition, the sample shows how to change text and line styles and other grid styling properties.
This sample demonstrates how to visualize point data using 3D icons. Icons can be loaded from files in either Collada, OpenFlight or WaveFront OBJ format.
The sample shows animated 3D points. At startup, they are displayed using an airplane icon. Use the "open" button on the toolbar to load a .DAE, .OBJ or .FLT file. Doing so will replace the airplane model.
This sample demonstrates how to project images on terrain.
The sample shows an image being projected on terrain by an animated plane. Notice how the projected image deforms when projected on the terrain. The white lines indicate the projection frustum. This frustum can be toggled on or off in the layer pane.
This sample illustrates how multispectral raster imagery can be visualized and analyzed in an ILspView.
The sample starts with pre-loaded satellite image files covering the region of Las Vegas. The images are obtained from the LandSat7 USGS archive. They are multi-spectral GeoTIFF files that consist of 7 bands. The sample also allows you to load other GeoTIFF files from disk.
The panel below the layer controls demonstrates the LuciadLightspeed imaging operators and filters, and allows you to configure how the image in the selected layer is displayed. You can adjust brightness, contrast, opacity, and apply a sharpening filter using the sliders.
You can also choose which of the 7 image bands are displayed, and to which color channel they are mapped. To display the pre-loaded images in the the LandSat7 natural color preset for instance, select the bands 3, 2 and 1 in the Red, Green and Blue drop-down menus respectively. Other interesting band combinations that highlight specific aspects of the image data are 4-3-2, to display the near infrared (NIR) data, and 7-4-2 to display short-wavelength infrared (SWIR) data. The band combination 7-4-2 displays vegetation in bright shades of green, for instance.
The Curves panel displays the data distribution of the displayed image bands in a histogram. You can adjust the dynamic range for the bands in each color channel by manipulating the line displayed on top of the histogram into a curve. You can also enhance the image contrast automatically by applying the Equalization function on the Luminance tab.
The toolbar allows selecting a swipe and flicker controller to visually compare layers.The swipe controller displays a swipe line that can be dragged horizontally or vertically, displaying only half of the first set of layers on the left or top side, and half of the other set of layers on the other side. The flicker controller allows to quickly toggle between multiple layer sets by clicking the mouse. See the documentation of TLspSwipeController and TLspFlickerController for more info.
The sample makes use of TLspImageFilterStyle and the ALcdImageOperator API to perform the band selection and dynamic range adjustments.
Load additional files with drag and drop, or by clicking the Open button on the toolbar. When you select the resulting layer in the layer control panel, three additional panels appear below the layer controls.
In the General panel, you can apply several image filters to the selected raster layer. Use the sliders to adapt the image contrast, brightness, opacity and sharpness.Click Reset to return to the default filter settings.
The Visible bands panel allows you to choose which image bands are made visible, and in which color. The drop-down
menus next to the Red, Green and Blue color channels contain a list of the image bands present in the
selected raster layer. To map an image band to a particular color channel, select the band number from the
drop-down menu next to the preferred color.
To see just one band in grayscale, click the grayscale icon and select a band from the drop-down menu.
The Curves panel consists of four tabs. The Red, Green and Blue tabs displays a histogram and a tone curve for the
color-mapped bands of the loaded image. To see the histogram and tone curve for a particular band, select the tab
with the color to which you mapped the band. To change the tone curve in a particular color channel, select the
line on the histogram, and drag its control points until it forms a curve, and your image displays the required
color balance. You can add or delete points on the selected curve by ctrl-clicking. The Luminance tab displays
a histogram and curve for the brightness of the image. You can manipulate the tone curve to improve the contrast
in the image. To enhance image contrast automatically, click Equalize. As a result, the contrast will be
stretched automatically, and the curve will change.
To reset curves to their original settings, click Reset.
To visually compare layers, select the swipe controller from the toolbar. Compare for example the Las Vegas image from 2000 and 2003. By dragging the swipe line you should be able to easily see the differences between the two image files. Enable the flicker controller from the toolbar and select the two Las Vegas image files. Quickly click the mouse to toggle between the two layers.
This sample demonstrates how to display balloons in a TLspFXView
using TLspFXBalloonManager
.
This sample requires JavaFX. Depending on the JDK you are using, you may need to install it separately.
Refer to the technical notes in the documentation for more information.
The sample shows two points on the map, each of which is tied to a balloon. A balloon is made visible when a single object is selected. The balloon contains an editable text field containing the position of the icon in geodetic coordinates.
For a more extensive description of the balloon manager API see the developers' guide.
Select one of the icons. A balloon will appear. Editing the coordinate panel in the balloon and hitting return will change the location of the icon. The balloon arrow also gets relocated with this operation. Balloons are only shown when one domain object is selected.
This sample demonstrates the ability to load, visualize and print data from sources in different formats
on a Lightspeed JavaFX map using ILcdModelDecoder
and ILspLayerFactory
.
This sample requires JavaFX. Depending on the JDK you are using, you may need to install it separately.
Refer to the technical notes in the documentation for more information.
A file and a URL action are configured to load data in almost every available format.
The sample uses a composite ILcdModelDecoder
to decode the data into anILcdModel
.
After this, a composite ILspLayerFactory
creates a layer that controls how
the model of the loaded data is displayed.
The model decoders and layer factories are retrieved using a service look-up mechanism, and
contain both built-in and sample implementations.
Add new data by pressing the appropriate toolbar button or by dragging and dropping files or URLs on the map. Not all styled LuciadLightspeed formats have a dedicated Lightspeed layer factory (an example of this is DGN), in which case a fallback layer factory is used. As a result, the visualization of some data might not be correctly styled.
Use the print button on the toolbar to preview and print the current contents of the map.
This sample illustrates the editing and creation capabilities of the editors that are available in the Lightspeed API.
This sample requires JavaFX. Depending on the JDK you are using, you may need to install it separately.
Refer to the technical notes in the documentation for more information.
The sample contains one shape layer for both editing and creation. Shape creation is performed using TLspCreateController. Shape editing is performed using TLspEditController.
Consult the developer's guide or the documented source code of this sample for detailed information on how to create an application that uses Lightspeed editors.
To edit one of the shapes, click on the shape and interact with one of its edit handles. Please refer to the javadoc of the different editor classes in the com.luciad.view.lightspeed.editor package to see what functionality is provided by each of the handles.
To create a new shape, activate one of the create controllers in the toolbar. Most of the controllers also have an extruded creation variant. This variant creates an extruded shape with the base shape that is created by the normal editor. For instance, the ellipse create controller creates an extruded ellipse when extrusion is activated. Extrusion can be activated by the extrusion button in the creation toolbar.
For most shapes creation is simply performed by a sequence of mouse clicks or taps. Some additional instructions for special cases:
When creating or editing shapes you can disable snapping by pressing the control key (cmd on macOS). Insert or remove a point from a polyline or polygon by holding down the control key (cmd on macOS) while pressing. Select multiple shapes by holding the shift while pressing. Use the delete key to remove selected shapes.
This sample demonstrates how to add touch support into a JavaFX application.
This sample requires JavaFX. Depending on the JDK you are using, you may need to install it separately.
Refer to the technical notes in the documentation for more information.
The sample features large buttons to allow easy manipulation with fingers instead of a mouse as input device.
Use one finger to pan around and to select or edit objects. Use two fingers to zoom or rotate.
To edit one of the shapes, you just have to touch the shape and interact with one of its editing handles. Please refer to the javadoc of the different editor classes in the API to see what functionality is provided by each of the handles.
To create a new shape, activate one of the create controllers in the toolbar. Note that most of the controllers also have an extruded creation variant. This variant creates an extruded shape with the base shape that is created by the normal editor. For instance, the ellipse create controller creates an extruded ellipse when extrusion is activated. Extrusion can be activated by the extrusion button in the creation toolbar (third button).
Some shapes like polylines, polygons, and complex polygons have different (dynamic) creation steps that can be ended by pressing the Commit button. For example, to create a complex polygon containing two triangular shapes, the sequence of interactions should be: tap-tap-tap, commit (to end first polygon), tap-tap-tap, commit (to end second polygon), commit (to end complex polygon creation).
This sample demonstrates how labels can be made editable. The labels are editable in the sense that they can be moved to a new location, as well as in the sense that they offer the user an interactive component that can be used to edit information related to the domain objects.
Move the mouse over a label of a city. An interactive, editable label will be shown instead of the regular label. You can enter a comment for the labeled city in the text field. To apply the changes, press the Enter key or press the green tick mark at the top of the interactive label. To cancel the outstanding changes, press the red 'cancel' icon at the top of the label or press the Escape key.
The interactive label can be moved by clicking and dragging on the title bar of the interactive label.
This sample demonstrates various labeling algorithms:
Note that the river's springs are determined as the first point of the first polyline, which may not correspond to reality.
To see the effects of the labeling algorithms select a layer, by clicking it in the layer control and:
To modify the label styling, drag the opacity slider, or change the font using the Font combobox.
This sample demonstrates how Swing components can be overlaid on an ILspView. Specifically, the sample shows a JInternalFrame which contains a secondary map view, alongside with navigation controls for the main view.
To avoid issues with the mixing of lightweight and heavyweight components, the sample uses TLspSwingView rather than TLspAWTView. A JLayeredPane is added to the main view. Within this layered pane, one layer is a JDesktopPane containing the internal frame with the second view. Another layer contains the standard navigation controls and scale indicator for the main view (as can also be seen in other samples).
Move, resize, minimize and maximize the internal frame. Observe how it sits between the main view and its overlaid navigation controls.
This sample demonstrates how the view-world transformation can be customized in order to constrain the navigation freedom. This behavior can be enabled or disabled using a checkbox in the toolbar.
Take note of the checkbox labeled "Limit Navigation" in the upper right corner of the screen, by default it is checked. As long as this checkbox is checked your navigational options are constrained:
Uncheck the "Limit Navigation" checkbox and retry panning, zooming and rotating the view and notice the difference with the constrained version of these behaviors.
This sample shows to add a map overview for an ILspView. The map overview is overlaid on the main view. It shows the bounds of the area of the world that is visible in the main view.
The map overview is itself a TLspSwingView, which is added to the main view's overlay panel. The visible map area is obtained using ALspViewXYZWorldTransformation.getGeodeticVisibleArea(). The map overview continuously fits to this polygon.
Navigate in the main view. Switch between 3D and the various 2D projections. Observe how the map overview updates continuously and how the polygon in the map overview corresponds to the area of the world that can be seen in the main view.
This sample demonstrates how 3D shapes in LuciadLightspeed can be discretized and saved as 3D meshes in a custom file format.
The intent of this sample is to show you how to export 3D shapes from LuciadLightspeed as 3D meshes for re-use in a LuciadRIA client. The produced JSON file can easily be parsed by the LuciadRIA MeshFactory.
To save a 3D shape as a JSON mesh-file, select a shape in the view, and press the save button in the toolbar.
This sample demonstrates how to use
TLspNavigationControlsFactory
to create
Swing-based controls for view navigation and overlay these controls on a view.
The default navigation controls are as usual visible in the top right corner. A secondary set of controls is added to the left side of the view. The distinct components are the same but they are separated and added in different corners and they always appear active. The compass navigation control on the left side points towards the magnetic north instead of the real north.
Use the secondary set of navigation controls to pan, zoom and rotate the view.
This sample contains three layers:
Navigate the map. Notice how the mouse location at the bottom indicates the pixel coordinates in the image.
Select one of the shapes and edit it or create a new shape.
Open an image file.
This sample contains two layers:
Navigate the map. Notice how the shapes at the top of the screen remain at the same position at any time.
Select one of the green shapes and edit it.
Select one of the blue ellipses. One of the icons and mini-ellipses is automatically selected as well.
Select one of the pencil icons or mini-ellipse. The corresponding ellipse is selected as well.
Edit one of the blue ellipses. The corresponding mini-ellipse is edited as well.
The sample loads 500.000 aircraft positions around New York.
The plots are painted with a plot layer (TLspPlotLayerBuilder
).
At a certain scale, heading arrows are displayed, and labels that are de-cluttered using the continuous de-cluttering algorithm.
Filtering can be done through the properties of the data model.
Styling is also based on the properties of the data model.
Change the filtering through the sliders and drop-down boxes. The filter is immediately effective.
Change the color and icons through the drop-down boxes. The change is immediately effective.
Enable and disable density plots through the checkbox. The change is immediately effective.
This sample demonstrates how to print a component containing a view, using the TLspViewComponentPrintable.
The sample creates a page layout containing the view and some decorations. You can preview the page or print it directly using the buttons in the toolbar.
This sample demonstrates how to configure the measurement controller and change different properties of it dynamically at runtime.
It is possible to modify the following ruler settings:
This sample shows how to programmatically create and display a model. It reveals how to create an ILcdModel, how to populate it with ILcdShape objects, and how to display that data in an ILspLayer on a Lightspeed view.
For a more extensive description of each of these steps see the developers' guide.
The sample shows a polyline, a polygon, and a point visualized by an icon. Try interacting with the shapes.
This sample is intended to illustrate the process of editing an object's style at runtime.
It creates a setup in which a
TLspEditableStyler
is used to edit the
styles of all the objects. To tweak the values of the provider at runtime, a widget was
implemented which provides a GUI for editing the most prominent style properties (see
StyleEditor
andStyleEditorModel
).
Note that for simplicity, this sample focuses on editing line- and fill styles, but the concepts used in this sample can be applied to editing other styles as well.
This sample demonstrates expression based-styling in a Lightspeed view using
TLspParameterizedLineStyle
, TLspParameterizedFillStyle
and
TLspParameterizedIconStyle
Use the layer selection panel on the right to select different layers, demonstrating different kinds parameterized
styles, ILcdExpression
and shapes.
The first layer shows Flightradar tracks styled with a TLspParameterizedLineStyle
. Only the segment
of a track that is within a specified time interval is visible.
The second layer shows European countries styled with a TLspParameterizedFillStyle
. The fill color
of the countries is derived from the population property of each country.
The last layer visualizes cities using a TLspParameterizedIconStyle
. An icon for a city is scaled based
on the population property and the distance to the mouse cursor.
This sample demonstrates the capabilities of TLspFillStyle
. It shows various layers with
shapes with different fill styles:
TLspFillStyle.StipplePattern
with convenience methods to
draw lines or filled/outlined rectangles, ovals or polygons.
BufferedImage
, and can
be scaled, rotated or translated. Additionally, the texture can be set to be applied
relative to the bounds of the object or relative to the bounds of the world.
The sample has various layers containing shapes with different fill styles.
Move around in 2D and 3D to see the effect.
Edit the shapes to see how the different fill styles adapt.
The icon style sample demonstrates the icon styling functionality of TLspShapeLayerBuilder, i.e.: rotation and transparency of icons, drawing icons with a vertical line and drawing icons either with a size in world coordinates or in view coordinates. All this is accomplished using TLspIconStyle.
The sample contains three layers with icons, all located around San Francisco:
Zoom in on San Francisco and see how each icon layer resizes its icons differently. Also notice how the rotatable icons layer changes the color of its icons based on the scale of the view. Use the rotation slider to change the orientation of the rotatable icons.
The Raster Style sample illustrates how the style of a raster can be changed on the fly:
The sample starts with a raster style with 100% brightness, 100% contrast, 100% opacity and no custom filter. For more detailed information on how to use raster styles and providers, see the developer's guide or the documented source code of this sample.
The sample shows 3 types of layers:
Select a raster layer in the layer control and change its style using the panel on the left.
This sample demonstrates how line data can be visualized using complex strokes. This is achieved by using TLspComplexStrokedLineStyle.
The sample shows a number of shapes with different strokes. Use the layer selection panel on the right to select different layers, demonstrating different kinds of strokes. Select and edit the shapes to see how the stroke pattern adjusts itself. Switch to a 3D view to see how stroked lines appear when they are draped over the terrain.
This applet demonstrates the use of the touch-based ILspControllers
.
It features a single controller chain to navigate around the map, and select and edit objects.
The sample features large buttons to allow easy manipulation with fingers instead of a mouse as input device.
Use one finger to pan around and to select or edit objects. Use two fingers to zoom.
This sample demonstrates how ALspController
can be extended to implement a custom
touch controller.
The first custom controller displays a tooltip for objects that are touched.
The second custom controller fits the view to the bounds of an object if a touch-and-hold action is performed on that object.
Activate the first custom controller ("information panels"). While you touch an object on the map (e.g. a county), a tooltip will pop up showing some of that object's attributes.
Activate the second custom controller ("fit to object"). Touch and hold an object until a red circle visually notifies you that the touch-and-hold time has been reached. If you now release your finger, the view will fit to the bounds of that object.
This applet demonstrates the use of the touch-based ILspControllers
for editing purposes.
Navigate, select and edit objects. You can make a layer selectable by first tapping on its name in the layer list, and then tapping on the "Toggle layer selectable" button.
To edit one of the shapes, you just have to touch the shape and interact with one of its editing handles. Please refer to the javadoc of the different editor classes in the API to see what functionality is provided by each of the handles.
To create a new shape, activate one of the create controllers in the toolbar. Note that most of the controllers also have an extruded creation variant. This variant creates an extruded shape with the base shape that is created by the normal editor. For instance, the ellipse create controller creates an extruded ellipse when extrusion is activated. Extrusion can be activated by the extrusion button in the creation toolbar (right most button).
Some shapes like polylines, polygons, and complex polygons have different (dynamic) creation steps that can be ended by pressing the Commit button. For example, to create a complex polygon containing two triangular shapes, the sequence of interactions should be: tap-tap-tap, commit (to end first polygon), tap-tap-tap, commit (to end second polygon), commit (to end complex polygon creation).
This sample demonstrates the effect of touch events on a touch enabled Lightspeed view. It contains a setup that simulates touch events and passes them to the Lightspeed view. The touch controller set on the view is a navigation controller by default and will interpret the incoming events by panning and zooming the view.
The simulation can be started by clicking the "Simulate touch events" button in the toolbar.
Start a simulation of how touch events are handled in a Lightspeed view by clicking the button in the toolbar.
This sample shows how different constraints can be added to the view's camera to automatically follow one or more moving objects.
The sample shows a model with three airplanes. Their position is constantly updated. The sample attaches a tracking constraint to the camera so the airplanes are always in view.
The different possible tracking constraints are:
TLspLookFromTrackingCameraConstraint3D
: used to fix the camera at a certain position. Panning
and zooming are not possible, but rotating still is. Optionally, the direction of the camera can be fixed as
well, so rotating is also impossible.
TLspLookAtTrackingCameraConstraint3D
: used to fix the camera in a certain direction. Panning is
not possible, but zooming and rotating still is.
TLspLookAtTrackingCameraConstraint2D
: same as above for 2D views.
The combobox on the right shows the available tracking modes. It changes the world reference, view's camera, and the tracking mode.
Supported tracking modes for a 3D view are:
This sample demonstrates the use of the vertical view package. The 2D view in the upper part contains a flight layer with two flight routes. Each flight route is modeled as a list of 3D points.
The vertical view in the lower part is used to display the vertical profile of the flight that is selected in the 2D view. Apart from this profile, a number of sub-profiles associated to it can be shown in a vertical view. In this case, two sub-profiles are associated to the view: the terrain and the air route. FlightVVModel, an implementation of ILcdVVModel holds the main-profile points and the information about the sub-profile.
Select a flight. A vertical marker is shown in both views. Change the height of the flight by dragging its points up or down. You can zoom the X and Y axes by using the sliders to the right and at the bottom. You can disregard flight points at the left or right of the flight using the sliders at the top. Finally, the panel at the right allows you to select the altitude unit.
The OGC Symbology Encoding (Styled Layer Descriptor) standard describes an XML format to describe the style of a layer. This sample demonstrates how to decode such a style from a file and how to apply it to a Lightspeed layer.
The application displays a number of layers and a set of styles. The styles can be applied to the layers. Some of the styles are specific for a particular layer, while others can be applied to any layer.
The text area at the right displays the description of the style as it is defined in the SLD file.
Select a layer in the layer control and a style in the dropdown list. Selecting the style will automatically apply it to the selected layer.
This sample demonstrates how to create your own
ILcyActiveSettable
implementation. An active settable can best be compared by a toggle action. It
is typically visualized in the UI by a toggle button (for example a check box).
The samples creates an
ILcyActiveSettable
which enables a custom
controller (the samples.gxy.ToolTipController
). When enabled, this
controller shows a tooltip for objects under the mouse.
The active settable is inserted in both the menu bar and the tool bar of the map. Note how the selected state of both buttons is kept in sync.
The controller can be activated by clicking its button in the tool bar or by clicking the Map | Controls | Tool tips menu entry. When the controller is activated, it will show a tooltip for objects under the mouse. Hover with your mouse over a country and wait until the tooltip appears. By default, the controller is already active on start-up
Deactivating the controller is done by selecting another controller, either in the tool bar or in the Map | Controls menu.
Note how the selected state of the button in the tool bar and the radio button in the Map | Controls menu is kept in sync the whole time.
This sample illustrates how you can use an ALcyApplicationPaneTool to add extra panels to Lucy.
Consult the Add extra panels with custom UI article for more information about this sample.
The map in this sample visualizes humanitarian events (violence against civilians, battles, riots, protests, ...) on the Africa continent. The data set contains over 13 thousand events. If each event was visualized as a single point, the data would become unreadable. Therefore, the data is clustered.
When many events took place at the same location, they will be visualized by a single cluster icon. The cluster contains a label indicating how many events it represents. The clusters will be recalculated during interaction with the view. For example, when zooming in clusters will be expanded into individual events. When zooming out, multiple clusters can be grouped into one bigger cluster.
This functionality is provided by the introduction of the ClusteringSHPAddOn
.
This add-on plugs in an ALcyLspFormat
which handles the visualization of one
specific shape file (see ClusteringFormat.SOURCE_NAME_FILTER
).
In order to ensure that those shape files are not picked up by the default SHP add-on
(TLcyLspSHPFormatAddOn
),
the add-on plugs in the format with a higher priority.
This is done in ClusteringSHPAddOn#createFormatTool
.
The clustering functionality is located in the layer factory.
The incoming model gets decorated with an ALcdTransformingModel
using a
TLcdClusteringTransformer
,
and the layer is created for the transforming model.
As the add-on creates its own ALcdTransformingModel
instances, it is responsible to provide
workspace support for those models as well.
This is achieved by plugging in a ClusteringModelCodec
instance.
This sample demonstrates how to determine which files can be opened by Lucy as well as the actual opening of those files.
Lucy uses two concepts for opening a file:
ILcdModelDecoder
instances are used to convert a source to an ILcdModel
. When
the data needs to be visualized, the model is converted to a layer which can be added to a view. This
is the same mechanism as available in the core LuciadLightspeed product.
ALcyDataSourceHandler
instances are used to open all other data which do not fit
in the concept of an ILcdModelDecoder
. An example is data originating from a server like a WMS
server.
Typically this requires that a connection is set up to the server to see which data is available.
Then the data is selected, and that data stream can then be visualized on the client side.
Each of the format add-ons registers its model decoders and/or data source handlers to the Lucy
back-end (see
TLcyCompositeModelDecoder#addModelDecoder
and TLcyCompositeDataSourceHandler#addDataSourceHandler
).
Registering such an instance requires to register a matching ALcyFileTypeDescriptor
.
This descriptor allows to quickly filter which files are accepted by the model decoder or data source handler
through its
includes
method.
This sample illustrates how to use those registered
ALcyFileTypeDescriptor
instances
to determine which files in a certain directory can be opened by Lucy. The configuration file
allows to specify this directory and search depth. For each of the files in those directories
a menu-item will be added. When the menu item is clicked, the data is loaded on the map.
Loading of data in Lucy is the responsibility of the TLcyDataFormatManager
. This
class provides a
handleDataSources
method which will load the specified data.
Notice that opening some files may result in an error. For example a CADGR file and a Dafif file both have the extension .toc . Lucy indicates, based on the extension of the file, it can handle the file when at least one of the addons responsible for these file types is loaded. So when trying to open a Dafif file when this addon is not loaded, an error will be produced since the CADGR decoder does not know how to decode a Dafif file.
Use the menu items under the 'Data' menu item to load data onto the currently active GXY map. The data will be loaded on a background thread when a menu item is clicked. Loading the data on a background thread makes sure the Lucy UI remains responsive during the loading of the data.
The Lucy drawing add-on provides support for making annotations on a map. It comes with a set of default shapes and styling options. The API of this add-on allows customizations on many levels, for example:
This sample illustrates how to add support for a complete new domain object to the drawing add-on. The custom domain object is in this example just a simple point that is visualized with an icon.
All support for the custom domain object is created in the
CustomDomainObjectSupplier
class. This domain object supplier is then registered to the drawing format in the
DrawingCustomDomainObjectAddOn
.
The custom domain object is also available on Lightspeed maps with the same functionality as
on the GXY map. All the Lightspeed support for the custom domain object is contained in the
LspCustomDomainObjectSupplier
class which is registered to the Lightspeed drawing
format in the LspDrawingCustomDomainObjectAddOn
.
It is strongly recommended to read the chapter about the drawing add-on in the Lucy developer guide before going through the sample code. The developer guide provides an overview of the structure of the drawing add-on, and illustrates where the different customization hooks are located in the API. This knowledge will make it easier to understand and follow the code in this sample.
The sample starts with a drawing layer containing multiple custom domain objects and the drawing toolbar active.
All functionality is available on GXY and Lightspeed maps.
The Lucy drawing add-on provides support for making annotations on a map. It comes with a set of default shapes and styling options. The API of this add-on allows customizations on many levels, for example:
This sample illustrates how to customize one of the existing shapes. The customized shape in this example is the circle. During the creation of the circle the radius is displayed in a label. When moving an existing circle to another location using the mouse, the location of the center point is shown. On a Lightspeed view, the radius and center locations are both shown during editing and during creation.
The customization of the circle shape supplier happens in the
CircleSupplierWrapper
class. The decorated supplier is then registered to the drawing format in theDrawingPaintingAddOn
.
The customization of the Lightspeed circle shape supplier happens in the
LspCircleSupplierWrapper
class. The decorated supplier is then registered to the Lightspeed drawing format in the
LspDrawingPaintingAddOn
.
It is strongly recommended to read the chapter about the drawing add-on in the Lucy developer guide before going through the sample code. The developer guide provides an overview of the structure of the drawing add-on, and illustrates where the different customization hooks are located in the API. This knowledge will make it easier to understand and follow the code in this sample.
The sample starts with a drawing layer containing multiple circles and the drawing toolbar active.
All functionality is available on GXY and Lightspeed maps. On a Lightspeed map both the radius and the center location are shown during editing and creation.
The Lucy drawing add-on provides support for making annotations on a map. It comes with a set of default shapes and styling options. The API of this add-on allows customizations on many levels, for example:
This sample illustrates how to add support for a new shape while reusing the default styling options. The new shape in this example is the Hippodrome shape which is a shape available in the foundation samples.
All support for this new shape is created in the
HippodromeShapeSupplier
class. This
shape supplier is then registered to the drawing format in the
DrawingHippodromeAddOn
class.
The hippodrome shape is also available on Lightspeed maps with the same functionality as on the GXY
map. All the Lightspeed support for the hippodrome shape is contained in the
LspHippodromeShapeSupplier
class which is registered to the Lightspeed drawing format in the LspDrawingHippodromeAddOn
.
It is strongly recommended to read the chapter about the drawing add-on in the Lucy developer guide before going through the sample code. The developer guide provides an overview of the structure of the drawing add-on, and illustrates where the different customization hooks are located in the API. This knowledge will make it easier to understand and follow the code in this sample.
The sample starts with a drawing layer containing multiple hippodrome shapes and the drawing toolbar active.
All functionality is available on GXY and Lightspeed maps.
The Lucy drawing add-on provides support for making annotations on a map. It comes with a set of default shapes and styling options. The API of this add-on allows customizations at many levels, for example:
This sample illustrates how you can define styles up front, and provide the user with the UI to apply one of those pre-defined styles on the selected shapes.
Each drawing model has its own style repository (see TLcyDrawingModelDescriptor#getDrawingStyleRepository
).
This sample populates the style repository with some pre-defined styles (see
ApplyStyleActionFactory#addDefaultStyles
).
It also adds UI to the drawing tool bar. The UI lets the user apply one of those pre-defined styles to the selected
drawing objects.
This is done in the ApplyStyleAction#applyStyle()
method.
Applying one of the pre-defined styles to a drawing domain object comes down to retrieving the style object from the style repository, and setting it on the drawing domain object. At this point, the domain object shares its style with the style in the repository. As a result, a change to the style in the repository will lead to a style change of the domain object as well.
To ensure that this mechanism keeps working when the drawing model is saved and loaded later on, all the styles in the style repository are saved to the drawing file (*.drawing), along with the drawing shapes. The domain objects that share a style will save a reference to the style in the repository instead of saving the style itself. This allows restoring the style shared between domain object and style repository when the drawing file is loaded. You can see an example of this in the drawing file loaded by this sample (resources/samples/drawing/styles/polygonLayer.drawing).
It is strongly recommended to read the chapter about the drawing add-on in the Lucy developer's guide before going through the sample code. The developer's guide provides an overview of the structure of the drawing add-on, and illustrates the location of the customization hooks in the API. Knowledge of those Lucy drawing basics will make it easier to understand and follow the code in this sample.
The sample starts with a drawing layer that contains multiple polygons with different styles. The drawing tool bar is active.
All functionality is available on GXY as well as Lightspeed views.
This sample shows how you edit data in the Table view or in the Object Properties.
By registering customizer panel factories for instances of TLcdDataPropertyValueContext
,
you can enable editing for values of specific properties. The class
TLcyDataPropertyValueCustomizerPanelFactories
offers a number of implementations for basic types like Strings, Numbers, Measures etc... .
The class
TLcyDataPropertyValueFilters
offers filters that allow you to
pinpoint for which property you wish to register a customizer panel factory. For more information
we refer to the Javadoc of these classes.
This sample shows how you can add data to every map that is generated or constructed by the application, so for example not loaded from a file using a model decoder.
This sample generates an ILcdModel
using the generateModel
utility method in
GeneratedFormatAddOn
. For the purpose of the sample, it creates a very basic model with just three points
in it, but it could of course be anything. For example the result of some computation, the result of some web service
request or a connection to a live feed of tracks. The method addGeneratedDataToEveryMap
adds this model
to all current and future maps, respecting workspace support. The sample creates a new model instance for every map,
but could easily be modified to share a single model across maps, depending on the desired behavior.
This programmatically generated ILcdModel
is actually a new data format. So a Lucy
ALcyFormat
is created and plugged in. As Lightspeed support is needed as well, two formats are actually used:
GeneratedFormat
: this format is plugged in by GeneratedFormatAddOn
and takes care of
providing workspace support for the model, and providing a model content type provider. If GXY support would be
required, it would also be added here. The sample opted to not provide this, so null
is returned for
the GXY layer factory.
GeneratedLspFormat
: this format is plugged in by GeneratedLspFormatAddOn
and provides
the layer factory for Lightspeed views. Through its super-class, it also inherits workspace support for the
Lightspeed layers.
This sample demonstrates how to create your own Lucy front-end based on dockable frames provided by JIDE.
The front-end of Lucy is the part that starts Lucy, creates the general user interface
and loads the addons. Lucy is delivered with one such front-end,TLcyMain
, which
can create two different kinds of user interfaces: one with dockable frames (the default) or
one with tabbed panes.
This sample illustrates how to replace the whole front-end by a custom implementation where the
UI is based on dockable frames provided by JIDE. The docking functionality of this front-end
is identical to the 'DOCKING' mode ofTLcyMain
.
The general front-end functionality (for example the add-on loading) is located in the
AFrontEnd
class and is shared between the different front-end samples contained in the release. The UI
specific code is not available as source code. As such, this sample only allows to customize the
overall layout.
This sample does not require a JIDE license as it does not allow to program to the JIDE libraries.
It does allow to customize the overall layout to your needs, but does not provide access to its
ILcyApplicationPaneFactory
implementation.
Consult the Lucy developer guide for more information about custom front-ends.
The sample starts and shows the map, map overview and layer control using dockable frames.
This sample demonstrates how to create your own Lucy front-end based on internal frames.
The front-end of Lucy is the part that starts Lucy, creates the general user interface
and loads the addons. Lucy is delivered with one such front-end,TLcyMain
, which
can create two different kinds of user interfaces: one with dockable frames (the default) or
one with tabbed panes.
This sample illustrates how to replace the whole front-end by a custom implementation where the UI is based on internal frames.
The general front-end functionality (for example the add-on loading) is located in the
AFrontEnd
class and is shared between the different front-end samples contained in the release. The UI
specific code is contained in an
ILcyApplicationPaneFactory
implementation specific
to this sample:InternalFrameAppPaneFactory
.
Consult the Lucy developer guide for more information about custom front-ends.
The sample starts and shows the map, map overview and layer control using internal frames.
This sample demonstrates how to create your own Lucy front-end based on on-map panes.
The front-end of Lucy is the part that starts Lucy, creates the general user interface
and loads the addons. Lucy is delivered with one such front-end,TLcyMain
, which
can create two different kinds of user interfaces: one with dockable frames (the default) or
one with tabbed panes.
This sample illustrates how to replace the whole front-end by a custom implementation where the UI is based on so called on-map panes.
The general front-end functionality (for example the add-on loading) is located in the
AFrontEnd
class and is shared between the different front-end samples contained in the release. The UI
specific code is contained in an
ILcyApplicationPaneFactory
implementation specific
to this sample:MapCentricAppPaneFactory
.
It has one large area for the map, and all other panels are shown in so called on-map panes. These on-map panes are floating on top of the map. A limitation is that it only supports one map, if a second one is added, it throws an exception.
Consult the Lucy developer guide for more information about custom front-ends.
The sample starts and shows the map, map overview and layer control using internal frames.
This sample demonstrates how to create your own multi-touch front-end for Lucy.
The sample has the following modifications compared to the map centric front-end:
Consult the Lucy developer guide for more information about custom front-ends.
The sample starts and shows the map, map overview and layer control using internal frames. The size of all UI elements is increased to facilitate touch interaction. The controllers for the map are touch controllers.
This sample demonstrates how to create your own Lucy front-end based on tabbed panes.
The front-end of Lucy is the part that starts Lucy, creates the general user interface
and loads the addons. Lucy is delivered with one such front-end,TLcyMain
, which
can create two different kinds of user interfaces: one with dockable frames (the default) or
one with tabbed panes.
This sample illustrates how to replace the whole front-end by a custom implementation where the UI is based on tabbed panes.
The general front-end functionality (for example the add-on loading) is located in the
AFrontEnd
class and is shared between the different front-end samples contained in the release.
It offers unlimited flexibility over the main class, the user interface, how many tabbed panes to use, where to put them, whether to use tabbed panes at all, addon loading, position of the frame, number of frames, ... It also allows you to integrate Lucy within an existing application.
Consult the Lucy developer guide for more information about custom front-ends.
The sample starts and shows the map, map overview and layer control using tabbed panes.
This sample demonstrates how to customize the user interface of the GXY maps in Lucy.
The UI is customized by registering a custom extension of
TLcyMapComponentFactory
and
TLcyMapLayerControlFactory
to the map add-on. The registration of these custom factories
is done by setting the factory instances in the configuration file of theTLcyMapAddOn
.
The
MapComponentFactory extends TLcyMapComponentFactory
provides the following customizations
to the map:
The
MapLayerControlFactory extends TLcyMapLayerControlFactory
provides the following
customizations to the layer control:
Consult the Lucy developer guide for more information on customizing the GXY map.
On start-up, the sample shows a map which has a customized user interface.
This sample illustrates how to use the
ILcdHeightProvider
interface and
one of its Lucy specific implementations TLcyViewHeightProvider
.
The sample contains a panel which displays the minimum, maximum and average height in the currently visible area. The panel contains an 'Update' button allowing to recalculate those heights, for example when extra data is loaded or when the view bounds have been changed.
To calculate the minimum and maximum height in the visible area, a grid of sample points in the view are taken. This means that if the view is zoomed out, it is possible that the true lowest and highest point are missed and a less extreme value is displayed.
More information on the
ILcdHeightProvider
interface can be found in the
LuciadLightspeed developer guide.
Samples starts with the height panel visible, and the map fit on the Alps layer. Pressing the 'Update' button performs the height calculations and shows the results in the panel.
When changing the rotation, zoom or position in the Map view, use the 'Update' button in the Height pane to get the new values.
This sample demonstrates how to use the registered
ILcyCustomizerPanelFactory
instances on the Lucy back-end to create an ILcyCustomizerPanel
.
The sample shows the Layer Properties panel in a separate application pane. The Layer Properties panel is the same panel as shown when triggering the Layer Properties action in the layer control. Each time the selected layer is changed, the panel will show a new panel matching the new layer selection.
The code which creates the
ILcyCustomizerPanel
by using the registered
ILcyCustomizerPanelFactory
instances can be found in LayerPropertyEditor#createCustomizerPanelForContext
.
Consult the Lucy developer guide for more information about the
ILcyCustomizerPanel
and
ILcyCustomizerPanelFactory
interfaces.
When the sample starts, the 'Countries' layer is selected. In the upper-left corner, the Layer Properties panel is visible.
This sample demonstrates how to customize the user interface of the Lightspeed maps in Lucy.
The UI is customized by plugging in a custom extension of the
TLcyLspMapAddOn
(LspMapAddOn
) which overrides the
createGUIFactory
method. The overridden
method returns a custom
TLcyLspMapComponentFactory
and
TLcyLspMapLayerControlFactory
extension.
The
LspMapComponentFactory extends TLcyLspMapComponentFactory
provides the following
customizations to the map:
The
LspMapLayerControlFactory extends TLcyLspMapLayerControlFactory
provides the
following customizations to the layer control:
Consult the Lucy developer guide for more information on customizing the Lightspeed map.
On start-up, the sample conveniently loads a workspace that already contains a Lightspeed map to which an extra SHP layer has been added. Notice how the user interface of the Lightspeed map has been customized.
This sample illustrates how you can have multiple Lightspeed map component types, where each map component type has its own specific settings.
The sample defines two types of map components: a map for the preparation of a mission and a map which can be used during the execution of that mission. In the execution view, most of the common actions are removed so that only basic navigation is possible.
The different map types are defined in the custom configuration file for the
TLcyLspMapAddOn
:MissionMap_TLcyLspMapAddOn.cfg
. In this
file a
preparation
and
preview
map component type are defined
which both use a custom configuration file. These custom configuration files will make sure
that each type of map component has its specific UI.
The sample starts with a preparation view. An additional mission-switching button has been
added to the top toolbar. This button allows to create, next to the Mission Preparation tab,
an additional Mission Preview tab, as to get a preview of the execution view
during the preparation of that mission. This button triggers the
PreviewMapAction
which illustrates how you can use the API of the
TLcyLspMapAddOn
to create
a new map and add it to the UI.
Consult the Lucy developer guide for more information on using multiple Lightspeed map component types and map customizations.
Sample starts with the preparation view active. Load some data, make some changes to the styling of this data, ... .
Click the mission-switching button which has been added to the top toolbar to create, next to the Mission Preparation tab, an additional Mission Preview tab, as to get a preview of the execution view during the preparation of that mission.
As is shown, in execution view most of the common actions are removed so that only basic navigation is possible: it becomes impossible to load, remove or adapt layers and the ruler button, selector button and most menu items disappear.
Also note that layers and layer setting that are added or changed in the preparation view are not lost when opening execution view.
This sample illustrates how you can benefit from the Lucy style support by using an
ILspCustomizableStyler
on your layers.
Lucy will offer you:
The workspace support and saving of the style are made possible by letting the
SHPFormat
extend from the
ALcyLspStyleFormat
class. The class javadoc of that format documents
when this format can be used. The main requirement is that the extension uses an
ILspCustomizableStyler
as styler on the layers.
The user interface is provided by the TLcyLspLayerCustomizerAddOn
. This add-on can create
such customizer panels for
ILspCustomizableStyler
instances. Consult the class javadoc
of that add-on for more information.
More information on the built-in style support of Lucy can be found in the Lucy developer guide.
The sample opens with a Lightspeed map containing a SHP layer representing the countries of the world. The style used to paint the country depends on the population of the country. Small countries are painted in white, larger countries painted in pink.
Open the layer properties panel of the 'Countries' layer and modify the style for both the small and large countries.
This sample illustrates how to load a style which was previously saved and apply this loaded style to an existing layer.
The sample adds menu items under 'Map | Colors' which allow to change the style of the 'World' layer.
Lucy has the concept of ILcyLayerStyle
: an object which represents all
the style information of a layer. Such a layer style can be saved to and loaded from persistent
storage (for example to/from file), and can be applied to a layer. This sample illustrates both
mechanisms.
The most important code of this sample is located in the
ChangeStyleAction#loadStyle
method. First the layer style is retrieved from the layer using the available
ILcyLayerStyleProvider
instances. When the layer style is found, the settings stored in the file are applied on this
layer style by using aILcyLayerStyleCodec
.
The sample also shows how the application-wide selection style,
as provided by the TLcyLspStyleRepositoryAddOn, can be altered through the API. This is demonstrated
in the
ChangeStyleAction#updateSelectionStyleColors
method.
The sample adds menu items to the Map | Colors menu which allow to change the style of the existing layers to some predefined values. Switch between the different colors and watch how the style is applied to the world layer. Note how the default application-wide selection style changes from orange to white when switching to one of the predefined styles.
Use the 'Map | Colors' menu items to change the style of the world layer. Note how the selection style is also adjusted.
This sample demonstrates one of the customization options for the Lightspeed 'Layer Properties' panels.
Most of the Lightspeed layers use a 'Layer Properties' panel which is provided by the
TLcyLspLayerCustomizerAddOn
. This add-on provides a panel which allows to change
the style settings when the layer uses an ILspCustomizableStyler
. It also provides
a mechanism to change parts of this panel or to create your own panel re-using parts of the
default UI. Consult the class javadoc of the
TLcyLspLayerCustomizerAddOn
for more information.
In this sample, the standard UI for customizing the line style has been replaced by a custom UI.
This is achieved by registering an
ILcyCustomizerPanelFactory
for
TLcyLspCustomizableStyleContexts
on the Lucy back-end (see CustomLineStyleAddOn#plugInto
).
All of these contexts should contain one or more
TLspCustomizableStyles
wrapping TLspLineStyles
.
The panel created by the
TLcyLspLayerCustomizerAddOn
will use the registered
ILcyCustomizerPanelFactory instances of the Lucy back-end to create its UI.
It is strongly recommended to read the Lightspeed styling part in the Lucy developer guide before going over the code of this sample. The Lucy developer guide gives a high-level overview of the Lucy style support and customization options. This knowledge will make it easier to understand the code in this sample.
The sample starts with a Lightspeed view to which the 'Trajectories' layer is added. Open the 'Layer Properties' panel of that layer and note how the standard UI for changing the line style has been replaced by a custom one.
This sample demonstrates one of the customization options for the Lightspeed 'Layer Properties' panels.
Most of the Lightspeed layers use a 'Layer Properties' panel which is provided by the
TLcyLspLayerCustomizerAddOn
. This add-on provides a panel which allows to change
the style settings when the layer uses an ILspCustomizableStyler
. It also provides
a mechanism to change parts of this panel or to create your own panel re-using parts of the
default UI. Consult the class javadoc of the
TLcyLspLayerCustomizerAddOn
for more information.
In this sample parts of the standard UI are re-used to create a custom panel for a specific format.
This sample does not load the standard
TLcyLspSHPFormatAddOn
but replaces it by the SHPFormatAddOn
.
This
SHPFormatAddOn
plugs in its own format which allows to visualize SHP data
containing points. Furthermore, it overrides the
createLayerCustomizerPanelFactories
method to provide a
custom layer properties panel for those SHP layers. The custom panel only contains UI for the general
layer settings (e.g. visible, selectable, ... ) and UI to adjust the icon which is used.
It is strongly recommended to read the Lightspeed styling part in the Lucy developer guide before going over the code of this sample. The Lucy developer guide gives a high-level overview of the Lucy style support and customization options. This knowledge will make it easier to understand the code in this sample.
The sample starts with a Lightspeed view to which the 'city_125' layer is added. Open the 'Layer Properties' panel of that layer and note how the panel no longer contains tabs but provides all the info in one panel. The panel also features UI to customize the icon style.
This sample illustrates how to load a style which was previously saved and apply this loaded style to an existing layer.
The sample adds menu items under 'Map | Colors' which allow to change the style of the countries layer.
Lucy has the concept of ILcyLayerStyle
: an object which represents all
the style information of a layer. Such a layer style can be saved to and loaded from persistent
storage (for example to/from file), and can be applied to a layer. This sample illustrates both
mechanisms.
The most important code of this sample is located in the ChangeStyleAction#actionPerformed
method. The reading of the style file and creation of the ILcyLayerStyle
is done by using the ILcdGXYLayerDecoder
instances available on the Lucy back-end.
Once the ILcyLayerStyle
is created, it is applied on the countries layer by using the available
ILcyLayerStyleProvider
instances.
Use the menu item under 'Map | Colors' to change the style of the countries layer.
This sample demonstrates how to customize the printing functionality in Lucy.
The sample modifies the printed content in the following ways:
Consult the Lucy developer guide for more information on customizing the print page layout, the print preview UI, and more.
Open the print preview by using the 'File | Print Preview...' menu item on a 2D or 3D map.
The sample changes the page orientation to landscape. The preview shows one page with a watermark,
with at the top a header text and next to it an overview component. The legend, scale icon and scale
indication components are located at the right side of the map.
If you print the result, you'll notice a title page included in the print-out.
The Lucy Showcase sample illustrates various parts of the LuciadLightspeed technology, and how that technology is integrated
in
Lucy.
The sample comes with a set of pre-defined workspaces that each highlight a certain aspect of the product.
The sample also includes a user interface component that shows a preview of all available workspaces.
The UI is provided by the ThemeChooserAddOn
sample add-on.
Open the workspace overview by clicking the theme chooser icon located at the bottom of the left side bar. In the overview, you see a preview image of each workspace. Clicking one of the images to load the workspace.
It is possible to add your own workspaces to the Showcase sample, and remove existing workspaces.
By default, the sample shows all the workspaces from a pre-defined folder
(samples/lucy/showcase/themes
), but you can change that in the samples/showcase/ThemeChooserAddOn.cfg
configuration file.
If you remove workspaces from that folder, they will be removed from the sample.
You add support for an extra workspace by adding extra files to that folder:
custom.lws
. Note that the name of the workspace file determines the
name shown in the UI. In this example, the UI shows the name "custom".
custom.png
for example.
Lucy automatically saves such a preview image when you save a workspace.
You can always replace the standard preview image saved by Lucy with a custom one.
custom.html
for example.
The instructions in that file are shown underneath the map when the workspace is loaded.
This sample keeps the style of multiple layers in sync. Keeping the styles in sync illustrates multiple operations on a layer style:
ILcyLayerStyle
using the available
ILcyLayerStyleProvider
instances.
ILcyLayerStyle
.
The retrieval of the layer style and the copy operation are shown in the
LayerStyleSynchronizer#copyLayerStyle
method. Listening to changes of an existing layer style is done by registering an
ILcdChangeListener
to the
ILcyLayerStyle
instance. This is shown in the
LayerStyleSynchronizer#addLayer
method.
The style synchronization mechanism works for all layers on all maps. The layers only need to share the same model (for example by copying a layer from one map to another using the button in the layer control), and the styles will be kept in sync.
This synchronization mechanism can be switched off in the menu bar under 'Map | Synchronize layer style'.
The sample starts with a GXY and a Lightspeed map. The Trajectories layers on both maps share the same model, so the style of that layer will be synchronized.
Lucy has built-in functionality to show the attributes associated to data in tabular views. This sample illustrates how you can customize this tabular view.
The sample sets a renderer to the table which renders the text in color and italic. A button is added to the toolbar of the table which allows to change the color of the text.
This sample also illustrates the concept of an ALcyGUIFactory
: a class responsible
for the creation of a UI element (typically a whole panel) which provides API to customize this UI. The API
is designed in such a way that you can only need to provide code for the parts you want to customize, and
can reuse all the other UI elements.
The
TableViewGUIFactory
shows how an ALcyGUIFactory
is typically implemented
in the Lucy product. The TableViewExtGUIFactory
is an extension of this TableViewGUIFactory
,
illustrating how you can use the ALcyGUIFactory
API to customize parts of the UI and reusing
the rest.
See Working with Lucy GUI factory instances for more information on the ALcyGUIFactory
concept.
Note that the table view source code is included with every release. If you want to make customizations
beyond what the sample API has to offer you you can modify the source code directly. The class
javadoc of the
TLcyToteAddOn
(the official table-view add-on) documents the steps you need
to take to replace the default add-on by a customized add-on.
The sample starts with a table view for the world layer. The contents of the second column are rendered in bold, italic and blue.
Detailed instructions on using the regular table view can be found in Displaying your data in a table view.
This sample adds support for an editable, time-dependent format to Lucy. The data contains airplane trajectories, and allows to visualize the position of the aircraft during flight. It supports:
The sample adds two add-ons for this:
TrajectoryModelAddOn
: this add-on provides support for the modelling of the trajectory data.
TrajectoryAddOn
: this add-on provides visualization support for the trajectory data on a Lightspeed
map,
as well as the controller to create new trajectories on the map.
The product documentation contains some articles that provide more information about the product API used in this sample:
The default TLcyWorkspaceAddon
provides among other things the 'Open workspace' and 'Save workspace (as)' actions.
This sample shows how you can re-use the functionality behind those actions, while having full control over
the UI which is shown to the user, and the strings which are passed to the workspace manager.
An example use-case where you want to customize the UI and the strings is when you want to store the workspaces into a database instead of on the file system.
This sample illustrates the use-case where you want to save the workspaces to a hardcoded directory,
and load the workspaces from that same directory.
When you trigger the 'Open workspace' action, you will be presented with a modal dialog showing a progress indicator
(see the ChooseFromListWorkspaceAddOn.selectWorkspaceToOpen
method).
At the same time on a background thread the hardcoded directory will be scanned for existing workspaces (see the
FileRetrievalSwingWorker
class).
Once the background thread is finished, the dialog is updated and the user can select a workspace.
The selected workspace is converted to a path which is passed to the workspace manager.
When saving a workspace, the user only needs to input a name for the workspace (see the
ChooseFromListWorkspaceAddOn.selectWorkspaceDestination
method).
The name is converted to a path in the hardcoded directory, and passed to the workspace manager.
As the sample still works with file-based workspaces and passes file paths to the TLcyWorkspaceManager, there is no need to replace the ALcyWorkspaceCodec on the TLcyWorkspaceManager. The default codec is capable of handling file paths. In case you store the workspaces in a database, you will have to replace the codec.
Use the 'File | Open workspace' to open one of the workspaces from the hardcoded directory. Make some changes to it (for example load some extra data) and use the 'File | Save workspace as' action to save it with a new name.
This sample demonstrates the ability to load metadata encoded following the ISO 19139 standard schema.
Click the open button and select a file from the LuciadLightspeed/samples/resources/Data/metadata folder. The central frame will display the metadata as encoded in the file.
This sample demonstrates a simple gazetteer functionality.
Some metadata files are loaded and the geographic extent of the data they describe is extracted from the metadata and displayed on the map as bounds.
Double click on the bounds to display all metadata linked to the bounds.
Right click with the mouse to load the data which is described in the metadata. The location(s) of the file to load is extracted from the metadata.
This sample shows how to visualize dynamic tracks in a GXY map.
The sample shows several random parabolic trajectories and animates 2000 dynamic tracks moving
along these trajectories. The dynamic tracks layer is simulated using a
TLcdSimulator
with a custom ALcdSimulatorModel
.
Each track has a label that displays its identifier, and the grounded state of the track.
Press the "Play" button to start or the simulation. The tracks start moving across their individual trajectories.
As the tracks move around, the labels are gently repositioned to avoid overlap. If you hover the mouse over a label of a moving track, it stops moving. In the rare event labels get mixed up, you drag them to a new location. Labels move back automatically.
A time slider allows to see your progression in the simulation. When the simulation is not running, the slider also allows you to change the "simulation time" with your mouse.
You can adjust the replay speed factor using the "speed up" slider.
This sample shows how to visualize dynamic tracks in a Lightspeed map and timeline.
The sample shows 2000 random parabolic trajectories and animates 2000 dynamic tracks moving
along these trajectories. The dynamic tracks layer is simulated using a
TLcdSimulator
with a custom ALcdSimulatorModel
.
Tracks are visualized with airplane icons. In 3D projections, a line connects each icon with its zero-elevation
point.
Each track also has a trail of grey dots indicating previous positions. The trail is added to
the icons by using a custom ILspStyler
.
The track labels are decluttered using the TLspContinuousLabelingAlgorithm
,
a specialized algorithm for moving objects in a Lightspeed view.
The time line at the bottom is a non geo-referenced Lightspeed view that you can pan and zoom.
Press the "Play" button to start the simulation. The tracks start moving across their individual trajectories. The time view is also updated. If you pan the time view, the simulation is also updated. You can adjust the replay speed by zooming in or out on the time line.
Select a plane in the main view. Its altitude over time is displayed in the time view along with the name of its landing and take-off city.
Zoom in and pan around the world to see how the labels of the dynamic tracks are automatically decluttered depending on the current situation. You can also select and move all of the track labels.
The OGC Styled Layer Descriptor standard describes an XML format to describe the style of a layer. This sample demonstrates how to decode such a style from a file and how to apply it to a layer.
The application displays a number of layers and a set of styles. The styles can be applied to the layers. Some of the styles are specific for a particular layer, while others can be applied to any layer.
The text area at the right displays the description of the style as it is defined in the SLD file.
Select a layer in the layer control and a style in the dropdown list. Clicking the apply button will attempt to apply the style to the selected layer. Selecting 'Default' in the list resets the style of the layer.
This is a command-line sample. Click More info for run instructions.
This application demonstrates how to encode spatial data to a GeoPackage file, using TLcdGeoPackageModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.sqlite.geopackage.bat source_file destination_gpkg_file
Pass two arguments to this sample: an input file and a (new or existing) .gpkg file.
This sample demonstrates how to use an OGC Web Coverage Service (WCS) in a client application equipped with a 2D GXY view, using the Luciad WCS client API.
Using the client API, applications can create a "proxy" ILcdModel that transparently obtains coverage data from the WCS.
When a connection is made with a WCS service, the combo box in the upper right of the sample is populated with the list of coverages offered by this WCS. These coverages can be selected and visualized on the map.
During startup, the sample will try to connect to one of two default OGC WCS services:
samples.ogc.server.Main
sample.
Querying the list of available coverages: fill in a URL in the text field below the map and press the "Query WCS service" button. This will send a GetCapabilities request to the service and parse the list of available coverages. When successful, the coverages will be listed in the combo box in the upper right corner of the sample.
Retrieving and visualizing a coverage: select a coverage in the combo box in the upper right of the sample. Click the "Get coverage" button to send a GetCoverage request to the service and visualize the requested data on the map.
This sample demonstrates how to use an OGC Web Feature Service (WFS) in a client application equipped with a 2D GXY view, using the Luciad WFS client API.
Using the client API, applications can create a "proxy" ILcdModel that transparently obtains feature data from a WFS. This WFS proxy model can optionally be configured with an OGC Filter to be applied to the data and, as is done in the sample, a "maxfeatures" parameter to limit the number of features that are retrieved from the service.
When a connection is made with a WFS service, the combo box in the upper right of the sample is populated with the list of features types offered by this WFS. Selecting a feature types from the list retrieves and visualize the feature data on the map. You can also connect to other WFS services through the URL panel below the map.
During startup, the sample will try to connect to one of two default OGC WFS services:
samples.ogc.server.Main
sample.
To query the list of available feature types, fill in a server and press the "Query" button. This will send a GetCapabilities request to the service and parse the list of available features types. When successful, the feature types will be listed in the combo box in the upper right corner of the sample.
To visualize a feature type, just select it from the combo box. This will send a GetFeature request to the service for the selected feature type, and create a layer to visualize the retrieved feature data.
This sample demonstrates how to use an OGC Web Feature Service (WFS) in a client application equipped with a 2D / 3D Lightspeed view, using the Luciad WFS client API.
Using the client API, applications can create a "proxy" ILcdModel that transparently obtains feature data from a WFS. This WFS proxy model can optionally be configured By default, this results in a map loaded with:
When a connection is made with a WFS service, the combo box in the upper right of the sample is populated with the list of features types offered by this WFS. Selecting a feature types from the list retrieves and visualize the feature data on the map. You can also connect to other WFS services through the URL panel below the map.
During startup, the sample will try to connect to one of two default OGC WFS services:
samples.ogc.server.Main
sample.
To query the list of available feature types, fill in a server and press the "Query" button. This will send a GetCapabilities request to the service and parse the list of available features types. When successful, the feature types will be listed in the combo box in the upper right corner of the sample.
To visualize a feature type, just select it from the combo box. This will send a GetFeature request to the service for the selected feature type, and create a layer to visualize the retrieved feature data.
This sample demonstrates how to query ECDIS data from a LuciadFusion OGC Web Map Service (WMS) in a WMS client application, taking into account S-52 display settings.
This sample requires a LuciadFusion WMS service supporting SLD-based S-52 styling.
You can use the S-52 customizer panel on the right side of the map to tweak the display settings for the ECDIS WMS layers. The WMS client will encode the S-52 display settings into an S-52 SLD extension, and embed this SLD in the GetMap request that is sent to the server. The Fusion WMS server will return the ECDIS image, rendered with the settings from the SLD.
During startup, the sample will try to connect to a public LuciadFusion OGC WMS service (http://sampleservices.luciad.com/wms). Additionally, you can connect to other LuciadFusion WMS services through the URL panel.
Map interaction: the toolbar offers a set of actions to navigate on and interact with the map. This includes the ability to pan and zoom, to measure distances and to switch the projection. When the selection projection does not match the available projects in the WMS service, the data is automatically reprojected, fully transparent for the user.
S-52 display settings: The S-52 display settings customizer panel right of the map allows to modify the S-52 display settings. Any change to the settings will immediately trigger a new query to the WMS server with updated S-52 SLD styling parameters, and update the client view accordingly.
This sample demonstrates how to query ECDIS data from a LuciadFusion OGC Web Map Service (WMS) in a WMS client application, taking into account S-52 display settings.
This sample requires a LuciadFusion WMS service supporting SLD-based S-52 styling.
You can use the S-52 customizer panel on the right side of the map to tweak the display settings for the ECDIS WMS layers. The WMS client will encode the S-52 display settings into an S-52 SLD extension, and embed this SLD in the GetMap request that is sent to the server. The Fusion WMS server will return the ECDIS image, rendered with the settings from the SLD.
During startup, the sample will try to connect to a public LuciadFusion OGC WMS service (http://sampleservices.luciad.com/wms). Additionally, you can connect to other LuciadFusion WMS services through the URL panel.
Map interaction: the toolbar offers a set of actions to navigate on and interact with the map. This includes the ability to pan and zoom, to measure distances and to switch the projection. When the selection projection does not match the available projects in the WMS service, the data is automatically reprojected, fully transparent for the user.
S-52 display settings: The S-52 display settings customizer panel right of the map allows to modify the S-52 display settings. Any change to the settings will immediately trigger a new query to the WMS server with updated S-52 SLD styling parameters, and update the client view accordingly.
This sample demonstrates how map data from an OGC Web Map Service (WMS) can be retrieved and visualized in a GXY (2D) view.
Using the client API, applications can create a "proxy" ILcdModel that transparently obtains map data from the WMS.
When a connection is made with a WMS service, the layer list in the upper right of the sample is populated with the list of layers offered by this WMS. These layers can be selected and visualized on the map.
You can switch between a tiled and a non-tiled painting strategy. Tiled painting typically offers better performance while non-tiled painting allows pixel-perfect results in a 2D view.
The sample also demonstrates the use of WMS feature info requests. If the WMS advertises GetFeatureInfo support, you can click on the map. This requests additional feature information for that location from the service. If feature information is available, it will be painted as an overlay label on the map at the clicked location.
The sample demonstrates making use of multi-dimensional data when selecting WMS layers for which the WMS server advertises them.
The check box "Auto-update WMS" is enabled by default, which means that the sample will check at each pan/zoom action whether the capabilities at the server have been updated. Any changes in the available layers are applied automatically; if there are any new layers defined at the server, they will be added. Layers that are not available anymore at the server will be removed automatically.
During startup, the sample will try to connect to one of two default OGC WMS services:
samples.ogc.server.Main
sample.
WMS layer selection: the list in the upper right of the samples shows the available WMS layers. Selecting and deselecting layers triggers a map refresh, taking into account the current WMS layer selection.
Map interaction: the toolbar offers a set of actions to navigate on and interact with the map. This includes the ability to pan and zoom, to measure distances and to switch the projection. When the selection projection does not match the available projects in the WMS service, the data is automatically reprojected, fully transparent for the user.
Painting settings: disable the tiled checkbox in the panel. The update latency will increase but the results are now pixel-perfect when the view is using a 2D reference that is supported by the WMS server.
Feature info: click on the crosshair button in the toolbar to activate the feature info controller. Clicking on the cities or rivers of the USA or on the streets of Washington DC shows a label with the feature information next to the clicked point, if available.
Enable the check box "Auto-update WMS" to let the application check for new/removed WMS layers at each pan or zoom action. When used with the sample Luciad WMS service, one can add data in the samples/resources/Data/dynamic folder to try this feature. The following data formats are supported: SHP, MIF, CADRG, DMED, DEM, GeoTIFF, raster (.rst), ETOPO and a custom format (.txt). This folder is monitored each 10 seconds. When new data is found or when data is removed, the advertised layers in the WMS capabilities are automatically updated, and the client sample will automatically pick up the changes. Newly added data should therefore soon become visible at the client, after a pan or zoom action.
This sample demonstrates how map data from an OGC Web Map Service (WMS) can be retrieved and visualized in a Lightspeed view.
Using the client API, applications can create a "proxy" ILcdModel that transparently obtains map data from the WMS.
When a connection is made with a WMS service, the layer list in the upper right of the sample is populated with the list of layers offered by this WMS. These layers can be selected and visualized on the map.
You can switch between a tiled and a non-tiled painting strategy. Tiled painting typically offers better performance while non-tiled painting allows pixel-perfect results in a 2D view.
The sample also demonstrates the use of WMS feature info requests. If the WMS advertises GetFeatureInfo support, you can click on the map. This requests additional feature information for that location from the service. If feature information is available, it will be painted as an overlay label on the map at the clicked location.
The sample demonstrates making use of multi-dimensional data when selecting WMS layers for which the WMS server advertises them.
During startup, the sample will try to connect to one of two default OGC WMS services:
samples.ogc.server.Main
sample.
WMS layer selection: the list in the upper right of the samples shows the available WMS layers. Selecting and deselecting layers triggers a map refresh, taking into account the current WMS layer selection.
Map interaction: the toolbar offers a set of actions to navigate on and interact with the map. This includes the ability to pan and zoom, to measure distances and to switch the projection. When the selection projection does not match the available projects in the WMS service, the data is automatically reprojected, fully transparent for the user.
Painting settings: disable the tiled checkbox in the panel. The update latency will increase but the results are now pixel-perfect when the view is using a 2D reference that is supported by the WMS server.
Feature info: click on the crosshair button in the toolbar to activate the feature info controller. Clicking on the cities or rivers of the USA or on the streets of Washington DC shows a label with the feature information next to the clicked point, if available.
This sample allows performing convex hull operation and constructive geometry operations on interactively created shapes.
To apply convex hull and constructive geometry operations to a shape you created and edited:
This sample allows performing convex hull operation and constructive geometry operations on interactively created shapes.
To apply convex hull and constructive geometry operations to a shape you created and edited:
This applet demonstrates several topological relations provided by the rigorous geometry package. The relations can be checked between US states and geodetic flight trajectories. It's possible to select an object. All other objects are then color-coded according to their relationship with the selected object. Not all possible relations supported by the package are shown and if multiple relations hold true only one is shown, otherwise too much different colors would be needed.
States and flight trajectories are shown in gray by default. Use the selection tool to select a state or a flight trajectory. All other objects that interact with the selected object in some way are then drawn in another color. The color codes are:
This applet allows creating shapes using toolbar buttons and editing them. Selecting two shapes displays their topology relations.
To analyze the topology relations between two shapes you created and edited:
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to convert any data format that contains valid Panoramic image data into the Luciad Panorama Format. The Luciad Panorama Format is optimized for serving the Panoramic image data with LuciadFusion and visualizing with LuciadRIA. Refer to the Panoramic image section of the documentation for more information.
Run the sample using the shell script in the samples
folder:
panorama.converter.bat -i=<inputFile> -o=<outputFile>
This sample can visualize panorama locations on the map, display the raw images and process them into a Luciad Panorama.
This sample can be used as a debugging tool when implementing a custom panorama format.
The Luciad Panorama is not stored, use the Panorama Converter sample or LuciadFusion to fully process panoramas.
Refer to the Panoramic images section of the documentation.
This is a command-line sample. Click More info for run instructions.
This application demonstrates how to encode spatial data to an DB2 Spatial database, using a TLcdDB2SpatialModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.db2.spatial.bat source_file destination_db2_file
The connection to the database can be specified by means of a properties
file, in this case Data/Db2/states.db2
.
To convert a file, make sure the URL in Data/Db2/states.db2
points to your
DB2 Spatial database and convert for example Data/Shp/Usa/states.shp
into it.
This is a command-line sample. Click More info for run instructions.
This application demonstrates how to encode geodetic data to an Informix Geodetic database, using a TLcdInformixGeodeticModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.informix.geodetic.bat source_file destination_ifx_file
The connection to the database can be specified by means of a properties
file, in this case Data/Informix/states.ifx
.
Make sure the URL in Data/Informix/states.ifx
points to your
Informix Geodetic database. You can then convert Data/Shp/Usa/states.shp
to Data/Informix/states.ifx
This is a command-line sample. Click More info for run instructions.
This application demonstrates how to encode spatial data to an Informix Spatial database, using a TLcdInformixSpatialModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.informix.spatial.bat source_file destination_isd_file
The connection to the database can be specified by means of a properties
file, in this case Data/Informix/states.isd
.
Make sure the URL in Data/Informix/states.isd
points to your
Informix Spatial database. You can then convert
Data/Shp/Usa/states.shp
to Data/Informix/states.isd
This is a command-line sample. Click More info for run instructions.
This application demonstrates how to encode spatial data to a Microsoft SQL database, using a TLcdMSSQLModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.mssql.bat source_file destination_mss_file
The connection to the database can be specified by means of a properties
file, in this case Data/MSSQL/world.mss
.
Make sure the URL in Data/MSSQL/world.mss
points to
your Microsoft SQL database. You can then convert
Data/Shp/world/world.shp
to Data/MSSQL/world.mss
.
This is a command-line sample. Click More info for run instructions.
This application demonstrates how to encode spatial data to an Oracle Spatial Object-Relational database, using a TLcdOracleSpatialModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.oracle.spatial.bat source_file destination_ora_file
The connection to the database can be specified by means of a properties
file, in this case Data/Oracle/states.ora
.
Make sure the URL in Data/Oracle/states.ora
points to your
Oracle Spatial database. You can then convert
Data/Shp/Usa/states.shp
to Data/Oracle/states.ora
.
This is a command-line sample. Click More info for run instructions.
This application demonstrates how to encode spatial data to a PostgreSQL PostGIS database, using a TLcdPostGISModelEncoder.
Run the sample using the shell script in the samples
folder:
encoder.postgresql.bat source_file destination_pgs_file
The connection to the database can be specified by means of a properties
file, in this case Data/Postgresql/states.pgs
.
Make sure the URL in Data/Postgresql/states.pgs
points to
your PostgreSQL PostGIS database. You can then convert
Data/Shp/Usa/states.shp
to Data/Postgresql/states.pgs
.
This sample shows how to integrate network functionality in GDF applications. GDF datasets can be read into the sample. During loading, the sample will convert the GDF data into a road network and preprocess the network. The network toolbar provides all functionality to compute shortest routes and traces on the road network. The info button shows details about all routes/traces which are computed.
First select a GDF file using the 'Open' button in the toolbar. After the data has been loaded, shortest routes can be computed and displayed. To compute a route:
This sample demonstrates how to use the LuciadLightspeed Graph & Routing Engine component. It contains a sample graph, representing a small road network, consisting of a set of nodes (junctions) and edges (roads) connecting the nodes. Some of the roads are directed (indicated by a black arrow), some turns are forbidden (indicated by a red corner). Each road has an associated maximum speed, indicated by its thickness.
The length of a route is defined by an ILcdEdgeValueFunction, which associates a value with each edge in the graph. This value can be based on a simple cartesian distance function, a function combining distance and maximum speed into a time-cost function, or other, user-defined functions.
You can display the complete sequence of edges and the total distance of a route via the 'Show routing information' button.
The sample also illustrates how to associates values with nodes, e.g. to incorporate the time to wait for a traffic light on a junction.
Heuristic distance functions, providing estimate distances between two nodes, can accelerate the routing process. They are not required for the routing algorithm to work, but, if one is used, the calculated distances should always be an underestimate of the real remaining distance, otherwise a correct result is not guaranteed.
The cost function and heuristic distance function to be used can be configured via the 'Network configuration' button.
Besides routing, tracing can also be performed, calculating all nodes that are reachable within a given distance.
Finally, the sample shows how to partition a graph and perform routing in partitioned graphs. A partition is calculated for the sample graph, and is visualized by the colors of the nodes. Partitioning can reduce the processor and memory usage significantly when routing.
Note that the size of this sample graph is too small to show the effect of heuristic distance functions and partitioning on routing performance.
Routes can be calculated by first selecting a start node and an end node, using the start/end node selection controller. Once start node and end node are selected, the route can be computed and visualized by pressing the 'Calculate the shortest route' button. Optionally, a start and/or end edge can also be selected, but they are only relevant when turn restrictions are activated. The start and end edge should always be connected to the start and end node, respectively.
This sample demonstrates how to perform cross country route planning with LuciadLightspeed. The sample shows a map with height data. The "Compute route" controller allows to select two points. After the second point has been selected, a route between the two selected points will be computed and shown.
The right panel allows to experiment with different distance functions, which will result in different solutions.
Heuristic distance functions, providing estimate distances between two nodes, can accelerate the routing process. They are not required for the routing algorithm to work, but, if one is used, the calculated distances should always be an underestimate of the real remaining distance, otherwise a correct result is not guaranteed. The right panel allows to enable or disable a simple distance function.
Note that, since the algorithm uses a raster approximation, the computed solution will be an approximation of the actual shortest route.
To compute a route, first enable the "Compute route" controller by pressing the "Compute route" button. After the controller has been enabled, select a start and end point on the map. After the second point has been selected, a route between the two selected points will be computed and shown.
This sample demonstrates how to analyze very large networks with LuciadLightspeed, using numeric graphs. The sample has an Open button which allows to load a numeric graph that was created with the network preprocessor sample. By default, the sample will load the USA roads dataset included in the release.
After the graph has been loaded, routes can be calculated by first selecting a start and end node via the start/end node selection controller, and then pressing the routing button. Only begin and end points of roads (polylines) can be selected as start/end node. Optionally, a start edge can also be selected to indicate from which direction the beginning of the route will be entered, and an end edge to indicate in which direction the route will be left. The start and end edge should always be connected to the start and end node, respectively. They are only relevant however when the graph contains turn restrictions.
The 'Destroy edge' button allows to mark edges as deleted. The application will take these changes into account during succeeding shortest route computations.
Note the sample has a scale range set on the layers, as the default sample dataset is too large to display at once on the map. Zoom in on the map to make the data visible.
First preprocess a SHP file using the samples.network.numeric.preprocessor sample. The generated Network configuration properties file can be loaded using the 'Open file' button. After the data has been loaded, shortest routes can be computed and displayed. To compute a route:
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to convert SHP data to a numeric graph.
Run the sample using the shell script in the samples
folder:
network.numeric.preprocessor.bat source_directory destination_file
This sample is a command-line sample.
It requires two arguments: one specifying the data source dir and one specifying the
numeric graph destination file.
A sample dataset is provided in resources/Data/Shp/Usa/roads/
.
See the documentation of Preprocessor.java for more information on how the input data should be organized.
The properties file that is created by the preprocessor can be opened with the numeric network viewer sample.
This sample is a configuration editor for a Luciad Web Map Server.
This sample starts the OGC web services sample on localhost port 8080, giving access to an OGC
Web Map Service (WMS), a Web Feature Service (WFS), and a Web Coverage Service (WCS).
LuciadFusion also adds a Web Catalogue Service (CSW) to this sample.
The services can be accessed through a set of client samples delivered with LuciadLightspeed, or through the service's administrative page available at the following URL: http://localhost:8080/LuciadOGCServices This administrative page is built using HTML / JavaScript and is delivered with the services sample. It provides a graphical front-end to the OGC services and gives access to their capabilities.
You can run one of the client samples delivered with LuciadLightspeed to connect with the OGC services:
This sample shows how to interactively declutter clusters of objects using offset icons, the continuous labeling algorithm and an animation labeling algorithm. A discrete labeling algorithm declutters the labels statically. When the mouse hovers over a cluster, the icons are first animated by an animation labeling algorithm, and then decluttered using the continuous labeling algorithm.
This sample demonstrates how to combine offset label placement and continuous label decluttering. It also shows how to customize the labeling algorithm by
This sample shows how to interactively declutter clusters of objects using offset icons, the continuous labeling algorithm and an animation labeling algorithm. A discrete labeling algorithm declutters the labels statically. When the mouse hovers over a cluster, the icons are first animated by an animation labeling algorithm, and then decluttered using the continuous labeling algorithm.
This sample demonstrates how to combine offset label placement and continuous label decluttering. It also shows how to customize the labeling algorithm by
This sample demonstrates how to connect to and visualize a custom radar feed. This sample uses the following classes:
TLcdRadar
: the domain object into which you decode your radar video data
TLspRadarVideoLayerBuilder
: the layer builder for showing the radar video data in a Lightspeed view
Configure the styling of the radar using the controls in the bottom right panel. You can change the following properties of the styling:
Switch to different 2D projections to see how the radar display is warped. Switch to 3D to see how the radar feed is draped on the terrain.
This sample illustrates how to customize the line-of-sight TEA add-on.
The sample adds a custom propagation function to the TEA back-end. It also integrates this custom function in the available UI.
The custom propagation function is added to the back-end in the
LOSCoverageBackEnd
class. This back-end is set on the add-on by overriding the
createLOSCoverageBackEnd
method in theLOSCoverageAddOn
. Since this sample focuses on the Lucy integration and
not on the TEA functionality, the propagation function is a very simple one.
The custom propagation function is made available in the UI as well. The adjustments in the
configuration file of the TEA add-on makes sure the UI allows you to select the custom propagation
function. Further, the
LOSCoverageGUIFactory extends TLcyLOSCoverageGUIFactory
class adds a dummy style panel to the UI for the custom propagation function.
Consult the Lucy developer guide for more information about the customization options of the TEA add-ons. The TEA developer guide contains more information about the TEA functionality.
The sample starts with a workspace containing a point over the Alps. The LOS for the point is calculated using the custom propagation function. The LOS panel shows the custom style panel for the propagation function. Note that clicking the checkbox has no effect.
You can switch in the UI to the normal propagation function. This will show the standard styling options for that propagation function. When you press the 'Update' button, the new line-of-sight calculations are shown in the map. Switching back to the custom propagation function again shows the custom style panel.
This sample demonstrates the terrain distance controller.
The terrain distance controller measures distance between points taking into account the terrain elevation in between. As such this will be an approximation of the distance to travel over land from start to end point.
The distance is influenced by the path taken between the points which can be either geodetic (shortest path on the ellipsoid) or of constant azimuth. Note that distance following a constant azimuth path may be smaller than when following a geodetic path, due to the terrain underneath.
Activate the terrain ruler in the toolbar and click a few times on the DTED data. A path is created and the distance along that path is shown computed. Adjust the measure mode settings to use a different distance calculation. Notice how the distance is bigger if “over terrain” is enabled. The parts of the measurement that are out of terrain bounds are shown as “Unknown”.
This sample demonstrates how to find extreme points inside a shape.
The sample allows you to find minimum and maximum points inside a selected area. A minimum/maximum point is defined to be the lowest or highest point in the surrounding area. This area is defined by a configurable separation distance.
To ensure that the peaks are more or less distinct, a separation height is needed. This height defines the minimum height difference which has to be bridged between two peaks.
Edit the selected polygon, adjust the extreme point settings and click the 'Compute' button. The found minimum (green) and maximum (red) points are added to the map and are shown inside the polygon.
This sample demonstrates how to visualize hypsometric computations on elevation data in a Lightspeed view. The computations can be applied to either the view's terrain or a specific elevation model.
The application generates all hypsometric calculations in advance, and puts them in separate layer. You can view separate the various hypsometric functions by toggling the visibility of their respective layers. The following functions are shown:
The panel in the upper right corner displays information about the hypsometric functions, relative to the position of the mouse.
This sample demonstrates how to produce line-of-sight computations, between two points and between a point and its environment.
The map shows DTED terrain data and points defined in a geodetic reference (black with white border) and in a grid reference (white with black border).
For point-to-point computations:
For line-of-sight coverage computations:
This sample demonstrates how to generate directional viewsheds for terrain and a shape model.
To calculate shadows for the sample terrain and city:
The sample creates a new composite viewshed based on the terrain and the city. It does so by extruding the given polygons to make them 3D. It also places the resulting extruded shapes above terrain. The sun is used as a direction: Conceptually the sun is at infinite height.
To visualize the viewshed it is wrapped in a multilevel raster. Visible (i.e. non-shadowed) portions of the terrain are transparent, while non-visible (i.e. shadowed) portions are gray. The raster creates tiles by sampling the composite viewshed at a height that is a combination of the height of the terrain plus the sampling height offset.
This sample demonstrates how to generate positional viewsheds for terrain and a shape model.
To calculate visibility for the sample terrain and city:
The sample creates a new composite viewshed based on the terrain and the city. It does so by extruding the given polygons to make them 3D. It also places the resulting extruded shapes above terrain. The observer is used as a position. Its height is given by the underlying terrain, plus the eye height offset.
To visualize the viewshed it is wrapped in a multilevel raster. Visible portions of the terrain are transparent, while non-visible portions are gray. The raster creates tiles by sampling the composite viewshed at a height that is a combination of the height of the terrain plus the sampling height offset.
The sample allows you to compute the visibility from a shape to a polyline or a polygon. You can do so by specifying the shapes using the drop-downs.
Edit the shapes and configure the desired visibility computation with the drop-downs. The visibility will be computed and added to the map.
This sample demonstrates the contour functionality of the Terrain Analysis Engine Component.
Select a type of contour. Two different contour types are available:
This sample demonstrates the terrain distance controller.
The terrain distance controller measures distance between points taking into account the terrain elevation in between. As such this will be an approximation of the distance to travel over land from start to end point.
The distance is influenced by the path taken between the points which can be either geodetic (shortest path on the ellipsoid) or of constant azimuth. Note that distance following a constant azimuth path may be smaller than when following a geodetic path, due to the terrain underneath.
Activate the terrain ruler and click a few times on the DTED data. A path is created and the distance along that path is shown computed. Adjust the measure mode settings to use a different distance calculation. Notice how the distance is bigger if “over terrain” is enabled. The parts of the measurement that are out of terrain bounds are shown as “Unknown”.
This sample demonstrates how to find extreme points inside a shape.
The sample allows you to find minimum and maximum points inside a selected area. A minimum/maximum point is defined to be the lowest or highest point in the surrounding area. This area is defined by a configurable separation distance.
To ensure that the peaks are more or less distinct, a separation height is needed. This height defines the minimum height difference which has to be bridged between two peaks.
Edit the selected polygon, adjust the extreme point settings and click the 'Compute' button. The found minimum (green) and maximum (red) points are added to the map and are shown inside the polygon.
Change the DTED level to control the resolution of the height data for the search algorithm.
This sample demonstrates how to visualize hypsometric computations on elevation data in a Lightspeed view. The computations can be applied to either the view's terrain or a specific elevation model.
Explore the various hypsometric functions and their input parameters (if applicable):
Open some additional elevation data (for example Data/Dted/Alps/dmed) and select the layer in the combo box in the "Hypsometry Data" panel. The hypsometric computations are now only applied to the selected layer instead.
This sample demonstrates how to set up Line-of-Sight (LOS) calculations in a Lightspeed view. The sample allows the user to edit an arcband that is used as input for LOS calculation.
The input shape is edited using the default shape editor. The resulting Line-of-Sight shape is visualized as a three-dimensional sheet using a TLspLOSCoveragePainter.
To edit the LOS calculation, first select the LOS input shape by clicking on it.
You can change the shape as follows:
Use the sliders in the parameters panel on the right to modify:
The style panel in the upper right side of the screen controls the following parameters:
All changes are applied immediately.
This sample demonstrates how to generate positional viewsheds for terrain and a shape model.
To calculate visibility for the sample terrain and city:
After some seconds, a viewshed is shown, indicating the hidden areas for the observer. It does not perfectly fit the buildings because of the sampling resolution.
The visibility result (in the form of a viewshed) produces a scalar field. The viewshed is visualized using the marching cubes algorithm. This algorithm extracts a polygonal mesh from a three-dimensional scalar field. The mesh represents the volumes that are invisible to the observer. The algorithm samples the scalar field at certain locations. The UI allows you to specify the resolution of this sampling with the "Viewshed step size"-setting.
The sample allows you to compute the visibility from a shape to a polyline or a polygon. You can do so by specifying the shapes using the drop-downs.
Edit the shapes and configure the desired visibility computation with the drop-downs. The visibility will be computed and added to the map.
This application demonstrates how to decode and visualize NetCDF and GRIB data.
The bottom of the map displays the data values under the mouse location. For every type of data, the value of the topmost visible layer is displayed.
The top of the map displays a time slider for temporal data. If there is no visible layer with time data, the slider is not displayed.
The left of the map displays a drop box menu and a vertical slider to filter multi-dimensional NetCDF and GRIB data. The menu allows you to choose one dimension, for example depth or air pressure. If there is no visible multi-dimensional layer, the slider and the menu are not displayed.
Notice that "Zonal Current" and "u,v-component of wind @ Isobaric surface" layers are interpolated on the dimensions.
The decoder supports equally-spaced rectilinear grids that follow the NetCDF Climate and Forecast conventions and GRIB data. You can open such a file by clicking the Open toolbar button or by dragging a file onto the map. Move the mouse around to see the relevant data values.
This application demonstrates how to decode and visualize NetCDF and GRIB data.
The bottom of the map displays the data values under the mouse location. For every type of data, the value of the topmost visible layer is displayed.
The top of the map displays a time slider for temporal data. If there is no visible layer with time data, the slider is not displayed.
The left of the map displays a drop box menu and a vertical slider to filter multi-dimensional NetCDF or GRIB data. The menu allows you to choose one dimension, for example depth or air pressure. If there is no visible multi-dimensional layer, the slider and the menu are not displayed.
Notice that "Zonal Current" and "u,v-component of wind @ Isobaric surface" layers are interpolated on the dimensions.
The decoder supports equally-spaced rectilinear grids that follow the NetCDF Climate and Forecast conventions and GRIB files. You can open such a file by clicking the Open toolbar button or by dragging a file onto the map. Move the mouse around to see the relevant data values.
This sample demonstrates creation and display of aeronautical data using the LuciadLightspeed Aviation Standards component. The sample sets up a GXY view and adds a few layers with Aeronautical Information System (AIS) data. Models containing AIS objects are created in the ModelFactory class. Layer creation is performed in the LayerFactory class.
The data is generated in a geodetic model reference. This illustrates the use of the AIS shape classes.
This sample demonstrates creation and display of aeronautical data using the LuciadLightspeed Aviation Standards component. The sample sets up a Lightspeed view and adds a few layers with Aeronautical Information System (AIS) data. Models containing AIS objects are created in the ModelFactory class. Layer creation is performed in the LayerFactory class.
The data is generated in a geodetic model reference. This illustrates the use of the AIS shape classes.
This sample demonstrates how to load and display data in the AIXM 3.3, 4.0 and 4.5 format. The loading of the data relies on the use of the TLcdAIXMModelDecoder class in combination with a number of ILcdAIXMHandler implementation that each take care of one or more AIXM feature types (airspaces, routes, ...). The visualization is configured in the LayerFactory class.
Press the open button in the toolbar to choose an AIXM snapshot or update file. You can select any of the loaded features to show a label, or you can double click on a feature to show the properties of the feature that were decoded from the AIXM file.
This applet demonstrates how to create, load, store, and display AIXM data in a GXY view. The sample creates and displays an AIXM 5.1 designated point and airspace and loads some AIXM 5.1 data of the Chicago area. It also converts data from AIXM 4.5/3.3.
If you want to use your own data, press the open button in the toolbar to choose an AIXM file. AIXM 5.1 files will be loaded directly, while airports, heliports and airspaces in AIXM4.5 and AIXM3.3 files will be converted on-the-fly to AIXM5.1 data.
Right click on an AIXM 5.1 feature on the map and choose 'View Properties' to show the data for that feature. The sample class AIXM51ElementFormatter is used by the dialog box to create more readable descriptions of the data. It also shows how to navigate through the domain model.
Select a layer and make it editable to enable editing of the AIXM 5.1 features. If you select a feature
and drag one of the handles, the underlying AIXM 5.1 data will be changed.
Click the save button to save the message in that layer to a file.
This applet demonstrates how to create, load, store, and display AIXM data in a Lightspeed view. The sample creates and displays an AIXM 5.1 designated point and airspace and loads some AIXM 5.1 data of the Chicago area.
If you want to use your own data, press the open button in the toolbar to choose an AIXM file.
Right click on an AIXM 5.1 feature on the map and choose 'View properties' to show the data for that feature. The sample class AIXM51ElementFormatter is used by the dialog box to create more readable descriptions of the data. It also shows how to navigate through the domain model.
Select a layer and make it editable to enable editing of the AIXM 5.1 features. If you select a feature and drag one of the handles, the underlying AIXM 5.1 data will be changed.
The COP sample offers the following functionality:
The COP user guide contains a detailed explanation of what is possible with the COP demo.
To get started:
startCOPServer.bat
script on Windows,
or startCOPServer.sh
on other platforms. You can find these scripts in the
distrib/copservices
folder of the
This sample demonstrates how to plug in a custom tracking camera.
This sample loads a custom extension of the
TLcyLspCameraLinkAddOn
which registers an extra
ALcyCameraLinkerFactory
instance to the Lucy
back-end.
Consult the Lucy developer guide for more information.
When the sample starts, a workspace is loaded with a tracking camera, which tracks a PIM track, already installed. There is also a previewer visible, previewing the tracked PIM track.
The installed custom camera is of the type "Free view" and can be accessed through the tracking pop-up menu which appears when right-clicking the plane. Note that this pop-up menu also contains the default tracking cameras, "Look at" and "Look from". To install the custom tracking camera select it from the tracking pop-up menu.
This sample demonstrates how to display military grid layers in a GXY view.
The following grid layers are included:
This sample demonstrates how to display military grid layers in a Lightspeed view.
The following grid layers are included:
This sample shows how to create, display, and edit military symbols on a map represented by a GXY view. The sample allows switching between APP-6A, APP-6B, APP-6C, APP-6D, MIL-STD-2525b, MIL-STD-2525c, and MIL-STD-2525d. A few military symbols are already shown on the map.
Click on a military symbol on the map to select it. You can drag the shape or its handles to edit the geometry, and change the properties and style in the symbol properties panel on the right.
New symbols can be made by typing in the name in the search box at the right, or by clicking the browse button next to it. Next, click on the map to place the symbol at the desired location. Multiple clicks can be required depending on the type of symbol (line, area, arrow, ...); a right-click ends this step.
This sample shows all military symbols in a GXY view.
The sample displays a layer with a number of symbols. The sample allows switching between APP-6A, APP-6B, APP-6C, APP-6D, MIL-STD-2525b, MIL-STD-2525c, and MIL-STD-2525d. It also allows to switch between icon symbols and tactical graphics.
This sample shows how to create, display, and edit military symbols on a map represented by a Lightspeed view. The sample allows switching between APP-6A, APP-6B, APP-6C, APP-6D, MIL-STD-2525b, MIL-STD-2525c, and MIL-STD-2525d. A few military symbols are already shown on the map.
Additionally this sample shows how to apply a clustering model and styler to an existing model. When zooming out, the sample will cluster identical symbols which not classified as part of the sea dimension.
Click on a military symbol on the map to select it. You can drag the shape or its handles to edit the geometry, and change the properties and style in the symbol properties panel on the right.
New symbols can be made by typing in the name in the search box of the toolbar, or by clicking the browse button next to it. Next, click on the map to place the symbol at the desired location. Multiple clicks can be required depending on the type of symbol (line, area, arrow, ...); a right-click ends this step.
The star-shaped button in the symbol properties panel adds the symbol as a favorite in the toolbar, allowing rapid creation of this symbol.
Zooming out leads to the formation of clusters in order to keep the overview.
This sample shows all military symbols in a Lightspeed view.
The sample displays a layer with a number of symbols. The sample allows switching between
APP-6A, APP-6B, APP-6C, APP-6D, MIL-STD-2525b, MIL-STD-2525c, and MIL-STD-2525d. It also allows to switch between
icon symbols and tactical graphics.
Note that switching to tactical graphics might block the application for a moment, because of
the exceptional amount of complex strokes.
This sample demonstrates how to decode, display, customize and edit NVG data in a GXY View. The sample decodes an NVG file illustrating a fictitious takeover of San Francisco. All military symbols in the file come from the APP-6B standard. For illustration purposes, some points use a domain specific symbol set to show civilian entities. The sample allows switching between APP-6A, APP-6B, APP-6C, APP-6D, MIL-STD-2525b, MIL-STD-2525c and MIL-STD-2525d.
The custom painter provider is a TLcdNVGGXYPainterProvider with a registered painter provider for the domain specific symbols. This painter provider is simply an icon painter.
Click on a symbol on the map to select it. You can drag the shape or its handles to edit the geometry, and change the properties and style in the symbol properties panel on the right.
New symbols can be created by typing in the name in the search box at the top. Alternatively, click the browse button next to the search box, select the desired symbol, and click the select button. Optionally, you can change the supported geometry for the symbol on the left. Next, click on the map to place the symbol at the desired location. Multiple clicks can be required depending on the type of symbol (line, area, arrow, ...); a right-click ends this step.
You can save your changes by clicking the appropriate toolbar button.
This sample demonstrates how to decode, display, customize and edit NVG data in a Lightspeed View. The sample decodes an NVG file illustrating a fictitious takeover of San Francisco. All military symbols in the file come from the APP-6B standard. For illustration purposes, some points use a domain specific symbol set to show civilian entities. The sample allows switching between APP-6A, APP-6B, APP-6C, APP-6D, MIL-STD-2525b, MIL-STD-2525c and MIL-STD-2525d.
The styler used in the sample styles NVG domain objects as defined in NVG by passing a TLspNVGStyle. For domain specific symbols, the styler passes a TLspIconStyle with a custom icon.
Click on a symbol on the map to select it. You can drag the shape or its handles to edit the geometry, and change the properties and style in the symbol properties panel on the right.
New symbols can be created by typing in the name in the search box at the top. Alternatively, click the browse button next to the search box, select the desired symbol, and click the select button. Optionally, you can change the supported geometry for the symbol on the left. Next, click on the map to place the symbol at the desired location. Multiple clicks can be required depending on the type of symbol (line, area, arrow, ...); a right-click ends this step.
You can save your changes by clicking the appropriate toolbar button.
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to decode BIM data (Binz, IFC, Revit, Navisworks) and export them as a 3DTiles dataset.
Run the sample using the shell script in the samples
folder:
bim.converter.bat -i=<inputFile> -o=<outputPath>
The tool has two mandatory parameters: the path to the input BIM file, and the path of the output directory where the 3DTiles dataset will be written.
If you execute it with invalid or insufficient arguments, the tool prints out its usage documentation.
The supported data formats are Binz, IFC, Revit and Navisworks. Please refer to the respective documentation articles for more specific information about these formats.
This is a command-line sample. Click More info for run instructions.
This command-line tool demonstrates how to use the 3D Tiles Processing Engine, which allows automatic tiling and multi-leveling of an OBJ dataset into a 3DTiles dataset. The produced tileset can then be optimally served by LuciadFusion.
Run the sample using the shell script in the samples
folder:
meshup.bat -i=<input (OBJ) File or Folder> -o=<outputPath>
The tool has two mandatory parameters: the path to the the input OBJ file or folder containing OBJ files, and the path of the output directory where the 3DTiles dataset will be written.
If you execute it with invalid or insufficient arguments, the tool prints out its usage documentation.
For more information about MeshUp and its parameters, see the 3D Tiles processing Engine documentation page.
This sample demonstrates how to load and display ECDIS data on a map, and configure S-52 display settings interactively.
While this sample only demonstrates S-52 on a Lightspeed view, you can easily use the same approach on a GXY view.
The sample loads data using the registered ILcdModelDecoder
services, and uses the registered ILspLayerFactory
services.
In practice, this will be:
TLcdS57UnifiedModelDecoder
to load S-57 catalogs and/or cells
TLcdS63UnifiedModelDecoder
to load S-63 encrypted catalogs and/or cells
S52LayerFactory
to create Lightspeed layers with the S-52 symbology (delegates to TLspS52LayerBuilder
)
S52GXYLayerFactory
to create GXY layers with the S-52 symbology (delegates to TLcdS52GXYLayerFactory
)
Both the GXY and Lightspeed layers can be configured with a TLcdS52DisplaySettings
instance to configure the styling.
This sample provides a UI component to interactively change the S-52 display settings.
This sample supports
To load S-63 catalogs or cells, you need:
The sample will automatically load an individual ENC cell and fit on it.
The S-52 display settings button can be used to display the S-52 display settings dialog. It allows to modify each individual S-52 display setting, supported by the S-52 rendering engine.
Objects can be double-clicked to see a list with their attributes.
The LuciadLightspeed distribution contains no multileveled ECDIS data. NOAA, the U.S. National Oceanic & Atmospheric Administration provides a large dataset on its website, which can be found at http://www.nauticalcharts.noaa.gov/mcd/enc/
The LuciadLightspeed distribution contains no AML data. UKHO, the United Kingdom Hydrographic Office, provides a sample AML dataset on its website, which can be found at http://www.ukho.gov.uk/Defence/AML/Pages/Home.aspx
This sample shows the data model of all supported ASDI categories, for tracks, trajectories, flightplans and flight plan histories.
This sample generates a list of data models trees. The data models contain all declared properties of all declared types inside the data model. The sample can generate strings for any given property, which can then be used in conjunction with a TLcdDataObjectExpressionLanguage to generate a value for a data object of the selected data type.
Click on any of the data types on the left. This will generate a tree in the center of the frame. Each tree contains a list of properties. By clicking on a property, you generate a string that is visible in the textarea on the bottom of the frame.
A property itself also has a data type that in turn can have its own list of properties.
This sample shows how to decode an ASDI file and create a realtime presentation of this data on a GXY map.
This sample decodes an ASDI file, which contains information in the form of trajectories and flight plan history objects. For each trajectory, a track is created that represents that trajectory at a certain point in time. This time can be controlled by the Simulator control panel at the bottom of the window. When selecting a track, the trajectory corresponding with the track is also selected and the flight plan associated with the track at the current time is added to the map.
You can view the detailed properties of a track or associated flight plan by selecting a track.
You can open an ASDI file using the "Open" button on the toolbar. Some sample data is available in the LuciadLightspeed distribution.
To view the details of an ASDI track and associated flight plan, click on it and a popup will appear with the details.
You can use the controls at the bottom of the page to control the simulation:
Zoom in to see the labels of the tracks. After that you can move the text-labels by
This sample shows how to create a live stream from an ASDI file.
This sample will process the ASDI file so that the ASDI live decoder can replay the data as if it were live data. The decoder will maintain a list of tracks and update them according to the information it receives from the live InputStream. As stated above, in this sample this live InputStream will be derived from an ASDI file.
When you select a track that has flight plan information associated with it, the associated flight plan is added to the map.
When you select a track, more information about the track and associated flight plan will be shown in a popup.
The sample will open a predefined ASDI file and start replaying that.
To view the details of an ASDI track and associated flight plan, click on the track and a popup will appear with the details.
Zoom in to see the labels of the tracks. After that you can move the text-labels by
This sample shows the data model of all supported ASTERIX categories, for both tracks and trajectories.
This sample generates a list of data models trees. The data models contain all declared properties of all declared types inside the data model. The sample can generate strings for any given property, which can then be used in conjunction with a TLcdDataObjectExpressionLanguage to generate a value for a data object of the selected data type.
Select data types on the top. This will generate a tree in the center of the frame. Each tree contains a list of properties. By clicking on a property, you generate a string that is visible in the textarea on the bottom of the frame.
A property itself also has a data type that in turn can have its own list of properties.
This sample shows how to decode an ASTERIX file and create a realtime presentation of this data.
This sample decodes an asterix file, which contains information in the form of trajectories. For each of these trajectories, a track is created that represents that trajectory at a certain point in time. This time can be controlled by the Simulator control panel at the bottom of the window.
Since ASTERIX data usually is relative with respect to a radar, the positions of the radars must be specified. These positions can be entered in the locations.cfg file. If you have your own ASTERIX data you wish to load, you will need to add the locations of your radars to this file.
Furthermore you can view the detailed properties of a track by double-clicking on it.
Each track is labeled with its track number when zoomed in. The labels avoid overlap in a continuous fashion by moving the labels around gently. In the event labels get mixed up, they can be dragged to a new location, after which they move back automatically.
Press the "Open" button on the toolbar to open an ASTERIX file. Some sample data is available in the LuciadLightspeed distribution. If you have your own ASTERIX data you wish to load, you will need to add the locations of the radars to the locations.cfg file.
Click on an ASTERIX track to view the details on it in a popup.
You can use the controls at the bottom of the page to control the simulation:
Zoom in to see the labels of the tracks. After that you can move the text-labels by
This sample shows how to visualize an ASTERIX cat. 240 radar feed using TLspRadarVideoLayerBuilder. The sample uses a generated ASTERIX 240 data stream, which is sent to the decoder at a specified block rate. The stream is generated based on track data which is loaded from another ASTERIX file. It also contains some simulated noise, which can be filtered out using the styling panel (see instructions below).
Furthermore, the sample demonstrates the use of ALcdASTERIXReferenceProvider to supply the position of the radar platform, which is not included in ASTERIX category 240 data. Finally, it also illustrates the various styling options that are available for radar video layers.
The styling of the radar layers can be configured using the controls in the bottom right panel. You can change the following properties of the styling:
This sample shows how to visualize ASTERIX data on a track display.
The sample shows a track display view, populated with tracks. Each track has a history trail and a label with some information in it. It is possible to hover over or highlight certain tracks by clicking on their icon. Once a track is highlighted, it is displayed using a different icon and it has more content in its label. Among this new content is a comments field which can be modified by clicking on it. Track labels can be moved by dragging them with the middle mouse button.
Track labels have the following content:
In general, the implementation for the labels of this track display aims to keep labels as stable as possible. Zooming and panning should not affect the label locations, pin lines should not move when a track is highlighted, etc... This way, the sample tries to reduce noise as much as possible. This for example explains why labels can be only partially visible at the edge of the map.
This sample shows how to create a live stream from an ASTERIX final file.
This sample will process the ASTERIX final file so that the ASTERIX live decoder can replay the data as if it were live data. The decoder will maintain a list of tracks and update them according to the information it receives from the live InputStream. As stated above, in this sample this live InputStream will be derived from a final ASTERIX file.
Since ASTERIX data usually is relative with respect to a radar, the positions of the radars must be specified. These positions can be entered in the locations.cfg file. If you have your own ASTERIX data you wish to load, you will need to add the locations of your radars to this file.
Each track is labeled with its track number when zoomed in. The labels avoid overlap in a continuous fashion by moving the labels around gently. In the event labels get mixed up, they can be dragged to a new location, after which they move back automatically.
When you double-click on a track, detailed properties will be shown in a popup.
The sample opens a predefined ASTERIX file and starts replaying it.
Double-click on an ASTERIX track to view the details on it in a popup.
Zoom in to see the labels of the tracks. After that you can move the text-labels by
This is a command-line sample. Click More info for run instructions.
This command-line sample demonstrates how to fuse a single coverage from one or more input data sources. It illustrates both basic and advanced usage of the fusion engine. It has extension points that allow subclasses to customize it further. It can be used as a stand-alone command-line fusion tool in scripts. Because of 32-bit VM restrictions, it uses a default maximum heap of 768 MB (-Xmx768m), which may be too limited to fuse large data sets such as the NOAA ENCs. For a 64-bit VM, you may want set this to higher value in the sample's startup script, for example -Xmx1500m.
Run the sample using the shell script in the samples
folder:
fusion.engine.bat -s:<source> -t:<target-tile-store>
For a detailed list of command-line options, run the sample without arguments.
The minimal arguments are the input data source(s) and the target Tile Store URI:
"-s:<source>"
The input data source(s), which may be a single file or a directory.
"-t:<target-tile-store>"
The target Tile Store, which may be a local directory ("file:" URI) or a remote Tile Store ("http:" URI).
For example, "fusion.engine.sh -s:/my/input/data/sources -t:http://my.server:8081/LuciadFusion/lts"
will create a coverage using all the input data found in /my/input/data/sources
.
The coverage and assets will have a generated UUID as ID, and no name.
Typically, you want to specify some options for assets and coverage. Options for assets start with
"-a:"
, options for the coverage start with "-c:"
.
For example,
"fusion.engine.sh -s[0]:/my/input/data/background.tif" -s[1]:/my/input/data/california.jp2
-a[0]:id:background.tif -a[1]:id:california.jp2 -c:id:california
will create a coverage "california" from two input data sources. The indexes determine the order: "california.jp2"
will be on top of "background.tif".
When you use this sample in a script, for example to regularly re-fuse a specific coverage, you may want to consider
the "-overwrite"
option.
Without it, fusion would resume from checkpoint if a previous fusion was unfinished, or do nothing if a previous
fusion was finished.
This is a command-line sample. Click More info for run instructions.
This command-line sample demonstrates how to plug in a custom raster format into the fusion engine.
It illustrates how support for ArcInfo ASCII Grid can be added by extending the
fusion.engine
sample.
Run the sample using the shell script in the samples
folder:
fusion.engine.format.bat -s:<source> -t:<target-tile-store>
For a detailed list of command-line options, run the sample without arguments.
See also the fusion.engine
sample for detailed instructions.
The minimal arguments are the input data source(s) and the target Tile Store URI:
"-s:<source>"
The input data source(s), which may be a single file or a directory.
"-t:<target-tile-store>"
The target Tile Store, which may be a local directory ("file:" URI) or a remote Tile Store ("http:" URI).
For example, "fusion.engine.sh -s:/my/input/data/sources.asc -t:http://my.server:8081/LuciadFusion/lts"
will create a coverage using all the input data found in /my/input/data/sources
.
The coverage and assets will have a generated UUID as ID, and no name.
This is a command-line sample. Click More info for run instructions.
This command-line sample demonstrates how to pre-process one or more input files into a single point cloud. It illustrates both basic usage of the pre-processor. It can be used as a stand-alone command-line tool in scripts. Because of 32-bit VM restrictions, it uses a default maximum heap of 768 MB (-Xmx768m), which may be too limited to process large data sets. For a 64-bit VM, you may want set this to higher value in the sample's startup script, for example -Xmx2g.
Run the sample using the shell script in the samples
folder:
fusion.pointcloud.bat --input=<source> --output=<target-directory>
For a detailed list of command-line options, run the sample without arguments.
The minimal arguments are the input data source(s) and the target path:
"--input=<source>"
The input source, which may be a single file or a directory.
"--output=<target>"
The target directory, which will be created if necessary.
For example, "fusion.pointcloud.sh --input=/my/input/data/sources --target=/my/output/pointcloud"
will create a point cloud store using all the input data found in /my/input/data/sources
.
The output of this process can be imported into LuciadFusion Studio by adding the entire output directory as a "Data Root". Once the data root is crawled, you should be able to see a new data entry that represents the preprocesed dataset in your "Data" tab. To serve it, create a new Service using this dataset, and set the service type to "OGC 3D Tiles".
The preprocessed output can also be opened directly in a Lightspeed-based client such as Lucy. To do this, open the "tileset.json" found in the root of the output directory.
When you use this sample in a script, for example to regularly re-fuse a specific coverage, you may want to consider removing the target directory first. Without this, the preprocessor would add data from the input sources to the existing point cloud, or do nothing if all of the input sources were already to the point cloud previously.