I'm just starting out with Cesium js.
I can host the HelloWorld.html on local host and see the globe and stars.
If I try to set up a new Cesium.Viewer in a div on a page with a second div with control buttons, the Cesium viewer still takes over 100% of the browser window.
Does anyone have an example/advice of using a Cesium Viewer with other controls on a web page? It seems like this should be a common thing to want to do but I can't get it to display within the div.
As Hyper Sonic alluded too, Cesium lives inside any canvas element you want, so anything you can do with an HTML canvas, you can do with Cesium. Itâs all accomplished through standard CSS styling. Here are two quick examples:
If youâre talking about having Cesium not be the full browser window, then you need to modify your pages CSS so that the Cesium container doesnât take up the full screen. For example, hereâs a complete Cesium app with a small window:
If youâre talking about overlaying controls on top of a full screen Cesium window, thatâs easy too and there are a myriad of ways to do it. Hereâs one of them:
Hello World!
@import url(../Build/Cesium/Widgets/widgets.css);
html, body, #cesiumContainer {
width: 100%; height: 100%; margin: 0; padding: 0; overflow: hidden;
}
#overlay {
color : #FFFFFF;
top : 6px;
left : 6px;
position : absolute;
z-index : 1;
}
Here is some text and a shiny Button! And here is some more text
Trying that first HTML example I entered cesiumContainer into the console. Apparently everything is contained within the cesiumContainer div. That makes sense looking at this line: var viewer = new Cesium.Viewer(âcesiumContainerâ);
The canvas is buried a bit. First expand cesiumContainer, then expand cesium-viewer, then expand cesium-viewer-cesiumWidgetContainer, then expand cesium-widget, and thereâs the canvas. You could also just open the console and select the elements tab then expand it from there as well.
I tried altering the style width using JavaScript, but the web browser complained, so I donât know if you can change it while it is running.
I hope so, you can change the div Google Earth lives in and it would adjust to the new size and position on the fly (though sometimes youâd have to jiggle it a bit first.)
You can type document.getElementById(âcesiumContainerâ).style and it will give you a bunch of empty properties.
I tried the 2nd HTML example and that z-index 1 is needed to render the div above canvas. Perhaps the other divs placed over the canvas are z-index 1 as well. Iâd imagine if you also want to render over the other divs youâd need z-index 2.
Is there a way to dynamically adjust the cesiumContainer div while itâs running? I noticed that Google Earth API automatically adjusted as itâs div changed.
Although Streetview only adjusts to the div when it is first started. When I changed the size of the div Streetview was attached to it would not expand to the new size. I had to delete the Streetview instance and create a new one. It would be nice if Streetview would adjust to the new size, even just checking the div size every few seconds to see if it changed would work if there isnât already an onChange function. Same with Cesium.
My example was just one way to do it. You can also add items directly to the viewer.container div if you were so inclined. My main point was that Cesium just fits in with the rest of the CSS/HTML system and thereâs nothing special about it. You can even use CSS transforms to do all kinds of crazy stuff with it.
The Viewer and CesiumWidget widgets both automatically resize to match the div that they live in. There is also a Vewier.resize() method that forces the resize if needed or if you are implementing a custom render loop.
Thanks for all the info! Ya youâre right, Cesium does seem to automatically resize. I forgot to put quotes around 800px regarding the earlier post.
It can be set using JavaScript anytime using stuff like â800pxâ or â50%â.
The Cesium Viewer is a standalone application as well, the main difference is that it uses AMD modules rather than the combined Cesium.js.
Thereâs also this: https://github.com/pjcozzi/cesium-starter-app; though it needs to be updated to 1.6 (which is trivial to do yourself by just replacing the Cesium directory with the one from 1.6).
Thanks for the link to the Cesium starter app, Iâll be sure to check that out.
Iâd like to use percentages to declare div sizes, but Iâve hit a snag.
var ccs = document.getElementById(âcesiumContainerâ).style;
ccs.width=â100%â;ccs.height=â500pxâ; //this works
ccs.width=â1900pxâ;ccs.height=â500pxâ; //this works
ccs.width=â1900pxâ;ccs.height=â50%â; //this doesnât work
ccs.width=â100%â;ccs.height=â50%â; //this doesnât work
``
The 2 that donât work simply take up the full screen. I suppose I could figure out the window size then convert % to px as a way around this.
Those last two should definitely work, but percentage values are dependant on the parent object. If you can create a small example that doesnât do what you expect (and works with non-Cesium div doing the same thing) please let us know.
Thatâs odd, if I omit this in the style tags
html, body, #cesiumContainer {
width: 100%; height: 100%; margin: 0; padding: 0; overflow: hidden;}
``
This JavaScript statement (placed in the window.onload function)
var ccs = document.getElementById(âcesiumContainerâ).style;
ccs.width=â100%â;ccs.height=â50%â;
``
results in Cesium taking 100% width and 100% height. Yet if I donât omit that in the style tags the JavaScript statement will work properly. Iâll be sure to not omit that in the style tags! Thanks, now I donât have to use a % to px function.