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

More actions for cesium (3Dtiles geofox), potree, static meshes (f3d), pmtiles, geoparquet #465

Merged
merged 26 commits into from
Jan 23, 2025
Merged
Show file tree
Hide file tree
Changes from 22 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
6143960
Add CesiumSandcastle action for OGC 3D-Tiles datasets
jo-chemla Aug 14, 2024
e1d8f5a
Add Potree Action for COPC/Potree datasets
jo-chemla Aug 14, 2024
f7c639e
Add 3dviewer.net for handling gltf, fbx, obj, ply etc
jo-chemla Aug 14, 2024
424c304
Reference new actions in assetActions config
jo-chemla Aug 14, 2024
0181e03
Add Protomaps reader for pmtiles
jo-chemla Aug 19, 2024
9695c84
Edit checks for mime types
jo-chemla Aug 19, 2024
6df2722
Fix copcviewer can show for ept.json
jo-chemla Aug 19, 2024
2d59d44
Replace component.filename.endsWith with asset.href.includes
jo-chemla Aug 20, 2024
20023b7
Add Geofox.ai for OGC 3dtiles assets, fullscreen webapp
jo-chemla Aug 20, 2024
a196427
Add Geoparquet.info asset viewer
jo-chemla Aug 28, 2024
5c96656
Add links actions for 3d-tiles, protomaps
jo-chemla Aug 28, 2024
c04bde5
Rename CesiumSandcastle files and components to OGC3dTiles
jo-chemla Aug 28, 2024
da087b8
Add to Actions Documentation new assets and links actions
jo-chemla Aug 28, 2024
29866e0
Remove Geoparquet following m-mohr suggestion
jo-chemla Aug 28, 2024
3320c40
Update potree action
jo-chemla Aug 29, 2024
f528e59
Replace viewer for 3d objects from 3dviewer.net to f3d.app
jo-chemla Sep 4, 2024
394e20a
Resolve PR comments
jo-chemla Jan 9, 2025
5ea57f7
F3D.js faster show check support extensions
jo-chemla Jan 9, 2025
47b7f2f
Stop passing empty extension to f3d url param
jo-chemla Jan 9, 2025
f47fc81
urijs auto-encodes
jo-chemla Jan 9, 2025
e3a1b17
urijs auto-encodes
jo-chemla Jan 9, 2025
629215e
urijs auto-encodes
jo-chemla Jan 9, 2025
fcead3a
Remove potree temporarily
jo-chemla Jan 9, 2025
469d78e
Remove potree temporarily
jo-chemla Jan 9, 2025
5619f54
Add note for potree asset action `show`
jo-chemla Jan 9, 2025
f35f9c0
Edit link to iconem potree viewer in docs
jo-chemla Jan 21, 2025
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
15 changes: 13 additions & 2 deletions assetActions.config.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,20 @@
//import Felt from './src/actions/assets/Felt.js';
import Cesium from './src/actions/assets/Cesium.js';
import CopcViewer from './src/actions/assets/CopcViewer.js';
import F3D from './src/actions/assets/F3D.js';
import GeoJsonIo from './src/actions/assets/GeoJsonIo.js';
//import Felt from './src/actions/assets/Felt.js';
// import Geofox from './src/actions/assets/Geofox.js';
// import Geoparquet from './src/actions/assets/Geoparquet.js';
import Potree from './src/actions/assets/Potree.js';
jo-chemla marked this conversation as resolved.
Show resolved Hide resolved
import Protomaps from './src/actions/assets/Protomaps.js';

