Display a World Map - MATLAB & Simulink (original) (raw)

This example shows how to access imagery from the United States Geological Survey (USGS) National Map SOAP server. To create the map, you need the following information.

This example shows you how to call functions in the USGS web service,USGSImageryOnly_MapServer, to get this information.

Install the Java® JDK™ and Apache® CXF programs and set the tool paths to run this example.

p = matlab.wsdl.setWSDLToolPath; if (isempty(p.JDK) || isempty(p.CXF)) disp('Install the Java Development Kit (JDK) and Apache CXF programs.') disp('See the Set Up WSDL Tools link at the end of this example.') else disp('Paths set to:') matlab.wsdl.setWSDLToolPath end

Change your current folder to a writable folder.

Assign the WSDL URL.

wsdlFile = ... 'http://basemap.nationalmap.gov/arcgis/services/USGSImageryOnly/MapServer?wsdl';

Create the class files for the client.

matlab.wsdl.createWSDLClient(wsdlFile)

Created USGSImageryOnly_MapServer. .\USGSImageryOnly_MapServer.m .+wsdl

In order to use USGSImageryOnly_MapServer, you must run javaaddpath('.+wsdl\mapserver.jar').

ans =

@USGSImageryOnly_MapServer

Add the jar files to the Java path.

javaaddpath('.+wsdl\mapserver.jar')

Start the service.

wsdl = USGSImageryOnly_MapServer;

Explore the service.

help USGSImageryOnly_MapServer

USGSImageryOnly_MapServer A client to connect to the USGSImageryOnly_MapServer service SERVICE = USGSImageryOnly_MapServer connects to http://basemap.nationalmap.gov/arcgis/services/USGSImageryOnly/MapServer and returns a SERVICE.

 To communicate with the service, call a function on the SERVICE:

    [...] = FUNCTION(SERVICE,arg,...) 

 See doc USGSImageryOnly_MapServer for a list of functions.

Click the link doc USGSImageryOnly_MapServer. MATLAB® opens a reference page forUSGSImageryOnly_MapServer in your system web browser.

Read the documentation for the required inputs to theGetMapTile function.

--- help for USGSImageryOnly_MapServer/GetMapTile ---

GetMapTile
Result = GetMapTile(obj,MapName,Level,Row,Column,Format)
Inputs: obj - USGSImageryOnly_MapServer object MapName - string Level - numeric scalar (XML int) Row - numeric scalar (XML int) Column - numeric scalar (XML int) Format - string Output: Result - vector of numbers 0-255 (XML base64Binary)

See also USGSImageryOnly_MapServer.

You need MapName, Level,Row, Column, andFormat input arguments.

Read the documentation for a function that provides a map name,GetDefaultMapName.

--- help for USGSImageryOnly_MapServer/GetDefaultMapName ---

GetDefaultMapName
Result = GetDefaultMapName(obj)
Inputs: obj - USGSImageryOnly_MapServer object Output: Result - string

See also USGSImageryOnly_MapServer.

This function provides a map name.

Read the documentation for a function that provides a map format information,GetTileImageInfo.

--- help for USGSImageryOnly_MapServer/GetTileImageInfo ---

GetTileImageInfo
Result = GetTileImageInfo(obj,MapName)
Inputs: obj - USGSImageryOnly_MapServer object MapName - string Output: Result - TileImageInfo object

See also USGSImageryOnly_MapServer.

This function returns a TileImageInfo object.

Read the documentation for the TileImageInfo object by clicking the link in the help display toTileImageInfo.

TileImageInfo(CacheTileFormat,CompressionQuality,Antialiasing) TileImageInfo object for use with USGSImageryOnly_MapServer web client

  CacheTileFormat - string
      The cache tile format.
  CompressionQuality - numeric scalar (XML int)
      The cache tile image compression quality.
  Antialiasing - string

See also USGSImageryOnly_MapServer.

MATLAB opens a document in the system web browser. The format information is CacheTileFormat.

Create the JPEG data. The following code requires knowledge of the JPEG image format and the tiling scheme used by the USGS server.

% Get the default map name. defaultMapName = GetDefaultMapName(wsdl);

% Get the map count. count = GetMapCount(wsdl);

% Get the map name. There is only one map (count value), % but the index is zero-based. mapName = GetMapName(wsdl, count-1);

% Get information about the tiles. tileImageInfo = GetTileImageInfo(wsdl, mapName);

% Get the format of the data. format = tileImageInfo.CacheTileFormat;

% Since format is specified as 'Mixed' it implies that % the result of GetMapTile is a JPEG-encoded stream. % The map tiles are organized with the lowest level as % the lowest level of detail and the tiles use % zero-based indexing. level = 0; row = 0; col = 0; jpeg = GetMapTile(wsdl,mapName,level,row,col,format);

Write the JPEG-encoded data to a file. Use imread to read and decode the JPEG data and return an M-by-N-by-3 uint8 matrix.

ext = '.jpg'; tilename = ['USGSImageryOnly_MapServer' '0_0_0' ext]; fid = fopen(tilename,'w'); fwrite(fid,jpeg) fclose(fid)

View the map.

tileImage = imread(tilename); figure imshow(tileImage)

See Also

Topics