主頁 > 企業開發 > 3dTiles 資料規范詳解[4.1] b3dm瓦片二進制資料檔案結構

3dTiles 資料規范詳解[4.1] b3dm瓦片二進制資料檔案結構

2020-09-10 04:07:01 企業開發

原創,轉載請規范注明出處:https://www.cnblogs.com/onsummer/p/13252896.html
我的git地址:github.com/onsummer

B3dm,Batched 3D Model,成批量的三維模型的意思,

傾斜攝影資料(例如osgb)、BIM資料(如rvt)、傳統三維模型(如obj、dae、3dMax制作的模型等),均可創建此類瓦片,

瓦片檔案二進制布局(檔案結構)

① 檔案頭:占28位元組(byte)

位于b3dm檔案最開頭的28個位元組,是7個屬性資料:

屬性的官方名稱 位元組長 型別 含義
magic 4 string(或char[4]) 該瓦片檔案的型別,在b3dm中是 "b3dm"
version 4 uint32 該瓦片的版本,目前限定是 1.
byteLength 4 uint32 該瓦片檔案的檔案大小,單位:byte
featureTableJSONByteLength 4 uint32 要素表的JSON文本(二進制形式)長度
featureTableBinaryByteLength 4 uint32 要素表的二進制資料長度
batchTableJSONByteLength 4 uint32 批量表的JSON文本(二進制形式)長度
batchTableBinaryByteLength 4 uint32 批量表的二進制資料長度

其中,

byteLength = 28 + featureTableJSONByteLength + featureTableBinaryByteLength + batchTableJSONByteLength + batchTableBinaryByteLength + glb的位元組長度

② 要素表

回顧上篇,我說的是

要素表,記錄的是整個瓦片渲染相關的資料,而不是渲染所需的資料,

那么,b3dm瓦片中的要素表會記錄哪些資料呢?

全域屬性

什么是全域屬性?即對于瓦片每一個三維模型(或BATCH、要素)或者直接對當前瓦片有效的資料,在b3dm中,要素表有以下全域屬性:

屬性名 屬性資料型別 屬性描述 是否必須存在
BATCH_LENGTH uint32 當前瓦片檔案內三維模型(BATCH、要素)的個數 yes
RTC_CENTER float32[3] 如果模型的坐標是相對坐標,那么相對坐標的中心即此 no

注意,如果glb模型并不需要屬性資料,即要素表和批量表有可能是空表,那么 BATCH_LENGTH 的值應設為 0 .

*要素屬性

對于每個模型(BATCH、要素)各自獨立的資料,在b3dm中沒有,

我們回憶一下要素表的定義:與渲染相關的資料,

b3dm瓦片與渲染相關的資料都在glb中了,所以b3dm并不需要存盤每個模型各自獨立的資料,即不存在要素屬性,

在i3dm、pnts兩種瓦片中,要素屬性會非常多,

全域屬性存在哪里?

全域屬性存盤在 要素表的JSON中,見下文:

JSON頭部資料

由上圖可知,檔案頭28位元組資料之后是要素表,要素表前部是 長達 featureTableJSONByteLength 位元組的二進制JSON文本,利用各種語言內置的API可以將這段二進制資料轉換為字串,然后決議為JSON物件,

例如,這里決議了一個b3dm檔案的 要素表JSON:

{
    "BATCH_LENGTH": 4
}

那么,此b3dm瓦片就有4個模型(4個要素,或4個BATCH),其 batchId 是0、1、2、3.

要素表的二進制本體資料

無,

注:

當要素表的 JSON 資料以參考二進制體的方式出現時,資料才會記錄在要素表的二進制本體資料中,此時JSON記錄的是位元組偏移量等資訊,

但是在b3dm瓦片中,要素表只需要JSON就可以了,不需要自找麻煩再參考二進制資料,因為BATCH_LENGTHRTC_CENTER 都相對好記錄,一個是數值,一個是3元素的陣列,

在下面的要介紹批量表中,就會出現 JSON 資料參考二進制體的情況了,在 i3dm 和 pnts 瓦片中,要素表 JSON就會大量參考其二進制體,

③ 批量表

批量表記錄的是每個模型的屬性資料,以及擴展資料(擴展資料以后再談),

要素表和批量表唯一的聯系就是 BATCH_LENGTH,在 i3dm 中叫 INSTANCE_LENGTH,在 pnts 中叫 POINTS_LENGTH

這很好理解,要素表記錄了有多少個模型(BATCH、要素),那么批量表每個屬性就有多少個值,

JSON頭部資料

先上一份批量表的JSON看看:

{
    "height" : {
        "byteOffset" : 0,
        "componentType" : "FLOAT",
        "type" : "SCALAR"
    },   
    "geographic" : {
        "byteOffset" : 40,
        "componentType" : "DOUBLE",
        "type" : "VEC3"
    },
}

這個批量表的JSON有兩個屬性:heightgeographic,字面義即模型的高度值、地理坐標值,

height 屬性通過其 componentType 指定資料的值型別為 FLOAT,通過其 type 指定資料的元素型別為 SCALAR(即標量),