export default {
//Felt
Cesium,
CopcViewer,
F3D,
GeoJsonIo,
//Felt
// Geoparquet, // not ready yet
Potree,
jo-chemla marked this conversation as resolved.
Show resolved Hide resolved
Protomaps,
};
56 changes: 56 additions & 0 deletions docs/actions.md
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,44 @@ import GeoJsonIo from './src/actions/assets/GeoJsonIo.js';
export default { GeoJsonIo };
```

### OGC3dTiles

Adds an `Open in Geofox.ai` button that allows to open OGC 3D Tiles files on <https://viewer.geofox.ai> or Cesium Sandcastle.

```js
import OGC3dTiles from './src/actions/assets/OGC3dTiles.js';
export default { OGC3dTiles };
```

### geoparquet.info

Adds an `Open in geoparquet.info` button that allows to open GeoParquet files on <https://geoparquet.info>.

```js
import Geoparquet from './src/actions/assets/Geoparquet.js';
export default { Geoparquet };
```

### potree.org

Adds an `Open in potree.org` button that allows to open COPC and Potree files on <https://potree.org> (via [Darren Wiens](https://mpc-copc-viewer.netlify.app) or [Iconem](https://3d.iconem.com/tools/load_potree_project_from_urlparam.html) apps)

```js
import Potree from './src/actions/assets/Potree.js';
export default { Potree };
```

### pmtiles.io

Adds an `Open in pmtiles.io` button that allows to open Protomaps PMTiles files on <https://pmtiles.io>.

```js
import Protomaps from './src/actions/assets/Protomaps.js';
export default { Protomaps };
```



## Links

All actions for links are stored in the folder [`src/actions/links`](../src/actions/links).
Expand All @@ -61,4 +99,22 @@ The link to the XYZ has to follow the [web-map-links extension](https://github.c
```js
import Felt from './src/actions/links/Felt.js';
export default { Felt };
```

### pmtiles.io

Adds an `Open in pmtiles.io` button that allows to open Protomaps PMTiles files on <https://pmtiles.io>.

```js
import Protomaps from './src/actions/assets/Protomaps.js';
export default { Protomaps };
```

### OGC3dTiles

Adds an `Open in Geofox.ai` button that allows to open OGC 3D Tiles files on <https://viewer.geofox.ai> or Cesium Sandcastle.

```js
import OGC3dTiles from './src/actions/assets/OGC3dTiles.js';
export default { OGC3dTiles };
```
9 changes: 7 additions & 2 deletions linkActions.config.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
//import Felt from './src/actions/links/Felt.js';
// import Felt from './src/actions/links/Felt.js';
// import Geofox from './src/actions/links/Geofox.js';
import Cesium from './src/actions/links/Cesium.js';
import Protomaps from './src/actions/links/Protomaps.js';

export default {
//Felt
// Felt,
Cesium,
Protomaps
};
50 changes: 50 additions & 0 deletions src/actions/assets/Cesium.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
import AssetActionPlugin from "../AssetActionPlugin";
import URI from 'urijs';
import i18n from "../../i18n";

// See mime types discussion for 3d-tiles here and there
// https://github.com/opengeospatial/ogcapi-3d-geovolumes/issues/13
const OGC3DTILES_SUPPORTED_TYPES = [
// 'application/json',
'application/3dtiles+json',
];

export default class Cesium extends AssetActionPlugin {

get show() {
return this.component.isBrowserProtocol && OGC3DTILES_SUPPORTED_TYPES.includes(this.asset.type);
}

get uri() {
// https://sandcastle.cesium.com/standalone.html vs https://sandcastle.cesium.com/index.html
let uri = new URI("https://sandcastle.cesium.com/standalone.html");
const tileset_url = this.component.href;
const code_payload = {
html: `
<style> @import url(../templates/bucket.css); </style>
<div id="cesiumContainer" class="fullSize"></div>
`,
code: `
const viewer = new Cesium.Viewer("cesiumContainer", {
terrain: Cesium.Terrain.fromWorldTerrain(),
});

try {
const tileset = await Cesium.Cesium3DTileset.fromUrl('${tileset_url}');
viewer.scene.primitives.add(tileset);
viewer.zoomTo(tileset);
} catch (error) {
console.log('Error loading tileset');
}
`.replaceAll(' ', '')
};
const code_str = btoa(JSON.stringify(code_payload));
uri.addQuery('code', code_str);
return uri;
}

get text() {
return i18n.t('actions.openIn', {service: 'Cesium Sandcastle'});
}

}
5 changes: 4 additions & 1 deletion src/actions/assets/CopcViewer.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ import i18n from "../../i18n";
export default class CopcViewer extends AssetActionPlugin {

get show() {
return this.component.isBrowserProtocol && this.asset.type === 'application/vnd.laszip+copc';
return this.component.isBrowserProtocol && (
this.asset.type === 'application/vnd.laszip+copc'
|| URI(this.asset.href).filename() == 'ept.json'
);
}

get uri() {
Expand Down
45 changes: 45 additions & 0 deletions src/actions/assets/F3D.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
import AssetActionPlugin from "../AssetActionPlugin";
import URI from 'urijs';
import i18n from "../../i18n";

// obj & ply files are usually with mime-type text/plain
const F3D_SUPPORTED_TYPES = [
'model/gltf-binary',
'model/gltf+json',
'application/fbx',
];
// below is usually text/plain
const F3D_SUPPORTED_FILEEXTS = ['obj', 'ply', 'fbx', 'glb', 'gltf'];
export default class F3D extends AssetActionPlugin {

get show() {
const suffix = URI(this.asset.href).suffix();
return this.component.isBrowserProtocol && (
F3D_SUPPORTED_TYPES.includes(this.asset.type)
|| F3D_SUPPORTED_FILEEXTS.some(ext => (suffix === ext))
);
}

get uri() {
// `https://f3d.app/web/#model=${modelUrl}` see PR merged for parsing model url and extension: https://github.com/f3d-app/f3d/pull/1596
// Could enforce extension to help f3d.app determine the mesh type and loader to use
let uri = new URI("https://f3d.app/web");
uri.addQuery("model", this.component.href);
uri = uri.toString().replace('?', '#');
return uri;
}

get uri_3dviewer() {
// `https://3dviewer.net/#model=${modelUrl}` misconception, # is not a fragment but a query, can be replaced
// let uri = new URI("https://3dviewer.net/");
// uri.addQuery("model", this.component.href);
// uri = uri.toString().replace('?', '#');
let uri = `https://3dviewer.net/#model=${this.component.href.replace('%2F', '/')}`;
return uri;
}

