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

Primitive

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

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

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

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

new Primitive(options)
Parameters:
options (Object)
Name Description
options.geometryInstances
(Array.<GeometryInstance> | GeometryInstance)
要渲染的幾何體實例-或單個幾何體實例。
options.appearance
Appearance
用于呈現原語的外觀。
options.depthFailAppearance
Appearance
用于在深度測試失敗時對該基元進行著色的外觀。
options.show
Boolean
default true
確定是否顯示此基元。
options.modelMatrix
Matrix4
default Matrix4.IDENTITY
將基本體(所有幾何體實例)從模型轉換為世界坐標的4x4轉換矩陣。
options.vertexCacheOptimize
Boolean
default false
true時,幾何體頂點將針對頂點前和頂點后明暗器緩存進行優化。
options.interleave
Boolean
default false
true時,幾何頂點屬性交錯,這可以稍微提高渲染性能,但增加加載時間。
options.compressVertices
Boolean
default true
true時,幾何體頂點被壓縮,這將節省內存。
options.releaseGeometryInstances
Boolean
default true
true時,原語不保留對輸入geometryInstances的引用以保存內存。
options.allowPicking
Boolean
default true
true時,每個幾何體實例只能使用Scene#pick進行選擇。當false時,保存GPU內存。
options.cull
Boolean
default true
true時,渲染器的平截體剔除和地平線根據其邊界體積剔除基本體的命令。如果要手動剔除原語,請將其設置為false以獲得較小的性能增益。
options.asynchronous
Boolean
default true
確定在準備就緒之前是異步創建基元還是阻止創建基元。
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工作者上創建和批處理幾何體實例。
Default Value: true

(readonly) compressVertices : Boolean

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

cull : Boolean

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

debugShowBoundingVolume : Boolean

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

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

Default Value: false

depthFailAppearance : Appearance

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

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

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

Default Value: undefined

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

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

在呈現基元后更改此屬性沒有效果。

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

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

(readonly) readyPromise : Promise.<Primitive>

獲取解決基元何時準備呈現的承諾。

(readonly) releaseGeometryInstances : Boolean

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

shadows : ShadowMode

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

show : Boolean

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

(readonly) vertexCacheOptimize : Boolean

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

Methods

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

一旦對象被破壞,就不應使用它;調用除isDestroyed以外的任何函數都將導致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以外的任何函數都將導致DeveloperError異常。

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

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

Throws
  • DeveloperError : 所有實例幾何必須具有相同的PrimitiveType。
  • DeveloperError : 外觀和材料有一個統一的名稱。
  • DeveloperError : Primitive.ModelMatrix僅在3D模式下受支持。
  • RuntimeError : 需要頂點紋理獲取支持來渲染具有每個實例屬性的基本體。頂點紋理圖像單位的最大數目必須大于零。
主站蜘蛛池模板: 久久久网 | 日韩城人网站 | 中文字幕日韩一区 | 四季av中文字幕 | 日韩影片在线观看 | 久久99国产视频 | 91久久婷婷 | a级黄色毛片免费播放视频 a级黄色毛片三个搞一 | 天天操天天弄 | 天天色天天看 | 日本一区二区高清 | 成人黄色在线网站 | 日日噜噜噜噜夜夜爽亚洲精品 | 高清一区二区三区 | 一级做性色α爱片久久毛片色 | www.久久久久久久久 | 久草在线免费电影 | 国产91视 | 免费成人短视频 | 黄色a级片免费看 | 亚洲精品资源 | 免费看黄网站在线观看 | 在线观看中文字幕视频 | 久久久成人999亚洲区美女 | 久热在线| 日本欧美www视频网站 | 成人毛片区| 成人午夜视频在线播放 | sis52.com| 综合久久婷婷 | 日本三级一区 | 亚洲国产综合在线播放av66 | 91精品久久久久久久久不卡 | 久久综合成人精品亚洲另类欧美 | 亚洲最大综合网 | 国产91在线看 | 在线免费观看成年人视频 | 日韩综合在线视频 | 麻豆电影免费观看 | 中文字幕在线观看不卡 | 中国一级片视频 |