wiki:OSGeo4W_jp/MapServermapfile

MapServer

新しいマップサーバーのインストールのテストを行う

MapServer cgi スクリプトはコマンドから実行できます。Apacheウェブサーバーがサービスを行うに当たって適切にインストールされているかどうか確かめる必要があります。

《started》の状態に設定されている Apache OSGEO4W Web Server という名前のサービスがあることを確認するためのサービスマネージャーへ行ってください。下のコマンドで容易に利用できます。80ポートが開いているかどうか確認してください。

#netstat -na |findstr LISTEN

Windows7 pro をご利用の場合、既定の 80 listen ポートではなく、IIS が既に使っている8080を利用するために、C: \OSGeo4W\apache\conf\httpd.conf メイン Apache 設定ファイルから Listen の修正をする必要があります。

前文の設定を行えば、次のような既定のインデックスページをロードすることができます。

最初のMapServer マップファイルを作成する

マップファイルは、地図をマップファイル上で確定し、地図中に表示されるべきレイヤー、各レイヤーを表示する方法、レイヤーの順、写真として地図に表示するために使われるアウトプットフォーマットの確定などが書き込まれているファイルです。

どのマップファイルも XML ファイル( xml マップファイルは最近の MapServer バージョンによってサポートされていますが、ここでは、《 old / standard 》シンタックスに注目しています)として容易に表示できます。それぞれの XML ファイルにはオープニングタグとクロージングタグがあります。必要であれば、個別に閉じることができます。

どのレイヤーも持たない基本的なマップファイルは # から始まり、次のようになります。

MAP
# the name of your map
NAME 	≪ my vietnam demo map ≫
# the default size of your map
SIZE 	1024 	768
# the bounding box to display
EXTENT 	102.148611 8.633287 109.453599 23.377778
# the path where your vector data files are located
SHAPEPATH ≪ C: \OSGeo4W\Data\Shapes\ ≫
# the default output format (from a list which should follow)
IMAGETYPE png
END

これでマップファイルに IMAGETYPE 属性を設定しました。これは OUTPUTFORMAT ブロックの MAP ブロックに含まれている名前です(同じマップファイルに含まれています)。

マップファイルの書き込みを容易に理解するため、 INCLUDE ディレクティブを使用します。それでファイルの集合中の複雑なマップファイルを分割します。

C: \OSGeo4W\maps\outputs.map という名前のファイルを作成し、そこに以下を挿入してください。これで、どのように作成された画像が表示されるのかを定義します。

OUTPUTFORMAT
NAME 		"png" 	# the name referenced in the MAP block
MIMETYPE 	"image/png" # the mimeType of created file
DRIVER 	"AGG/PNG" # the driver used to generate the image (default is GD/PNG)
EXTENSION 	"png" 	# the filename will be ended by .png
IMAGEMODE 	"RGBA" 	# render in 32bit Red/Green/Blue/Alpha
TRANSPARENT 	TRUE
END
OUTPUTFORMAT
NAME 		"gtif"
MIMETYPE 	"image/gtif"
DRIVER 		"GDAL/GTIFF"
EXTENSION 	"gtif"
IMAGEMODE 	"PC256"
TRANSPARENT 	TRUE
END

次のコンテンツに従って、 C: \OSGeo4W\maps\mapfile.map ファイルを作成してください。

MAP
NAME "my demo vietnam map"
EXTENT 102.148611 8.633287 109.453599 23.377778
SYMBOLSET "C: \OSGeo4W\maps\symbols.sym"
FONTSET "C: \OSGeo4W\maps\fonts.txt"
SHAPEPATH "C: \OSGeo4W\Data\Shapes\"
SIZE 1024 768
IMAGETYPE png
INCLUDE "outputs.map"
# default projection of the map
PROJECTION
  "init=epsg: 4326"
END
# WEB block
WEB
  IMAGEPATH "C: \OSGeo4W\apache\htdoc s\Temp" # directory where produced imgs go
  IMAGEURL "/TEMP" # relative path to download image from the web server
  METADATA
    "ows_title" "My Demo Vie tnam Map" #
  END
 END
 INCLUDE "layers.map"
END

レイヤーブロックを作成する

layers.map ファイルを作成しなければなりません。それは次のコンテンツを含んでいなければなりません。

LAYER
  NAME "Administrative"
  DATA "vietnam_administrative "
  TYPE LINE # data type , you can use the ogrinfo command previously presented
  METADATA
    "ows_title" "Administrative Boundaries" # title of WMS / WFS
  END
  CLASS
    NAME "Vietnam Administrative Boundaries"
    STYLE
      #OUTLINECOLOR R G B color around the geometry
      COLOR 255 200 100 # color inside the geometry
      WIDTH 2
    END
  END
END

これで同じフォーマットの他のレイヤーに簡単に追加できます。シェープファイルは C: \OSGeo4W\Data\Shapes\ ディレクトリに含まれました。公式のマップファイル参照文書からレイヤーシンタックス、サポート、スタイル等について」、より多くの情報を得ることができます。

WMS サーバーとして MapServer を使用する

一度 layers.map ファイルを作成すれば、画像としてのマップを表示するためのブラウザーで見える前に mapserver.exe スクリプトを使用できます。WMS プロトコルの使用が可能なレイヤーについての情報を入手できます。

  • 注意:ここではMapServerを使用しません。しかし、C: \OSGeo4W\maps\symbols.symC:\OSGeo4W\maps\fonts.txt の2つの空ファイルを作成しなければならないことに注意してください。ここでは2つのファイルは使用しないので、これに関する情報は提供しません。しかし、この2つのファイルは、レイヤーのスタイルを定義するのに使われるシンボルの定義と、表示例などのフォントの定義に使用されることに注意してください。
  • 表示された画質:既定のGD/PNGドライバーおよびAGG/PNGドライバーの使用の違いをチェックするため、マップファイルからINCLUDE 'outputs.map'パートへのコメントも歓迎します。下の画像からインストールの違いを比較することができます。

WFS サーバーとしてMapServerを使用する

WFSサーバーとしてMapServerを使用している全データソースコンテンツの入手方法について示します。MapServer に WFS 機能を追加するために、マップファイルにいくつかの METADATA ブロック属性を設定しなければなりません。

ウェブブロック内に以下を追加してください。

 METADATA
 "wfs_encoding" "UTF-8"
 "ows_title" 	"My Vietnam Demo Map"
"wfs_onlineresource " "http: //localhost/cgi-bin/mapserv.exe?map=C:/OSGeo4W/maps/mapfile.map"
  END

サンプル《 Administrative 》LAYER ブロックのための DUMP 属性および METADATA ブロックは次のようになります。

DUMP TRUE
 METADATA
 "gml_featureid" "id"
 "wfs_title" "Administrative Boundaries"
"gml_include_items" "NAME,ADMIN_LEVEL"
END

WMS プロトコルについて前に述べたように、WFS プロトコルを使用している MapServer と相互利用できます。

Last modified 14 years ago Last modified on Mar 29, 2010, 8:05:34 PM
Note: See TracWiki for help on using the wiki.