Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Vector Tiles #4665

Merged
merged 425 commits into from
Jan 8, 2018
Merged
Show file tree
Hide file tree
Changes from 250 commits
Commits
Show all changes
425 commits
Select commit Hold shift + click to select a range
ada9029
Change positionOffset to heightOffset, fix displaying anchor lines.
bagnell Jun 12, 2017
ba5197d
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jun 12, 2017
7f642b8
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jun 21, 2017
7e1297d
Fixes after merge.
bagnell Jun 21, 2017
3171e6f
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jun 22, 2017
6f30747
Fix picking vector tiles on 3D tiles.
bagnell Jun 22, 2017
c95c1f0
Minor picking update.
bagnell Jun 23, 2017
8420743
Revert to 3D Tiles Sandcastle example from master.
bagnell Jun 23, 2017
f4cd9db
Update server to serve vector tiles.
bagnell Jun 30, 2017
c77406b
Add per-polygon minimum and maximum heights according to the spec.
bagnell Jul 5, 2017
01323ba
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jul 5, 2017
fb0925c
Only generate batch ids when not provided.
bagnell Jul 5, 2017
0991919
Merge remote-tracking branch 'origin/master' into vector-tiles
Jul 6, 2017
d431a69
Minor updates from review.
bagnell Jul 5, 2017
7021477
Update format to use arbitrary rectangle and use provided transform.
bagnell Jul 7, 2017
26bb104
Update positions with model matrix when decoding.
bagnell Jul 8, 2017
22ce894
Merge branch 'instanced-tile-padding' into vector-tiles
Jul 11, 2017
61d410b
Merge branch 'instanced-tile-padding' into vector-tiles
Jul 12, 2017
d9b6b0d
Merged master.
Jul 12, 2017
0504033
Merge remote-tracking branch 'origin/master' into vector-tiles
Jul 18, 2017
cf61acd
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jul 21, 2017
a5c1fa9
Rename GroundPrimitiveBatch -> Vector3DTilePolygons.
bagnell Jul 21, 2017
b34abe3
Rename GroundPolylineBatch -> Vector3DTilePolylines.
bagnell Jul 21, 2017
cd25740
Add Vector3DTilePoints.
bagnell Jul 21, 2017
e3d4fc0
Move feature creation to primitives.
bagnell Jul 21, 2017
0080112
Move style application to primitives.
bagnell Jul 21, 2017
9a883f0
Create Cesium3DTilePointFeature.
bagnell Jul 21, 2017
4e6dfca
Change Cesium3DTilePointFeature.color to labelColor. Update doc.
bagnell Jul 24, 2017
66857bf
Fix styling points with non-generated batch ids.
bagnell Jul 24, 2017
39f5098
Refactor Vector3DTilePolygon for upcoming arbitrary classification pr…
bagnell Jul 24, 2017
11e2124
Add Vector3DTileBatch type to represent the renderable index ranges a…
bagnell Jul 25, 2017
aeece61
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jul 25, 2017
bd776b9
Updates after merge.
bagnell Jul 25, 2017
686de4f
Fix tests after merge and temporarily disable vector tile tests.
bagnell Jul 25, 2017
c76f9bd
Fix jitter.
bagnell Jul 26, 2017
82b7b36
Fix styling.
bagnell Jul 26, 2017
f7e16f4
Fix initial batching by color.
bagnell Jul 26, 2017
93dfdd8
Fix polygons with the wrong winding order.
bagnell Jul 27, 2017
adc73da
We aren't checking if some styles are defined.
Jul 28, 2017
f5d2cae
Fix typo
Aug 2, 2017
fd23df9
Merge pull request #5718 from oterral/patch-3
Aug 2, 2017
5282d5d
Fix typo
Aug 2, 2017
a0bb925
Merge pull request #5719 from oterral/patch-4
Aug 2, 2017
ec6db3d
Added disableDepthTestDistance to point style.
Aug 7, 2017
9ef4d23
Added origin and labelOrigin styles.
Aug 7, 2017
1205e03
Changed label origin in vector tiles to match label collection.
Aug 7, 2017
bba1ca7
Initial mesh implementation. Still testing.
bagnell Aug 8, 2017
a7509de
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Aug 8, 2017
d31b32f
Merge branch 'vector-tiles' into vector-tile-mesh
bagnell Aug 8, 2017
83cc174
Updates after testing.
bagnell Aug 9, 2017
ca14796
Add ability to view classification mesh wireframe.
bagnell Aug 9, 2017
848eb25
Merge branch 'master' into vector-tiles
Aug 10, 2017
f1fffb6
Merge branch 'master' into vector-tiles
bagnell Aug 10, 2017
6f8bc61
Declare member in constructor.
bagnell Aug 11, 2017
dd6e212
Initial alpha classification styling.
bagnell Aug 14, 2017
e58d0b1
Fix artifacts from picking.
bagnell Aug 15, 2017
8805c9b
Inverted classification for multipass OIT (MRT unsupported).
bagnell Aug 15, 2017
63ada00
Fix for when OIT unsupported.
bagnell Aug 15, 2017
07a2557
Add doc and code comments.
bagnell Aug 15, 2017
346ad3e
Update Sandcastle example.
bagnell Aug 15, 2017
244c0cf
Draw classification style when classification is inverted.
bagnell Aug 16, 2017
a3c19c4
Always pick classifications regardless of alpha or show property.
bagnell Aug 16, 2017
2442aec
Fix rendering when highlighting on pick and classification is inverted.
bagnell Aug 17, 2017
a379ee0
Clean up.
bagnell Aug 17, 2017
03d1a23
Merge branch 'master' into vector-tiles
bagnell Aug 18, 2017
d209338
Merge branch 'vector-tiles' into invertable-style
bagnell Aug 18, 2017
b409f7b
Add vector tile support for boxes, cylinders, ellipsoids, and spheres.
bagnell Aug 21, 2017
5d6bac9
Merge branch 'vector-tiles' into invertable-style
bagnell Aug 21, 2017
5f2e46d
Use tile bounding volume (still need pick bounding volumes). Fix batc…
bagnell Aug 21, 2017
553affe
Merge branch 'vector-tiles' into invertable-style
bagnell Aug 21, 2017
c1c54c3
Change invertClassificationAlpha to invertClassificationColor.
bagnell Aug 28, 2017
54dd4f5
Merge branch 'master' into vector-tiles
bagnell Sep 1, 2017
39f5672
Merge branch 'vector-tiles' into invertable-style
bagnell Sep 1, 2017
815e648
Fixes after merge.
bagnell Sep 1, 2017
0a96758
Merge remote-tracking branch 'origin/master' into vector-tiles
gberaudo Sep 4, 2017
a17690e
Merge pull request #5810 from gberaudo/vector-tiles-1.37
bagnell Sep 5, 2017
5642430
Fix constants.
bagnell Sep 5, 2017
2defc39
Merge branch 'vector-tiles' into invertable-style
bagnell Sep 5, 2017
b1b8894
Fix vector tiles pass and enable skip LODs by default.
bagnell Sep 6, 2017
5257ff9
Turn on skip LOD optimization by default.
bagnell Sep 7, 2017
899af16
Fix data structure for rebatching mesh indices. Check if rebatching i…
bagnell Sep 8, 2017
69584f0
Merge branch 'vector-tiles' into invertable-style
bagnell Sep 8, 2017
3ac6180
Fix feature batch id.
bagnell Sep 11, 2017
7b3dfdc
Merge branch 'vector-tiles' into invertable-style
bagnell Sep 11, 2017
6e8cb08
Initial commit for optimized classification inversion.
bagnell Sep 12, 2017
1e6ab0c
fix polyline vector tiles
likangning93 Sep 14, 2017
1dad5f3
Merge pull request #5828 from likangning93/fixPolylines
bagnell Sep 14, 2017
4bc35a5
Fix transcluent invert color.
bagnell Sep 14, 2017
df81a03
Fix highlighting when inverted, re-enable picking in Sandcastle example.
bagnell Sep 14, 2017
eb1adb7
Change stencil reference and mask to remove multiple stencil clears.
bagnell Sep 14, 2017
be04782
Clear buffers for each frustum to fix multifrustum artifact.
bagnell Sep 15, 2017
cb50ce4
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Sep 15, 2017
8563ced
Merge branch 'vector-tiles' into invertable-style
bagnell Sep 15, 2017
14072c5
Only update invert buffers when enabled. Only use translucency when f…
bagnell Sep 15, 2017
5648f31
Fix blinking on pick.
bagnell Sep 15, 2017
411b8fd
Fix for when alpha is unsupported and individual color components are…
bagnell Sep 15, 2017
855ccd4
Add code comment for how the invert classification works.
bagnell Sep 15, 2017
6478a76
Add invert classification support to ClassificationPrimitive. Update …
bagnell Sep 15, 2017
40d5e4b
Add support to GroundPrimitive and add tests.
bagnell Sep 18, 2017
099abba
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Sep 18, 2017
b5c0565
Merge branch 'vector-tiles' into invertable-style
bagnell Sep 18, 2017
e16d16c
Clean up after merge.
bagnell Sep 18, 2017
94fa13d
Merge pull request #5755 from AnalyticalGraphicsInc/invertable-style
bagnell Sep 18, 2017
0ada825
Move classification mesh creation to a web worker.
bagnell Sep 19, 2017
27670f5
Merge branch 'vector-tiles' into mesh-web-worker
bagnell Sep 19, 2017
bcdf661
Compute mesh bounding volumes.
bagnell Sep 19, 2017
403aa24
Remove outdated Sandcastle example.
bagnell Sep 20, 2017
a9529ee
Remove outdated tests.
bagnell Sep 20, 2017
81337ba
Add AttributeCompression and OrientedBoundingBox tests.
bagnell Sep 20, 2017
f11e6b6
Add new style tests.
bagnell Sep 21, 2017
852df0b
Move geometry mesh creation to a web worker. Some renames. Add 3D Til…
bagnell Sep 22, 2017
09128f9
Clean up geometry web worker.
bagnell Sep 26, 2017
4887528
Compute Geometry bounding volumes.
bagnell Sep 26, 2017
6f75de5
Clean up.
bagnell Sep 26, 2017
bed73b9
Move polyline loading to web worker.
bagnell Sep 26, 2017
3b05f98
Clean up.
bagnell Sep 26, 2017
7bef19c
Merged master.
Sep 27, 2017
688e705
Greatly improve performance for applying simple styles to vector tiles.
bagnell Sep 27, 2017
8ef1b97
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Sep 28, 2017
603184a
Improve point load time and fix stuttering on load by moving position…
bagnell Sep 28, 2017
312150a
Some clean up and more tests.
bagnell Sep 29, 2017
b79093f
Merge tag '1.38' into vector-tiles
gberaudo Oct 3, 2017
2905c24
Merge pull request #5875 from gberaudo/merge-1.38-into-vector-tiles
bagnell Oct 3, 2017
5602c30
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Oct 3, 2017
3a1f7bf
Add more vector tile geometry tests.
bagnell Oct 3, 2017
7570c4c
Add vector tile mesh tests.
bagnell Oct 3, 2017
6168e8a
Add wireframe tests.
bagnell Oct 3, 2017
0c1a85d
Add geometry and mesh picking tests.
bagnell Oct 4, 2017
76b177a
Add re-batch and invert classification tests.
bagnell Oct 4, 2017
a07d28c
Fix failing geometry tests on travis.
bagnell Oct 4, 2017
ed55b55
Fix failing meshe tests from travis.
bagnell Oct 4, 2017
9504afb
Add polygon tests.
bagnell Oct 4, 2017
ceca0f6
Add test for polygons with different minimum and maximum heights.
bagnell Oct 5, 2017
38cc1ae
Add vector tiles points tests.
bagnell Oct 5, 2017
d3726c3
Merge branch 'buffer-copy' into vector-tiles
bagnell Oct 5, 2017
6379416
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Oct 5, 2017
69fbd0d
Add WebGL 2 tests for re-batches using buffer-to-buffer copies.
bagnell Oct 5, 2017
cfa3e0e
Add polyline tests.
bagnell Oct 5, 2017
46439ef
Add sample tilesets.
bagnell Oct 11, 2017
0060e18
Add vector content render and pick tests.
bagnell Oct 12, 2017
68e52d5
Clean up batch ids creation.
bagnell Oct 12, 2017
5f3e665
Add tests when the tile includes batch ids.
bagnell Oct 12, 2017
4a168a9
Fix batch ids for cylinders, ellipsoids, and spheres.
bagnell Oct 13, 2017
13df9bb
Update sample tilesets.
bagnell Oct 13, 2017
7c1bfb8
Fix rebatching and indexing with batch ids.
bagnell Oct 13, 2017
d83392d
Do not apply model matrix to polygons when given in cartographic format.
bagnell Oct 13, 2017
cc89f78
Update samples and add debug colorize test.
bagnell Oct 13, 2017
003ae7a
Fix re-batching after batch id changes.
bagnell Oct 16, 2017
26a3883
Remove all of the indexOf calls to make re-batching faster.
bagnell Oct 16, 2017
d873b70
Add tests for a tile with all of the vector types combined.
bagnell Oct 16, 2017
2319410
Change errors to RuntimeErrors for invalid tiles.
bagnell Oct 16, 2017
360da0a
Update private doc.
bagnell Oct 16, 2017
98a1cdc
Add option to classify either 3D Tiles, terrain or both.
bagnell Oct 16, 2017
adbc8ac
Add test for different classification types.
bagnell Oct 16, 2017
ff38aff
Update Sandcastle example.
bagnell Oct 18, 2017
3c3df68
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Oct 18, 2017
fd8bd82
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Oct 19, 2017
3f8b9fc
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Oct 26, 2017
3393c18
Merge tag '1.39' into vector-tiles
gberaudo Nov 2, 2017
89a8ef4
Merge pull request #5960 from gberaudo/vector-tiles
bagnell Nov 2, 2017
acd3f81
Merge branch 'master' into vector-tiles
lilleyse Nov 3, 2017
501c683
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Nov 3, 2017
a76ae75
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Nov 15, 2017
ce68124
Updates from review.
bagnell Nov 20, 2017
0f80e6c
More updates from review.
bagnell Nov 20, 2017
8b61e48
Add debug color option to point vector features.
bagnell Nov 20, 2017
5877cef
Minor doc update.
bagnell Nov 20, 2017
982aed9
Add better Sandcastle examples.
bagnell Nov 28, 2017
0de3ec4
Update vector tiles links and add a comment about experimental nature.
bagnell Nov 29, 2017
599fda2
Updates from review.
bagnell Nov 29, 2017
8f31344
More updates from review. Fix eslint errors. Revert Point Cloud example.
bagnell Nov 29, 2017
155c7ea
Update CHANGES.md. Minor updates from review.
bagnell Nov 29, 2017
d78d3d5
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Nov 29, 2017
fdae6d3
Fix merge error.
bagnell Nov 29, 2017
f433975
Merge branch 'master' into vector-tiles
bagnell Nov 30, 2017
d17b3ba
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Nov 30, 2017
73d26af
Add experimental tags.
bagnell Nov 30, 2017
27972ff
Add option to make a b3dm tileset classify another tileset.
bagnell Dec 1, 2017
b4f367a
Add a separate pass for classification on both terrain and 3D Tiles. …
bagnell Dec 1, 2017
e7ec3be
Optimize b3dm classification fragment shader.
bagnell Dec 1, 2017
2b0f52f
Initial rework.
bagnell Dec 4, 2017
f1ab457
Remove unneeded code.
bagnell Dec 4, 2017
33ff56e
Only create classification commands. Only create basic vertex and fra…
bagnell Dec 4, 2017
7fe3e37
Only use position and batch id attributes.
bagnell Dec 4, 2017
b3993b5
Remove more unneeded code.
bagnell Dec 4, 2017
cc7a228
Remove shader parsing.
bagnell Dec 4, 2017
fad8860
Remove unused uniform semantics.
bagnell Dec 4, 2017
a2a1e2f
Mostly working. Needs clean up. There are issues with model matrices,…
bagnell Dec 5, 2017
0d2f1e1
Fix model matrix.
bagnell Dec 5, 2017
6981a68
Fix rebatching and remove derived commands.
bagnell Dec 5, 2017
e1218d7
Clean up.
bagnell Dec 6, 2017
9173555
Fix test.
bagnell Dec 6, 2017
c1ad375
Revert Sandcastle example.
bagnell Dec 6, 2017
b448116
Remove mesh support from vector tiles.
bagnell Dec 6, 2017
f15d07f
Add Geometry tile.
bagnell Dec 6, 2017
1f8fb07
Remove geometry from vector tile.
bagnell Dec 6, 2017
9c054da
Update point cloud classification example. Tweak geometry tile to pre…
bagnell Dec 6, 2017
db85153
Update Vector tile specs.
bagnell Dec 6, 2017
124d290
Add Geometry3DTileContent tests.
bagnell Dec 6, 2017
1fe9fc8
Remove height reference.
bagnell Dec 6, 2017
8eabdad
Remove more unneeded code.
bagnell Dec 6, 2017
67cdf82
Fix failing test.
bagnell Dec 6, 2017
15b58e4
Remove unused cache.
bagnell Dec 6, 2017
0cefab9
Remove more unneeded code.
bagnell Dec 7, 2017
3e88765
Fix broken test again.
bagnell Dec 7, 2017
bc232cd
Clamp volumes to the far plane.
bagnell Dec 7, 2017
764267a
Add Sandcastle example.
bagnell Dec 7, 2017
00f1792
Updates from review.
bagnell Dec 7, 2017
7cec63d
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Dec 7, 2017
3ffd232
Merge branch 'vector-tiles' into b3dm-class
bagnell Dec 7, 2017
d377603
Update CHANGES.md after merge.
bagnell Dec 7, 2017
eb07e44
Update Sandcastle tileset url.
bagnell Dec 8, 2017
ea49b72
Remove node hierarchy.
bagnell Dec 8, 2017
12283c4
Update doc.
bagnell Dec 8, 2017
79ed093
Add tests. Fix quantization extension. Remove some more unneeded code.
bagnell Dec 8, 2017
0ab3156
Merge branch 'b3dm-class' into vector-split
bagnell Dec 11, 2017
5fdf1ad
Fix after merge.
bagnell Dec 11, 2017
772a9c3
Updates from review.
bagnell Dec 11, 2017
9fbc848
Merge branch 'b3dm-class' into vector-split
bagnell Dec 11, 2017
612c5f5
Update CHANGES.md.
bagnell Dec 11, 2017
618a892
Merge pull request #6034 from AnalyticalGraphicsInc/vector-split
pjcozzi Dec 12, 2017
d566de4
Remove some code expecting multiple primitives. Move glTF checks to c…
bagnell Dec 12, 2017
045e458
Only create one primitive.
bagnell Dec 12, 2017
6e57010
Don't parse shaders since they are generated.
bagnell Dec 12, 2017
15380ef
Remove runtimeNode.
bagnell Dec 12, 2017
92709e8
Create only one uniform map.
bagnell Dec 12, 2017
36b2b53
Factor out common code.
bagnell Dec 13, 2017
a4c4506
Factor out gltf semantic uniforms.
bagnell Dec 13, 2017
5232f88
Remove unused requires.
bagnell Dec 13, 2017
029abad
Pass debug settings to the vector primitive.
bagnell Dec 13, 2017
1fa1976
Add ClassificationModel tests.
bagnell Dec 13, 2017
8f389cb
Update restrictions in the doc.
bagnell Dec 13, 2017
53ed7f2
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Dec 13, 2017
5f4ed4c
Merge branch 'vector-tiles' into b3dm-class
bagnell Dec 13, 2017
2385d20
Update function name.
bagnell Dec 15, 2017
7d27a23
Merge pull request #6033 from AnalyticalGraphicsInc/b3dm-class
pjcozzi Dec 15, 2017
6188233
Updates from review. Add arraySlice tests. Fix lower level classifica…
bagnell Dec 28, 2017
d42f320
More updates from review.
bagnell Dec 28, 2017
b407913
Rename pointColor -> color.
bagnell Dec 28, 2017
459639a
Add tests for uncovered code.
bagnell Jan 2, 2018
bf9572d
Add exception tests for vector and geometry tiles.
bagnell Jan 2, 2018
0f5b30e
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jan 3, 2018
5587f89
Update horizontalOrigin, verticalOrigin, labelHorizontalOrigin, and l…
bagnell Jan 3, 2018
695a60d
Add positive infinity constant for styling.
bagnell Jan 3, 2018
09a8fd2
Align with revisions to spec. Update parsing and test tiles.
bagnell Jan 4, 2018
fe81890
Make skipLevelOfDetail a hint. Disable when using vector/geometry til…
bagnell Jan 5, 2018
8350f31
Merge branch '3d-tiles-vector' into vector-tiles
bagnell Jan 5, 2018
3340438
Update CHANGES.md.
bagnell Jan 8, 2018
b40c2a9
Update test tilesets to be uncompressed.
bagnell Jan 8, 2018
c379c63
Revert commits to Sandcastle example.
bagnell Jan 8, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
95 changes: 95 additions & 0 deletions Apps/Sandcastle/gallery/3D Tiles Classification.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
<!DOCTYPE html>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't see anything for this demo. The tests are also failing so maybe it has to do with something on my system.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add a screenshot.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok I ran this on another computer.

