国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久

Primitive

基本體表示Scene中的幾何體。幾何圖形可以來自下面的示例1所示的單個GeometryInstance,也可以來自實例數(shù)組,即使幾何圖形來自不同的幾何圖形類型,如代碼示例2中所示的RectangleGeometryEllipsoidGeometry

基本體將幾何體實例與描述完整著色的Appearance結合起來,包括MaterialRenderState。大致上,幾何體實例定義結構和位置,外觀定義視覺特征。分離幾何體和外觀允許我們混合和匹配大多數(shù)幾何體和外觀,并獨立地添加新的幾何體或外觀。

將多個實例組合成一個原語稱為批處理,顯著提高了靜態(tài)數(shù)據(jù)的性能。實例可以單獨選取;Scene#pick返回其GeometryInstance#id。使用類似于PerInstanceColorAppearance的每個實例外觀,每個實例也可以具有唯一的顏色。

Geometry可以在Web工作者或主線程上創(chuàng)建和批處理。前兩個示例顯示將使用幾何圖形的描述在Web工作者上創(chuàng)建的幾何圖形。第三個示例演示如何通過顯式調用createGeometry方法在主線程上創(chuàng)建幾何體。

new Primitive(options)
Parameters:
options (Object)
Name Description
options.geometryInstances
(Array.<GeometryInstance> | GeometryInstance)
要渲染的幾何體實例-或單個幾何體實例。
options.appearance
Appearance
用于呈現(xiàn)原語的外觀。
options.depthFailAppearance
Appearance
用于在深度測試失敗時對該基元進行著色的外觀。
options.show
Boolean
default true
確定是否顯示此基元。
options.modelMatrix
Matrix4
default Matrix4.IDENTITY
將基本體(所有幾何體實例)從模型轉換為世界坐標的4x4轉換矩陣。
options.vertexCacheOptimize
Boolean
default false
true時,幾何體頂點將針對頂點前和頂點后明暗器緩存進行優(yōu)化。
options.interleave
Boolean
default false
true時,幾何頂點屬性交錯,這可以稍微提高渲染性能,但增加加載時間。
options.compressVertices
Boolean
default true
true時,幾何體頂點被壓縮,這將節(jié)省內存。
options.releaseGeometryInstances
Boolean
default true
true時,原語不保留對輸入geometryInstances的引用以保存內存。
options.allowPicking
Boolean
default true
true時,每個幾何體實例只能使用Scene#pick進行選擇。當false時,保存GPU內存。
options.cull
Boolean
default true
true時,渲染器的平截體剔除和地平線根據(jù)其邊界體積剔除基本體的命令。如果要手動剔除原語,請將其設置為false以獲得較小的性能增益。
options.asynchronous
Boolean
default true
確定在準備就緒之前是異步創(chuàng)建基元還是阻止創(chuàng)建基元。
options.debugShowBoundingVolume
Boolean
default false
僅用于調試。確定是否顯示此基元的命令的邊界球。
options.shadows
ShadowMode
default ShadowMode.DISABLED
確定此基元是投射還是接收來自每個光源的陰影。
Examples
// 1. Draw a translucent ellipse on the surface with a checkerboard pattern
var instance = new bmgl.GeometryInstance({
  geometry : new bmgl.EllipseGeometry({
      center : bmgl.Cartesian3.fromDegrees(-100.0, 20.0),
      semiMinorAxis : 500000.0,
      semiMajorAxis : 1000000.0,
      rotation : bmgl.Math.PI_OVER_FOUR,
      vertexFormat : bmgl.VertexFormat.POSITION_AND_ST
  }),
  id : 'object returned when this instance is picked and to get/set per-instance attributes'
});
scene.primitives.add(new bmgl.Primitive({
  geometryInstances : instance,
  appearance : new bmgl.EllipsoidSurfaceAppearance({
    material : bmgl.Material.fromType('Checkerboard')
  })
}));
// 2. Draw different instances each with a unique color
var rectangleInstance = new bmgl.GeometryInstance({
  geometry : new bmgl.RectangleGeometry({
    rectangle : bmgl.Rectangle.fromDegrees(-140.0, 30.0, -100.0, 40.0),
    vertexFormat : bmgl.PerInstanceColorAppearance.VERTEX_FORMAT
  }),
  id : 'rectangle',
  attributes : {
    color : new bmgl.ColorGeometryInstanceAttribute(0.0, 1.0, 1.0, 0.5)
  }
});
var ellipsoidInstance = new bmgl.GeometryInstance({
  geometry : new bmgl.EllipsoidGeometry({
    radii : new bmgl.Cartesian3(500000.0, 500000.0, 1000000.0),
    vertexFormat : bmgl.VertexFormat.POSITION_AND_NORMAL
  }),
  modelMatrix : bmgl.Matrix4.multiplyByTranslation(bmgl.Transforms.eastNorthUpToFixedFrame(
    bmgl.Cartesian3.fromDegrees(-95.59777, 40.03883)), new bmgl.Cartesian3(0.0, 0.0, 500000.0), new bmgl.Matrix4()),
  id : 'ellipsoid',
  attributes : {
    color : bmgl.ColorGeometryInstanceAttribute.fromColor(bmgl.Color.AQUA)
  }
});
scene.primitives.add(new bmgl.Primitive({
  geometryInstances : [rectangleInstance, ellipsoidInstance],
  appearance : new bmgl.PerInstanceColorAppearance()
}));
// 3. Create the geometry on the main thread.
scene.primitives.add(new bmgl.Primitive({
  geometryInstances : new bmgl.GeometryInstance({
      geometry : bmgl.EllipsoidGeometry.createGeometry(new bmgl.EllipsoidGeometry({
        radii : new bmgl.Cartesian3(500000.0, 500000.0, 1000000.0),
        vertexFormat : bmgl.VertexFormat.POSITION_AND_NORMAL
      })),
      modelMatrix : bmgl.Matrix4.multiplyByTranslation(bmgl.Transforms.eastNorthUpToFixedFrame(
        bmgl.Cartesian3.fromDegrees(-95.59777, 40.03883)), new bmgl.Cartesian3(0.0, 0.0, 500000.0), new bmgl.Matrix4()),
      id : 'ellipsoid',
      attributes : {
        color : bmgl.ColorGeometryInstanceAttribute.fromColor(bmgl.Color.AQUA)
      }
  }),
  appearance : new bmgl.PerInstanceColorAppearance()
}));
See:

