Skip to content

deton/CzmlFirstPersonPlayer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 

Repository files navigation

CzmlFirstPersonPlayer

  • CZMLファイルを一人称視点で再生します。(CesiumJSを利用)
  • 道案内用途など、主に歩行者からの視点での表示を目的にしています。

道にそって移動するCZMLファイルの作成方法

ブラウザだけで作成可能:

  • OpenStreetMapデータから道路ネットワークデータを作成して (Appendix B)
  • その道路ネットワークデータを使って、地図上で指定した出発地と目的地間の経路を見つけて、道路上を移動するCZMLを作成 (Appendix A)

Example

PLATEAUの3Dタイル

CZML.First.Person.Player.mp4

(PLATEAUのテクスチャ付きの建築物の3Dタイルは、 建築物モデル(千代田区)を 手元にダウンロードした上で、http://localhost:8000から取得する形で表示しています。)

テクスチャ無しの建築物モデルでの表示例: https://deton.github.io/CzmlFirstPersonPlayer/?czmlurl=https://deton.github.io/CzmlFirstPersonPlayer/sample.czml

Google Photorealistic 3D Tiles

google3dtile.png

https://deton.github.io/CzmlFirstPersonPlayer/?tileset=google3dtile&czmlurl=https://deton.github.io/CzmlFirstPersonPlayer/sample.czml

zenrin3dtile

(ZENRIN City Asset SeriesのJapanese Otaku CityのFBXを3D Tilesに変換して使用。Appendix C)

URL Parameters

  • czmlurl: 読み込むCZMLファイルのURL。
  • viewrect: 初期表示領域(west,south,east,north)
    • (default): 139.7688,35.6970,139.7761,35.703
  • tileset: 3D tileset URL
  • tilesetHeightOffset: tilesetの高さ調整用のオフセット値[m]。
    • (default): 0
  • height: terrainからの視点の高さ[m]。CZML内のmodel.heightReferenceがCLAMPで始まる場合、terrainに対してこの固定値を足した値を視点の高さとして使います。
    • (default): 2
    • (備考): (JavaScript ConsoleでHEIGHT_OFFSETを変更することで調整可能)
  • minimap: minimap zoom level. 負の値の場合はminimapを非表示
    • (default): 17
  • imageryIdx: 地表面画像のindex。後からBaseLayerPicker(画面右上端から2個目のアイコン)で変更可能。
  • terrainIdx: 地表面地形のindex。後からBaseLayerPicker(画面右上端から2個目のアイコン)で変更可能。
    • -1: PLATEAU配信サービスのPLATEAU-Terrain
    • -2: 産総研 地質調査総合センターの標高タイルサービス
    • (ただし、token指定時はPLATEAU-Terrainを追加しないので、-1が標高タイルサービスになります。)
    • (default): -1
  • token: Cesium ion access token

URL Parameter Example

建物の3Dタイル

  • PLATEAU配信サービス
    • (表示に時間がかかったり、テクスチャが表示されなかったりする場合は、3D都市モデル(Project PLATEAU)ポータルサイトから3D Tilesのzipをダウンロード・展開して、localhostのhttp serverから取得する形にすると良いかもしれません。)
    • (PLATEAU VIEWで見ると、歩道橋などは橋梁モデル(LOD2)に含まれている場合があるようです。)

CZML内で表示に影響する要素

  • 位置は、czml[1].positionのcartographicDegreesのみ対応(cartesian等には未対応)。
  • czml[1].model.heightReference
    • CLAMPで始まる場合: terrainに対して、上記HEIGHT_OFFSET固定値を足した値を視点の高さとして使う。
    • RELATIVEで始まる場合: terrainに対してCZML内の高さを足した値を視点の高さとして使う。
    • NONEまたは指定無しの場合: CZML内の高さを絶対値として使う。(ellipsoidからの高さ)

備考

  • 再生開始後はドラッグ等によるCamera操作が効かなくなります。
    • 再生を中止して、Camera操作を有効にするには、JavaScript ConsoleでstopPlayAndEnableCameraControl();

Appendix A: 道路上を移動するCZMLを作成

Appendix B: 道路ネットワークデータをOpenStreetMapデータから作成

Appendix C: ZENRIN City Asset SeriesのJapanese Otaku CityのFBXを3D Tilesに変換して使用

  • FBXをFBX2glTFでglbに変換。(Textures/等のファイル群をfbxファイルと同じ場所に集めて実行)
  • Cesium ionにUploadして緯度経度高さとscaleを決定。
  • ローカルでtileset.jsonを作る場合は、 3d-tiles-toolsで、 npx 3d-tiles-tools createTilesetJson -i PQ_Remake_AKIHABARA.glb -o tileset.json --cartographicPositionDegrees 139.77024 35.69602 38
    • 表示させてみると小さいのでscaleを100にするため、(3d-tiles-toolsのソースを参考に)以下で調べたtransform値で、tileset.jsonのroot.transformを更新。
    var transform = bldg3dtiles.get(0).root.transform;
    var scale = 100;
    var modelMatrix = Cesium.Matrix4.multiplyByUniformScale(transform, scale, new Cesium.Matrix4());
    console.log(Cesium.Matrix4.toArray(modelMatrix));
    • creditは後から追加。 viewer.creditDisplay.addStaticCredit(new Cesium.Credit('3D city model by ©ZENRIN', true));

About

Plays CZML files in first person view using CesiumJS

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published