Cesium 是一個廣泛使用的 JavaScript 庫,它支持高級地理空間數據的可視化和操作。其中,Cesium 3D JSON 是一種用于描述三維幾何體和材質外觀的格式。
利用 CesiumJS,我們可以輕松地加載并渲染從 3D 建模工具中導出的模型,比如 Blender 或者 SketchUp。這些模型的輸出可以被保存為 Cesium 3D Json 文件,采用以下的結構:
{ "materials": { "roof material": { "type": "MetallicRoughness", "baseColorFactor": [1.0, 1.0, 1.0, 1.0], "metallicFactor": 0.1, "roughnessFactor": 0.8 } }, "geometries": [{ "attributes": { "POSITION": { "values": […] }, "NORMAL": { "values": […] } } }], "model": { "materials": { "roof material": { "definition": "materials['roof material']" } }, "geometries": [{ "attributes": { "POSITION": "geometries[0].attributes['POSITION']", "NORMAL": "geometries[0].attributes['NORMAL']" }, "mode": 4, "indices": { "values": […] } }] } }
在這個 JSON 文件中,我們看到最外層的三個對象:materials 、geometries 和 model。其中 materials 是材質存儲對象,用于表示 3D 對象的表面材質外觀; geometries 則是幾何體存儲對象,表示 3D 對象的形狀和外觀;model 是 3D 模型對象,其結構中包含 geometries 和 materials 的定義。
隨著WebGL 技術的飛速發展和網頁渲染能力的提高,CesiumJS 帶著強大的三維可視化能力,越來越受到開發者的重視和廣泛應用。
下一篇vue 更多加載