Members

(readonly) allowPicking : Boolean

true時,每個幾何體實例只能使用Scene#pick進行選擇。當false時,保存GPU內存。*
Default Value: true

appearance : Appearance

Appearance用于對該原語進行著色。每個幾何體實例都以相同的外觀著色。一些外觀,如PerInstanceColorAppearance允許為每個實例提供唯一的屬性。
Default Value: undefined

(readonly) asynchronous : Boolean

確定是否將在Web工作者上創(chuàng)建和批處理幾何體實例。
Default Value: true

(readonly) compressVertices : Boolean

true時,幾何體頂點被壓縮,這將節(jié)省內存。
Default Value: true

cull : Boolean

true時,渲染器的平截體剔除和地平線根據(jù)其邊界體積剔除基本體的命令。如果要手動剔除原語,請將其設置為false以獲得較小的性能增益。
Default Value: true

debugShowBoundingVolume : Boolean

此屬性僅用于調試;它既不用于生產,也不進行優(yōu)化。

為基本體中的每個draw命令繪制邊界球體。

Default Value: false

depthFailAppearance : Appearance

Appearance用于在深度測試失敗時對該原語進行著色。每個幾何體實例都以相同的外觀著色。一些外觀,如PerInstanceColorAppearance允許為每個實例提供唯一的屬性。

當使用需要顏色屬性的外觀時,如PerInstanceColorAppearance,請為每個實例屬性添加DepthFailColor。

需要ext}frag_depth webgl擴展以正確呈現(xiàn)。如果不支持擴展,則可能存在工件。

Default Value: undefined

(readonly) geometryInstances : (Array.<GeometryInstance>|GeometryInstance)

使用此基元渲染的幾何體實例。在構造基元時,如果options.releaseGeometryInstancestrue,則可能是undefined

在呈現(xiàn)基元后更改此屬性沒有效果。

Default Value: undefined

(readonly) interleave : Boolean

確定幾何體頂點屬性是否交錯,這可以稍微提高渲染性能。
Default Value: false

modelMatrix : Matrix4

將基本體(所有幾何體實例)從模型轉換為世界坐標的4x4轉換矩陣。當這是一個單位矩陣時,原語以世界坐標繪制,即地球的wgs84坐標。本地參考幀可以通過提供不同的轉換矩陣來使用,如Transforms.eastNorthUpToFixedFrame返回的轉換矩陣。

此屬性僅在3D模式下受支持。

Default Value: Matrix4.IDENTITY
Example:
var origin = bmgl.Cartesian3.fromDegrees(-95.0, 40.0, 200000.0);
p.modelMatrix = bmgl.Transforms.eastNorthUpToFixedFrame(origin);

(readonly) ready : Boolean