get text() {
return i18n.t('actions.openIn', {service: 'f3d.app'});
}

}
28 changes: 28 additions & 0 deletions src/actions/assets/Geofox.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import AssetActionPlugin from "../AssetActionPlugin";
import URI from 'urijs';
import i18n from "../../i18n";

// See mime types discussion for 3d-tiles here and there
// https://github.com/opengeospatial/ogcapi-3d-geovolumes/issues/13
const OGC3DTILES_SUPPORTED_TYPES = [
// 'application/json',
'application/3dtiles+json',
];

export default class Geofox extends AssetActionPlugin {

get show() {
return this.component.isBrowserProtocol && OGC3DTILES_SUPPORTED_TYPES.includes(this.asset.type);
}

get uri() {
let uri = new URI("https://viewer.geofox.ai/");
uri.addQuery('tileset', this.component.href);
return uri;
}

get text() {
return i18n.t('actions.openIn', {service: 'Geofox.ai'});
}

}
27 changes: 27 additions & 0 deletions src/actions/assets/Geoparquet.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import AssetActionPlugin from "../AssetActionPlugin";
import URI from 'urijs';
import i18n from "../../i18n";

const GEOPARQUET_SUPPORTED_TYPES = [
'application/vnd.apache.parquet',
'application/x-parquet'
];

export default class Geoparquet extends AssetActionPlugin {

get show() {
return this.component.isBrowserProtocol && GEOPARQUET_SUPPORTED_TYPES.includes(this.asset.type);
}

get uri() {
let uri = new URI("https://geoparquet.info");
uri.addQuery('url', this.component.href);
return uri;
}


get text() {
return i18n.t('actions.openIn', {service: 'Geoparquet.info'});
}

}
46 changes: 46 additions & 0 deletions src/actions/assets/Potree.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import AssetActionPlugin from "../AssetActionPlugin";
import URI from 'urijs';
import i18n from "../../i18n";

const POTREE_SUPPORTED_TYPES = [
'application/vnd.laszip+copc',
];

// this.component.filename.endsWith or this.asset.href.includes
const POTREE_SUPPORTED_FILEEXTS = [
'cloud.js', 'metadata.json', 'ept.json'
jo-chemla marked this conversation as resolved.
Show resolved Hide resolved
// potree v1, potree v2, EPT Entwine Point Tiles
];

export default class Potree extends AssetActionPlugin {

get show() {
return this.component.isBrowserProtocol && (
jo-chemla marked this conversation as resolved.
Show resolved Hide resolved
POTREE_SUPPORTED_TYPES.includes(this.asset.type)
|| POTREE_SUPPORTED_FILEEXTS.map(
f => URI(this.asset.href).filename().endsWith(f)
).some(e => e)
);
}

get uri() {
// Docs: PR made to original potree repo to avoid relying on iconem own infrastructure
// https://github.com/potree/potree/pull/1456
// would be accessible via https://potree.org/potree/examples/load_potree_project_from_urlparam.html
// Can also parse pointSize, FOV, opacity, edlEnabled, edlRadius, edlStrength, pointBudget, showBoundingBox, pointSizing, quality, position, target, background via loadSettingsFromURL
// Alternatives with single potree-supported tileset support and less param parsed
// https://mpc-copc-viewer.netlify.app?c=rgba&r= Darren Wiens app, which works eg with IGN COPC:
// https://potree.org/potree/examples/copc.html?c=rgba&r= Potree copc app
let uri = new URI("https://3d.iconem.com/apps/load_potree_project_from_urlparam");
const datasetUrl = this.component.href;
uri.addQuery('fit', 'true');
uri.addQuery('c', 'elevation'); // rgba, elevation, intensity etc
uri.addQuery('datasetsUrls', `["${datasetUrl}"]`);
return uri;
}

get text() {
return i18n.t('actions.openIn', {service: 'potree.org'});
}

}
30 changes: 30 additions & 0 deletions src/actions/assets/Protomaps.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import AssetActionPlugin from "../AssetActionPlugin";
import URI from 'urijs';
import i18n from "../../i18n";

// obj & ply files are usually with mime-type text/plain
const PROTOMAPS_SUPPORTED_TYPES = [
'application/vnd.pmtiles',
];

export default class Protomaps extends AssetActionPlugin {

get show() {
// Rather check if .pmtiles substring present in this.asset.href or simply this.component.filename.endsWith('pmtiles')
return this.component.isBrowserProtocol && (
PROTOMAPS_SUPPORTED_TYPES.includes(this.asset.type)
|| URI(this.asset.href).suffix() == 'pmtiles'
);
}

get uri() {
let uri = new URI("https://pmtiles.io/");
uri.addQuery("url", this.component.href); // returns the URI instance for chaining
return uri;
}

get text() {
return i18n.t('actions.openIn', {service: 'Protomaps'});
}

}
Loading