A couple things:

  • The demo is too much like a tech demo. We should create a more complete demo with a real world use case. Based on what's here there is potential for 3 or so different demos. Here are some ideas:
    • Traditional polygons and polylines on terrain with labels
    • 3D geometries used to classify a photogrammetry model
    • Something showing off the styling capabilities
  • If we keep this demo in some form, the tileset's geometric error should be tweaked so it doesn't disappear so soon.

<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
<meta name="description" content="A sample classification dataset rendered with 3D Tiles.">
<meta name="cesium-sandcastle-labels" content="Showcases, 3D Tiles">
<title>Cesium Demo</title>
<script type="text/javascript" src="../Sandcastle-header.js"></script>
<script type="text/javascript" src="../../../ThirdParty/requirejs-2.1.20/require.js"></script>
<script type="text/javascript">
require.config({
baseUrl : '../../../Source',
waitSeconds : 60
});
</script>
</head>
<body class="sandcastle-loading" data-sandcastle-bucket="bucket-requirejs.html">
<style>
@import url(../templates/bucket.css);
</style>
<div id="cesiumContainer" class="fullSize"></div>
<div id="loadingOverlay"><h1>Loading...</h1></div>
<div id="toolbar"></div>
<script id="cesium_sandcastle_script">
function startup(Cesium) {
'use strict';
//Sandcastle_Begin
var viewer = new Cesium.Viewer('cesiumContainer');
viewer.scene.globe.depthTestAgainstTerrain = true;

var classification = viewer.scene.primitives.add(new Cesium.Cesium3DTileset({
url : '../../../Specs/Data/Cesium3DTiles/Vector/VectorTileCombined/',
classificationType : Cesium.ClassificationType.TERRAIN
}));

classification.readyPromise.then(function(tileset) {
viewer.camera.setView({ destination : Cesium.Rectangle.fromDegrees(-0.01, -0.01, 0.01, 0.01) });

tileset.style = new Cesium.Cesium3DTileStyle({
color : "rgba(255, 255, 0, 1.0)",
pointColor : "rgba(255, 255, 0, 1.0)",
pointSize : 20.0
});
}).otherwise(function(error) {
throw(error);
});

var HIGHLIGHT_COLOR = new Cesium.Color(1.0, 1.0, 0.0, 0.4);
var current = {
feature : undefined,
originalColor : new Cesium.Color()
};

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
handler.setInputAction(function(movement) {
var pickedFeature = viewer.scene.pick(movement.endPosition);

if (Cesium.defined(current.feature) && (current.feature !== pickedFeature)) {
// Restore original color to feature that is no longer selected

// This assignment is necessary to work with the set property
if (Cesium.defined(current.feature.pointColor)) {
current.feature.pointColor = Cesium.Color.clone(current.originalColor, current.feature.pointColor);
} else {
current.feature.color = Cesium.Color.clone(current.originalColor, current.feature.color);
}
current.feature = undefined;
}

if (Cesium.defined(pickedFeature) && (pickedFeature !== current.feature)) {
current.feature = pickedFeature;
// Save original color and set to highlight color
if (Cesium.defined(pickedFeature.pointColor)) {
Cesium.Color.clone(pickedFeature.pointColor, current.originalColor);
pickedFeature.pointColor = Cesium.Color.clone(HIGHLIGHT_COLOR, pickedFeature.pointColor);
} else {
Cesium.Color.clone(pickedFeature.color, current.originalColor);
pickedFeature.color = Cesium.Color.clone(HIGHLIGHT_COLOR, pickedFeature.color);
}
}
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

//Sandcastle_End
Sandcastle.finishedLoading();
}
if (typeof Cesium !== "undefined") {
startup(Cesium);
} else if (typeof require === "function") {
require(["Cesium"], startup);
}
</script>
</body>
</html>
43 changes: 43 additions & 0 deletions Source/Core/AttributeCompression.js
Original file line number Diff line number Diff line change
Expand Up @@ -277,5 +277,48 @@ define([
return result;
};

function zigZagDecode(value) {
return (value >> 1) ^ (-(value & 1));
}

/**
* Decodes delta and ZigZag encoded vertices. This modifies the buffers in place.
*
* @param {Uint16Array} uBuffer The buffer or buffer view of u values.
* @param {Uint16Array} vBuffer The buffer or buffer view of v values.
* @param {Uint16Array} [heightBuffer] The buffer or buffer view of height values.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does the description "The buffer or buffer view" imply that ArrayBuffer is accepted?

*
* @see {@link http://cesiumjs.org/data-and-assets/terrain/formats/quantized-mesh-1.0.html|quantized-mesh-1.0 terrain format}
*/
AttributeCompression.zigZagDeltaDecode = function(uBuffer, vBuffer, heightBuffer) {
//>>includeStart('debug', pragmas.debug);
Check.defined('uBuffer', uBuffer);
Check.defined('vBuffer', vBuffer);
Check.typeOf.number.equals('uBuffer.length', 'vBuffer.length', uBuffer.length, vBuffer.length);
if (defined(heightBuffer)) {
Check.typeOf.number.equals('uBuffer.length', 'heightBuffer.length', uBuffer.length, heightBuffer.length);
}
//>>includeEnd('debug');

var count = uBuffer.length;

var u = 0;
var v = 0;
var height = 0;

for (var i = 0; i < count; ++i) {
u += zigZagDecode(uBuffer[i]);
v += zigZagDecode(vBuffer[i]);

uBuffer[i] = u;
vBuffer[i] = v;

if (defined(heightBuffer)) {
height += zigZagDecode(heightBuffer[i]);
heightBuffer[i] = height;
}
}
};

return AttributeCompression;
});
24 changes: 5 additions & 19 deletions Source/Core/CesiumTerrainProvider.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
define([
'../ThirdParty/Uri',
'../ThirdParty/when',
'./AttributeCompression',
'./BoundingSphere',
'./Cartesian3',
'./Credit',
Expand All @@ -27,6 +28,7 @@ define([
], function(
Uri,
when,
AttributeCompression,
BoundingSphere,
Cartesian3,
Credit,
Expand Down Expand Up @@ -449,24 +451,7 @@ define([
var vBuffer = encodedVertexBuffer.subarray(vertexCount, 2 * vertexCount);
var heightBuffer = encodedVertexBuffer.subarray(vertexCount * 2, 3 * vertexCount);

var i;
var u = 0;
var v = 0;
var height = 0;

function zigZagDecode(value) {
return (value >> 1) ^ (-(value & 1));
}

for (i = 0; i < vertexCount; ++i) {
u += zigZagDecode(uBuffer[i]);
v += zigZagDecode(vBuffer[i]);
height += zigZagDecode(heightBuffer[i]);

uBuffer[i] = u;
vBuffer[i] = v;
heightBuffer[i] = height;
}
AttributeCompression.zigZagDeltaDecode(uBuffer, vBuffer, heightBuffer);

// skip over any additional padding that was added for 2/4 byte alignment
if (pos % bytesPerIndex !== 0) {
Expand All @@ -482,7 +467,8 @@ define([
// https://code.google.com/p/webgl-loader/source/browse/trunk/samples/loader.js?r=99#55
// Copyright 2012 Google Inc., Apache 2.0 license.
var highest = 0;
for (i = 0; i < indices.length; ++i) {
var length = indices.length;
for (var i = 0; i < length; ++i) {
var code = indices[i];
indices[i] = highest - code;
if (code === 0) {
Expand Down
57 changes: 56 additions & 1 deletion Source/Core/OrientedBoundingBox.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ define([
'./Cartesian2',
'./Cartesian3',
'./Cartographic',
'./Check',
'./defaultValue',
'./defined',
'./DeveloperError',
Expand All @@ -19,6 +20,7 @@ define([
Cartesian2,
Cartesian3,
Cartographic,
Check,
defaultValue,
defined,
DeveloperError,
Expand Down Expand Up @@ -69,6 +71,59 @@ define([
this.halfAxes = Matrix3.clone(defaultValue(halfAxes, Matrix3.ZERO));
}

/**
* The number of elements used to pack the object into an array.
* @type {Number}
*/
OrientedBoundingBox.packedLength = Cartesian3.packedLength + Matrix3.packedLength;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Were these added to CHANGES.md?


/**
* Stores the provided instance into the provided array.
*
* @param {OrientedBoundingBox} value The value to pack.
* @param {Number[]} array The array to pack into.
* @param {Number} [startingIndex=0] The index into the array at which to start packing the elements.
*
* @returns {Number[]} The array that was packed into
*/
OrientedBoundingBox.pack = function(value, array, startingIndex) {
//>>includeStart('debug', pragmas.debug);
Check.typeOf.object('value', value);
Check.defined('array', array);
//>>includeEnd('debug');

startingIndex = defaultValue(startingIndex, 0);

Cartesian3.pack(value.center, array, startingIndex);
Matrix3.pack(value.halfAxes, array, startingIndex + Cartesian3.packedLength);

return array;
};

/**
* Retrieves an instance from a packed array.
*
* @param {Number[]} array The packed array.
* @param {Number} [startingIndex=0] The starting index of the element to be unpacked.
* @param {OrientedBoundingBox} [result] The object into which to store the result.
* @returns {OrientedBoundingBox} The modified result parameter or a new OrientedBoundingBox instance if one was not provided.
*/
OrientedBoundingBox.unpack = function(array, startingIndex, result) {
//>>includeStart('debug', pragmas.debug);
Check.defined('array', array);
//>>includeEnd('debug');

startingIndex = defaultValue(startingIndex, 0);

if (!defined(result)) {
result = new OrientedBoundingBox();
}

Cartesian3.unpack(array, startingIndex, result.center);
Matrix3.unpack(array, startingIndex + Cartesian3.packedLength, result.halfAxes);
return result;
};

var scratchCartesian1 = new Cartesian3();
var scratchCartesian2 = new Cartesian3();
var scratchCartesian3 = new Cartesian3();
Expand All @@ -86,7 +141,7 @@ define([
* This is an implementation of Stefan Gottschalk's Collision Queries using Oriented Bounding Boxes solution (PHD thesis).
* Reference: http://gamma.cs.unc.edu/users/gottschalk/main.pdf
*
* @param {Cartesian3[]} positions List of {@link Cartesian3} points that the bounding box will enclose.
* @param {Cartesian3[]} [positions] List of {@link Cartesian3} points that the bounding box will enclose.
* @param {OrientedBoundingBox} [result] The object onto which to store the result.
* @returns {OrientedBoundingBox} The modified result parameter or a new OrientedBoundingBox instance if one was not provided.
*
Expand Down
59 changes: 59 additions & 0 deletions Source/Core/arraySlice.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
define([
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are no tests for this file.

'./Check',
'./defaultValue',
'./defined',
'./FeatureDetection'
], function(
Check,
defaultValue,
defined,
FeatureDetection) {
'use strict';

var typedArrayTypes;

if (FeatureDetection.supportsTypedArrays()) {
typedArrayTypes = [Int8Array, Uint8Array, Uint8ClampedArray, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array];
}

/**
* Create a shallow copy of an array from begin to end.
*
* @param {Array} array The array to fill.
* @param {Number} [begin=0] The index to start at.
* @param {Number} [end=array.length] The index to end at.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this the ending index or ending index + 1? Either the documented default value or text is wrong.

*
* @returns {Array} The resulting array.
* @private
*/
function arraySlice(array, begin, end) {
//>>includeStart('debug', pragmas.debug);
Check.defined('array', array);
if (defined(begin)) {
Check.typeOf.number('begin', begin);
}
if (defined(end)) {
Check.typeOf.number('end', end);
}
//>>includeEnd('debug');

if (typeof array.slice === 'function') {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can't this be done at load time instead of each time the function is called? Or is this done here so that the developer errors can be checked? Could also still set a function variable at load time and call it here.

return array.slice(begin, end);
}

var copy = Array.prototype.slice.call(array, begin, end);
if (FeatureDetection.supportsTypedArrays()) {
var length = typedArrayTypes.length;
for (var i = 0; i < length; ++i) {
if (array instanceof typedArrayTypes[i]) {
copy = new typedArrayTypes[i](copy);
break;
}
}
}

return copy;
}

return arraySlice;
});
3 changes: 1 addition & 2 deletions Source/Scene/Batched3DModel3DTileContent.js
Original file line number Diff line number Diff line change
Expand Up @@ -382,12 +382,11 @@ define([
}

function createFeatures(content) {
var tileset = content._tileset;
var featuresLength = content.featuresLength;
if (!defined(content._features) && (featuresLength > 0)) {
var features = new Array(featuresLength);
for (var i = 0; i < featuresLength; ++i) {
features[i] = new Cesium3DTileFeature(tileset, content, i);
features[i] = new Cesium3DTileFeature(content, i);
}
content._features = features;
}
Expand Down
1 change: 1 addition & 0 deletions Source/Scene/Billboard.js
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,7 @@ define([
this._billboardCollection = billboardCollection;
this._dirty = false;
this._index = -1; //Used only by BillboardCollection
this._batchIndex = undefined; // Used only by Vector3DTilePoints and BillboardCollection

this._imageIndex = -1;
this._imageIndexPromise = undefined;
Expand Down
Loading