geographic 屬性通過其 componentType 指定資料的的值型別是 DOUBLE,通過其 type 指定資料的元素型別為 VEC3(即3個double數字構成的三維向量),

byteOffset ,即這個屬性值在 二進制本體資料 中從哪個位元組開始存盤,

從上表可以看出,height 屬性跨越 0 ~ 39 位元組,一共40個位元組,

通過 FeatureTableJSON 可以獲取 BATCH_LENGTH 為10,那么就有10個模型,對應的,這 40 個位元組就存盤了10個 height 值,查相關資料得知,FLOAT型別的資料位元組長度為 4,剛好 4 byte × 10 = 40 byte,即 height 屬性的全部資料的總長,

geographic 屬性也同理,VEC3 代表一個 geographic 有3個 DOUBLE 型別的數字,一個 DOUBLE 數值占 8byte,那么 geographic 一共資料總長是:

type × componentType × BATCH_LENGTH = 3 × 8byte × 10 = 240 byte.

事實上,兩個屬性的總長是 40 + 240 = 280 byte,與 b3dm 檔案頭中的第七個屬性 batchTableBinaryByteLength = 280 是一致的,

二進制本體資料

二進制本體資料即批量表中每個屬性的順次存盤,

能不能不寫二進制本體資料?

可以,如果你覺得資料量比較小,可以直接把資料寫在 BatchTableJSON 中,還是以上述兩個資料為例:

{
    "height": [10.0, 20.0, 15.0, ...], // 太長了不寫那么多,一共10個
    "geographic": [
        [113.42, 23.10, 102.1],
        [111.08, 22.98, 24.94],
    	// 太長不寫
    ]
}

但是,讀者請一定注意這一點:同樣是一個數字,二進制的JSON文本大多數時候體積會比二進制資料大,因為JSON文本還包括括號、逗號、冒號等JSON文本必須的符號,對于屬性資料相當大的情況,建議使用 JSON參考二進制本體資料的組織形式,此時JSON充當的角色是元資料,

注意:對于屬性的值型別是 JSON 中的 object、string、bool 型別,則必須存于 JSON 中,因為二進制體只能存 標量、234維向量四種型別的數字資料,

④ 內嵌的glb

本部分略,對glb資料感興趣的讀者可自行查閱 glTF 資料規范,

關于兩大資料表如何與glb每一個頂點進行關聯的,在前篇也有簡略介紹,可以參考官方的說明:

https://github.com/CesiumGS/3d-tiles/tree/master/specification/TileFormats/Batched3DModel#binary-gltf

⑤ 位元組對齊與編碼端序

JSON二進制文本對齊

FeatureTableJSON、BatchTableJSON的二進制文本,最后一個位元組相對于整個b3dm檔案來說,偏移量必須是8的倍數,

如果不對齊,必須用二進制空格(即 0x20)填夠,

你問我為啥不對起始偏移量也要求 8byte 對齊?因為 FeatureTableJSON 之前是28byte的 檔案頭,為了湊齊8倍數對齊,檔案頭和 FeatureTableJSON 還要塞4個位元組填滿,那就有點多余了,

末尾對齊,即 (28 + ftJSON長)能整除8,(28 + ftTable長 + btJSON長)能整除8.

資料體的起始、末尾對齊

二進制資料體,無論是要素表、批量表,首個位元組相對于b3dm檔案的位元組偏移量,必須是8的倍數,結束位元組的位元組偏移量,也必須是8的倍數,

如果不滿足,可以填充任意資料位元組滿足此要求,

特別的,二進制資料體中,每一個屬性值的第一個數值的第一個位元組的偏移量,相對于整個b3dm檔案,必須是其 componentType 的倍數,如果不滿足,則必須用空白位元組填滿,

例如,上述 height 屬性所在的批量表二進制資料體,理所當然位于批量表JSON之后,而批量表的JSON又是8byte對齊的,假設批量表的資料體起始位元組是800,那么 height 的第一個值起始位元組就是 800,由于 height 屬性的 componentType 是 FLOAT,即 4位元組,800 ÷ 4 能整除,所以沒有問題,

但是,假如 換一個屬性,其 componentType 是 BYTE,即 1位元組,那么假設第二個屬性的 componentType 是 DOUBLE,即 8位元組,就會出現 第二個屬性的第一個值起始偏移量是810,810 ÷ 8 并不能整除,必須補齊 6個空白位元組,以滿足第二個屬性第一個值的起始偏移量是 810+6 = 816位元組,

編碼端序

要素表、批量表的二進制資料,無論是JSON還是資料體,均使用小端序編碼(LittleEndian),

⑥ 擴展資料(extensions)與額外補充資訊(extras)

其實,無論是要素表,還是批量表,都允許在JSON中存在擴展資料,以擴充當前瓦片模型的功能,而并不是單一的一個一個模型順次存盤在瓦片檔案、glb中,

有關擴展資料,在以后會專門出一篇博客介紹,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/784.html

標籤:GIS

上一篇:關于Append和ObjectLoader性能對比

下一篇:3dTiles 資料規范詳解[4.2] i3dm瓦片二進制資料檔案結構

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more