Oracle Map builder simple map
Today I'm going to show how to create a very simple map based on the OSM data loaded into a Oracle Database. I use Germany OSM data for this guide.
The root post if this series is: Maps starting post. It has links to other posts of this series.
The first step is to download a Map Builder tool for building a map. It's available on the "Software Downloads for Oracle Fusion Middleware MapViewer" page.
data:image/s3,"s3://crabby-images/8070a/8070a021a17cda66001510fdd9668914ad29988d" alt="Oracle map builder download".png)
data:image/s3,"s3://crabby-images/8070a/8070a021a17cda66001510fdd9668914ad29988d" alt="Oracle map builder download".png)
After downloading and unpacking the archive, I got three jar-files.
data:image/s3,"s3://crabby-images/6ef62/6ef62df151be545c5cc36b0636c6aed1fc09c830" alt="mapbuilder.jar".png)
data:image/s3,"s3://crabby-images/6ef62/6ef62df151be545c5cc36b0636c6aed1fc09c830" alt="mapbuilder.jar".png)
The only tool I use in this post is mapbuilder.jar. You need java installed to run it. It's possible to run it either by double-clicking or using a command line, depending on your machine setup.
data:image/s3,"s3://crabby-images/9e00e/9e00e1f889701ae403ca12b24d6d4d2c54845680" alt="run mapbuilder".png)
data:image/s3,"s3://crabby-images/e839b/e839bf0391923eb17f34a791a2056d43ef23f45a" alt="".png)
data:image/s3,"s3://crabby-images/9e00e/9e00e1f889701ae403ca12b24d6d4d2c54845680" alt="run mapbuilder".png)
data:image/s3,"s3://crabby-images/e839b/e839bf0391923eb17f34a791a2056d43ef23f45a" alt="".png)
Map builder needs a connection to a database which stores map data. I don't think that creation of a connection needs any comments.
data:image/s3,"s3://crabby-images/a6af2/a6af2b014fdc1d8b87feedc9106cee49279304af" alt="".png)
data:image/s3,"s3://crabby-images/9626d/9626d1bc78c3c11dc7cab8d4da5b0f45ffe95ba3" alt="".png)
data:image/s3,"s3://crabby-images/5a6f6/5a6f68fac985f52234d7d3ae808f78112734b48d" alt="".png)
data:image/s3,"s3://crabby-images/a6af2/a6af2b014fdc1d8b87feedc9106cee49279304af" alt="".png)
data:image/s3,"s3://crabby-images/9626d/9626d1bc78c3c11dc7cab8d4da5b0f45ffe95ba3" alt="".png)
data:image/s3,"s3://crabby-images/5a6f6/5a6f68fac985f52234d7d3ae808f78112734b48d" alt="".png)
In the real life, I'd start with defining some styles for lines, and polygons, and markers. But it would make this post too big. So I use predefined styles, although they aren't nice.
I'll create a layer with German cities. Right-click on the
data:image/s3,"s3://crabby-images/3bfbe/3bfbe692299648a6b9f70f22c270a9a75d2a12b4" alt="oracle map builder create geometry theme".png)
Geometry Themes
node and create a new theme.data:image/s3,"s3://crabby-images/3bfbe/3bfbe692299648a6b9f70f22c270a9a75d2a12b4" alt="oracle map builder create geometry theme".png)
The name of my theme is "Cities" and it use the
data:image/s3,"s3://crabby-images/63222/632222ab2475f0e9a986ffef67c449e4f9c32e2b" alt="".png)
POINTS
table.data:image/s3,"s3://crabby-images/63222/632222ab2475f0e9a986ffef67c449e4f9c32e2b" alt="".png)
Now I need to define the appearance of the theme.
data:image/s3,"s3://crabby-images/8c857/8c8573d1851ac30745951129b3ff48f43d42d69d" alt="".png)
data:image/s3,"s3://crabby-images/8c857/8c8573d1851ac30745951129b3ff48f43d42d69d" alt="".png)
As this is a theme for points, I choose the "Marker" style. data:image/s3,"s3://crabby-images/92c5b/92c5bccc67f40243ffb58932138f8acccb783ac5" alt="".png)
data:image/s3,"s3://crabby-images/92c5b/92c5bccc67f40243ffb58932138f8acccb783ac5" alt="".png)
All predefined styles are stored in the
data:image/s3,"s3://crabby-images/5b935/5b935100cb3133fdd7ca24397d1e7c979cec3489" alt="MDSYS".png)
MDSYS
schema.data:image/s3,"s3://crabby-images/5b935/5b935100cb3133fdd7ca24397d1e7c979cec3489" alt="MDSYS".png)
There are only a few markers predefined, but I need only one for this time.
data:image/s3,"s3://crabby-images/619cf/619cf0595b54e18edc4dda915d9122c4956aca5f" alt="".png)
data:image/s3,"s3://crabby-images/5282f/5282fc19dc859ae0e83125931183cf1e76628467" alt="".png)
M.TOWN_HALL
for example.data:image/s3,"s3://crabby-images/619cf/619cf0595b54e18edc4dda915d9122c4956aca5f" alt="".png)
data:image/s3,"s3://crabby-images/5282f/5282fc19dc859ae0e83125931183cf1e76628467" alt="".png)
I want all the cities to be labelled with names so I choose labels style and attribute for labels.
data:image/s3,"s3://crabby-images/52457/52457969186dd9b07e2990831ec5734efd3ffa74" alt="".png)
data:image/s3,"s3://crabby-images/52457/52457969186dd9b07e2990831ec5734efd3ffa74" alt="".png)
And the last thing to do. The
data:image/s3,"s3://crabby-images/902cc/902ccb285f3b85de103b9fe0cb1a8ea67b31d5d1" alt="".png)
POINTS
table stores all points of all types. Not only cities, but other settlement types, and POIs and other stuff. So I create a filter to select only data on cities.data:image/s3,"s3://crabby-images/902cc/902ccb285f3b85de103b9fe0cb1a8ea67b31d5d1" alt="".png)
Not every option is defined by the wizard. There are a lot of other options to define, but it's OK for the first pass.
data:image/s3,"s3://crabby-images/e0c50/e0c50cc2231ecf58e6f994f3a1d054e67f834f96" alt="".png)
data:image/s3,"s3://crabby-images/e0c50/e0c50cc2231ecf58e6f994f3a1d054e67f834f96" alt="".png)
To see how the layer looks like, open the "Preview" tab and click green play button.
data:image/s3,"s3://crabby-images/dbed8/dbed86be5782f561a6157571cb9835a103c5451c" alt="".png)
data:image/s3,"s3://crabby-images/f3332/f3332a74b50e9dde706591d626d18c864ff34742" alt="".png)
data:image/s3,"s3://crabby-images/dbed8/dbed86be5782f561a6157571cb9835a103c5451c" alt="".png)
data:image/s3,"s3://crabby-images/f3332/f3332a74b50e9dde706591d626d18c864ff34742" alt="".png)
It's possible to get an error at this step. When I try to zoom in I get ORA-13226: interface not supported without a spatial index message.
data:image/s3,"s3://crabby-images/3a753/3a753b70f4d72b94da5ec7cb75225ff4a7667052" alt="".png)
![]()
data:image/s3,"s3://crabby-images/3a753/3a753b70f4d72b94da5ec7cb75225ff4a7667052" alt="".png)
The cause of this error is the absence of a spatial index. A spatial index should be created for every table. Actually, it's a good idea to create a few non-spatial indexes too. For example, it's much easier to find cities if the
data:image/s3,"s3://crabby-images/2eac9/2eac98ea16f594eb2c477d04c5b9686e0eaf1257" alt="create spatial index".png)
place
field is indexed.data:image/s3,"s3://crabby-images/2eac9/2eac98ea16f594eb2c477d04c5b9686e0eaf1257" alt="create spatial index".png)
I created two more geometry themes. One for a country border. It's based on the
data:image/s3,"s3://crabby-images/852b6/852b64ec5673b5267d297d648f6edace06262424" alt="".png)
data:image/s3,"s3://crabby-images/a0d66/a0d6641e7e4cc200787ddae16aa540ab82b52dd2" alt="".png)
MULTYPOLYGONS
table and styled with line.data:image/s3,"s3://crabby-images/852b6/852b64ec5673b5267d297d648f6edace06262424" alt="".png)
data:image/s3,"s3://crabby-images/a0d66/a0d6641e7e4cc200787ddae16aa540ab82b52dd2" alt="".png)
Different types of administative regions can be selected with the
data:image/s3,"s3://crabby-images/be213/be213d8b03eda850b8ad07a2b8b0973f76193e0b" alt="".png)
ADMIN_LEVEL
field. Country border has ADMIN_LEVEL='2'
.data:image/s3,"s3://crabby-images/be213/be213d8b03eda850b8ad07a2b8b0973f76193e0b" alt="".png)
And one more theme is
FEDERAL_LAND
. It's also built on the MULTYPOLYGON
table, but its ADMIN_LEVEL='4'
.
Now I have everything to create a very simple map of Germany. Right-click on the "Base map" node, select
data:image/s3,"s3://crabby-images/a3ba8/a3ba85ab16c2da123edac3e116d82653f45cea75" alt="".png)
create
.data:image/s3,"s3://crabby-images/a3ba8/a3ba85ab16c2da123edac3e116d82653f45cea75" alt="".png)
Give a name to the map.
data:image/s3,"s3://crabby-images/6bc67/6bc679276cf3cc887c0c3b56ee6aefde1a63482e" alt="".png)
data:image/s3,"s3://crabby-images/6bc67/6bc679276cf3cc887c0c3b56ee6aefde1a63482e" alt="".png)
Add all themes to the map.
data:image/s3,"s3://crabby-images/6f842/6f842fecec1b5874516b7a64a89089a17cff3a37" alt="".png)
data:image/s3,"s3://crabby-images/6e41c/6e41c5c1bcbc5b5164f7ef4ac42196d878eb86d4" alt="".png)
data:image/s3,"s3://crabby-images/4989b/4989bb7183a76e26da6f8792c1fa2ffc3209e9f8" alt="".png)
data:image/s3,"s3://crabby-images/6f842/6f842fecec1b5874516b7a64a89089a17cff3a37" alt="".png)
data:image/s3,"s3://crabby-images/6e41c/6e41c5c1bcbc5b5164f7ef4ac42196d878eb86d4" alt="".png)
data:image/s3,"s3://crabby-images/4989b/4989bb7183a76e26da6f8792c1fa2ffc3209e9f8" alt="".png)
There are parameters that should be tweaked in the real life, but I leave defaults for this time.
data:image/s3,"s3://crabby-images/29dde/29dde7f037927daa2a11cb07ecf005a0fad47f77" alt="".png)
data:image/s3,"s3://crabby-images/29dde/29dde7f037927daa2a11cb07ecf005a0fad47f77" alt="".png)
And here it is - a simple map of Germany. It's very simple and needs a lot of work to become nice. But even now it is sufficient to visualize some data for cities and federal lands.
data:image/s3,"s3://crabby-images/ccc2d/ccc2d71ed081c27d7add2b32f0460381741c7424" alt="".png)
data:image/s3,"s3://crabby-images/ccc2d/ccc2d71ed081c27d7add2b32f0460381741c7424" alt="".png)
I'll show how to setup Oracle Mapviewer 12c to work with this map in the next post.
ليست هناك تعليقات:
إرسال تعليق