確定基元是否已完成并準備好呈現(xiàn)。如果此屬性為真,則下次調用Primitive#update時將呈現(xiàn)原語。

(readonly) readyPromise : Promise.<Primitive>

獲取解決基元何時準備呈現(xiàn)的承諾。

(readonly) releaseGeometryInstances : Boolean

true時,原語不保留對輸入geometryInstances的引用以保存內存。
Default Value: true

shadows : ShadowMode

確定此基元是投射還是接收來自每個光源的陰影。
Default Value: ShadowMode.DISABLED

show : Boolean

確定是否顯示基元。這會影響基本體中的所有幾何體實例。
Default Value: true

(readonly) vertexCacheOptimize : Boolean

true時,幾何體頂點將針對頂點前和頂點后明暗器緩存進行優(yōu)化。
Default Value: true

Methods

destroy()
銷毀此對象持有的WebGL資源。銷毀對象允許確定地釋放WebGL資源,而不是依賴垃圾收集器來銷毀此對象。

一旦對象被破壞,就不應使用它;調用除isDestroyed以外的任何函數(shù)都將導致DeveloperError異常。因此,將返回值(undefined)賦給對象,如示例中所述。

Example
e = e && e.destroy();
Throws
See:
getGeometryInstanceAttributes(id) → {Object}
返回GeometryInstance的每個實例可修改屬性。
Parameters:
id (*) GeometryInstance的ID。
Example
var attributes = primitive.getGeometryInstanceAttributes('an id');
attributes.color = bmgl.ColorGeometryInstanceAttribute.toValue(bmgl.Color.AQUA);
attributes.show = bmgl.ShowGeometryInstanceAttribute.toValue(true);
attributes.distanceDisplayCondition = bmgl.DistanceDisplayConditionGeometryInstanceAttribute.toValue(100.0, 10000.0);
attributes.offset = bmgl.OffsetGeometryInstanceAttribute.toValue(Cartesian3.IDENTITY);
Throws
  • DeveloperError : 必須在調用GetGeometryInstanceAttributes之前調用Update。
isDestroyed() → {Boolean}
如果此對象被破壞,則返回true;否則返回false。

如果此對象被破壞,則不應使用它;調用除isDestroyed以外的任何函數(shù)都將導致DeveloperError異常。

See:
update()
ViewerBMWidget渲染場景以獲取渲染此原語所需的繪制命令時調用。

不要直接調用此函數(shù)。這只是為了列出渲染場景時可能傳播的異常:

Throws
  • DeveloperError : 所有實例幾何必須具有相同的PrimitiveType。
  • DeveloperError : 外觀和材料有一個統(tǒng)一的名稱。
  • DeveloperError : Primitive.ModelMatrix僅在3D模式下受支持。
  • RuntimeError : 需要頂點紋理獲取支持來渲染具有每個實例屬性的基本體。頂點紋理圖像單位的最大數(shù)目必須大于零。
