Cesium入门11 - Interactivity - 交互性

Cesium入门11 - Interactivity - 交互性

Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/javascript

最后,让咱们添加一些鼠标交互。为了提升咱们的geocache标记的可见性,当用户在标记上hovers时,咱们能够改变它们的样式来突出显示。html

为了实现这一点,咱们将使用拾取pick,一种Cesium的特征,从3D场景中返回数据,在观看者画布上给出像素位置。java

这里有如下几种不一样的picking:canvas

  • Scene.pick : 返回包含给定窗口位置的基元的对象。
  • Scene.drillPick : 返回包含给定窗口位置的全部原语的对象列表。
  • Globe.pick : 返回给定光线与地形的交点。

一下是一些picking操做的例子:ide

由于咱们但愿在hover触发咱们的高亮效果,首先咱们须要建立一个鼠标动做处理器。为此,咱们将使用ScreenSpaceEventHandler在用户输入操做中触发指定函数的一组处理程序。ScreenSpaceEventHandler.setInputAction()监听用户行为类型ScreenSpaceEventType,并运行一个特定的函数,将用户操做传递为参数。这里,咱们将传递一个以movement为输入的函数:函数

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
handler.setInputAction(function(movement) {}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

接下来让咱们来写咱们的高亮功能。处理程序将在鼠标movement中传递,从中咱们能够提取一个窗口位置与pick()一块儿使用。若是拾取返回billboard对象,咱们知道咱们在一个标记上hovering。而后,使用咱们了解的Entity样式,咱们能够应用突出显示样式。ui

// If the mouse is over a point of interest, change the entity billboard scale and color
handler.setInputAction(function(movement) {
    var pickedPrimitive = viewer.scene.pick(movement.endPosition);
    var pickedEntity = (Cesium.defined(pickedPrimitive)) ? pickedPrimitive.id : undefined;
    // Highlight the currently picked entity
    if (Cesium.defined(pickedEntity) && Cesium.defined(pickedEntity.billboard)) {
        pickedEntity.billboard.scale = 2.0;
        pickedEntity.billboard.color = Cesium.Color.ORANGERED;
    }
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

这成功地触发了标记的高亮样式更改。可是,您会注意到,当咱们移动光标时,标记保持突出。咱们能够经过跟踪最后一个标记来修复,并恢复原来的样式。idea

这里是完整的功能,标记高亮显示和取消高亮工做:rest

// If the mouse is over a point of interest, change the entity billboard scale and color
var previousPickedEntity = undefined;
handler.setInputAction(function(movement) {
    var pickedPrimitive = viewer.scene.pick(movement.endPosition);
    var pickedEntity = (Cesium.defined(pickedPrimitive)) ? pickedPrimitive.id : undefined;
    // Unhighlight the previously picked entity
    if (Cesium.defined(previousPickedEntity)) {
        previousPickedEntity.billboard.scale = 1.0;
        previousPickedEntity.billboard.color = Cesium.Color.WHITE;
    }
    // Highlight the currently picked entity
    if (Cesium.defined(pickedEntity) && Cesium.defined(pickedEntity.billboard)) {
        pickedEntity.billboard.scale = 2.0;
        pickedEntity.billboard.color = Cesium.Color.ORANGERED;
        previousPickedEntity = pickedEntity;
    }
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

就是这样!如今咱们成功地添加了鼠标movement handler和标记实体的hover行为。 code

Cesium中文网交流QQ群:807482793

Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/

相关文章
相关标签/搜索