国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久
<code id="kseui"><acronym id="kseui"></acronym></code>
  • <abbr id="kseui"><tbody id="kseui"></tbody></abbr>
  • <button id="kseui"></button>
  • 国产综合欧美| av免费观看久久| 欧美日韩综合精品| 久久99伊人| 亚洲网站视频| 综合网五月天| 亚洲二区自拍| 欧美日韩一区在线观看视频| 久久综合九色综合久99| 国产精品老牛| 国产亚洲亚洲| 亚洲区欧美区| 亚洲国产精品123| 欧美体内she精视频在线观看| 亚洲欧洲国产日韩精品| 亚洲欧洲一区二区在线观看| 国产欧美亚洲日本| av成人午夜| 91高跟黑色丝袜呻吟在线观看| 日韩视频在线观看国产| 正在播放精油久久| 一区二区三区欧美在线| 日韩国产欧美精品| 亚欧精品在线| 欧美黄色免费| 欧美日韩mv| 在线国产日韩| 久久黄色影院| 成人免费视频网站| 精品日本一区二区三区在线观看| 你懂的成人av| 欧美日韩视频| 欧美日韩在线大尺度| 欧美日一区二区三区在线观看国产免| 91视频免费进入| 成人在线看片| 欧洲精品久久| 欧美日韩亚洲一区三区| 99精品视频免费观看视频| 亚洲综合精品四区| 成人xxxxx色| 久久精品五月婷婷| 一本一本a久久| 在线亚洲美日韩| 国产另类自拍| 一道精品一区二区三区| av成人黄色| 国产三级精品在线不卡| 亚洲精品一区二区三| 亚洲婷婷在线| 国产精品国产一区二区| 亚洲va韩国va欧美va精四季| 国产精品分类| 成人在线免费观看一区| 视频在线一区二区三区| 亚洲乱亚洲高清| 韩国一区二区三区美女美女秀 | 欧美日韩亚洲一区二区三区在线观看| 亚洲一区二区三区高清不卡| 欧美一级专区| 日韩欧美精品久久| 激情亚洲网站| 极品日韩久久| 亚洲国产精品123| 久久国产精品 国产精品| 国产一区激情| 国产精品大全| 欧美激情精品久久久六区热门| 日本高清久久一区二区三区| 激情欧美国产欧美| 久久99精品久久久久久三级| 国产一区二区三区自拍| 国产麻豆一区二区三区在线观看| 麻豆91精品| 日韩欧美在线一区二区| 国产精品一级| 亚洲一区二区三区午夜| 91成人理论电影| 一本久道久久综合婷婷鲸鱼| 国产精品久久久久久久小唯西川| 97在线电影| 国产精品mv在线观看| 国产精品一区二| 亚洲一级二级| 青娱乐一区二区| 91九色在线观看| 欧美日韩综合另类| 日韩aⅴ视频一区二区三区| 久久蜜桃资源一区二区老牛| 午夜久久美女| 欧美一区二区三区在线免费观看| 日本不卡一二三区| 99在线观看| 国产精品久久777777毛茸茸| 中文字幕一区二区三区乱码| 精品欧美一区二区精品久久| 日韩一级精品| 欧美777四色影| 日韩中文一区二区三区| 国产伦精品一区二区三区视频免费| 欧美裸体网站| 国产精选一区二区| 97人人模人人爽人人喊38tv| 国产乱码精品一区二区三区不卡| 久久久久一区二区| 国产日韩欧美一区在线| 午夜亚洲福利| 欧美久久一级| 欧美精品日本| 中文字幕中文字幕一区三区| 日本一区免费| 日本三级中国三级99人妇网站| 国产精品a久久久久| 亚洲国产日韩综合一区| 视频一区二区综合| 免费在线观看91| 精品日韩欧美| 欧美日韩国产精品一卡| 久久成人资源| 日韩精品久久一区二区三区| 国产精品10p综合二区| 噜噜噜久久亚洲精品国产品小说| 久草热久草热线频97精品| 国产传媒一区二区三区| 成人免费视频网站| 成人动漫在线观看视频| av成人综合网| 欧美极品一区| 一区二区三区四区视频在线观看| 蜜桃av综合| 久久精品人人| 色综合电影网| 亚洲一区二区三区精品动漫| 亚洲图片欧洲图片日韩av| 午夜精品偷拍| 国产一区二区三区免费不卡| 免费亚洲一区| 久久riav| 亚洲天堂电影网| 亚洲精品国产精品国自产观看| 九色视频成人porny| 日韩精品无码一区二区三区| 在线不卡视频一区二区| 亚洲精品乱码| 国产亚洲自拍偷拍| 亚洲欧美日韩精品久久久 | 日本在线视频不卡| 中文字幕一区二区三区四区五区| 97超碰最新| 日本不卡免费新一二三区| 欧美日本久久| 欧美资源在线| 色一情一乱一伦一区二区三区 | 成人午夜电影在线播放| 国产专区一区二区| 一区一区视频| 久久狠狠一本精品综合网| 美女亚洲精品| 亚洲第一毛片| 久久久久久精| 91久久视频| 久久久久久国产精品免费免费| 国产精品国产精品国产专区不卡| 国产欧美大片| 九色91国产| 一区二区三区精品视频在线观看| 中文字幕精品一区日韩| 国产欧美日韩视频一区二区三区| 欧美在线免费| 91九色在线观看| 欧美日韩国产综合视频在线| 国产美女诱惑一区二区| 日韩偷拍一区二区| 男人的天堂亚洲| 中文字幕色一区二区| 老**午夜毛片一区二区三区| 你懂的亚洲视频| 精品在线视频一区二区三区| 亚洲黄色在线| 亚洲国产精品一区二区第一页| 先锋影音欧美| 岛国一区二区三区高清视频| 午夜精品一区二区三区四区| 久久综合九色综合网站| 欧美视频导航| 夜夜精品视频| 日韩黄色影视| 国产成人亚洲欧美| 国产情侣一区| 国内精品视频在线播放| 欧美日韩中文国产一区发布 | 亚洲视频大全| 国产精品videosex极品| 久久av一区二区三区漫画| 久久久福利视频| 在线精品亚洲一区二区| 在线观看成人av| 日韩精品一区二区三区外面 | 欧美91大片| 日韩欧美电影一区二区|