7、添加billboard小旗子

文章展示了如何在Cesium地图上通过鼠标点击事件创建并添加Billboard,将鼠标位置转换为经纬度,然后用这些坐标来定位billboard,实现点击地图添加小旗子的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        本节演示添加billboard小旗子,使用第四节click的例子,通过鼠标点击地图添加billboard添加小旗子。

1、修改鼠标点击事件mouseUp,在函数中创建BillboardCollection对象并添加到地图中。鼠标点击时获取鼠标位置,转换成经纬度然后添加billboard。

static void mouseUp(void *handler, Cesium::ScreenEvent *event) {
    Handler *aggregator = (Handler *) handler;

    if (aggregator->billboards == NULL) {
        // 创建BillboardCollection
        aggregator->billboards = new Cesium::BillboardCollection(NULL);
        aggregator->viewer->_scene->primitives()->add(aggregator->billboards);
    }
    glm::dvec2 position = event->position;//鼠标屏幕位置
    glm::dvec3 coor, carthposition;
    //转换成经纬度,与cesium基本一致
    aggregator->viewer->_scene->_camera->pickEllipsoid(position,
                                                       aggregator->viewer->_scene->_globe->_ellipsoid,
                                                       &coor);
    aggregator->viewer->_scene->_globe->_ellipsoid->cartesianToCartographic(coor, &carthposition);
    double longitude = Cesium::CesiumMath::toDegrees(carthposition.x);
    double latitude = Cesium::CesiumMath::toDegrees(carthposition.y);
    //添加billboard
    glm::dvec3 initialPosition2 = Cesium::Cartesian3::fromDegrees(longitude, latitude);
    aggregator->billboards->add(initialPosition2, "../data/home.png");

}

2、运行地图,点击地图即可添加一个billboard。

完整代码

/**
 * Created by IBM on 2021/3/3.
 */
#include <iostream>
#include <Widgets/Viewer/Viewer.h>
#include <Scene/BillboardCollection.h>


class Handler {
public:
    Cesium::Viewer *viewer;
    Cesium::BillboardCollection *billboards = NULL;

    /**
     * 鼠标抬起事件
     * @param type
     * @param position
     */
    static void mouseUp(void *handler, Cesium::ScreenEvent *event) {
        Handler *aggregator = (Handler *) handler;

        if (aggregator->billboards == NULL) {
            // 创建BillboardCollection
            aggregator->billboards = new Cesium::BillboardCollection(NULL);
            aggregator->viewer->_scene->primitives()->add(aggregator->billboards);
        }
        glm::dvec2 position = event->position;//鼠标屏幕位置
        glm::dvec3 coor, carthposition;
        //转换成经纬度,与cesium基本一致
        aggregator->viewer->_scene->_camera->pickEllipsoid(position,
                                                           aggregator->viewer->_scene->_globe->_ellipsoid,
                                                           &coor);
        aggregator->viewer->_scene->_globe->_ellipsoid->cartesianToCartographic(coor, &carthposition);
        double longitude = Cesium::CesiumMath::toDegrees(carthposition.x);
        double latitude = Cesium::CesiumMath::toDegrees(carthposition.y);
        //添加billboard
        glm::dvec3 initialPosition2 = Cesium::Cartesian3::fromDegrees(longitude, latitude);
        aggregator->billboards->add(initialPosition2, "../data/home.png");

    }
};

int main(int argc, char *argv[]) {
    Handler *handler = new Handler();
    Cesium::Viewer viewer = Cesium::Viewer(500, 300);
    handler->viewer = &viewer;
    std::string url = "https://dev.virtualearth.net";
    std::string key = "AmXdbd8UeUJtaRSn7yVwyXgQlBBUqliLbHpgn2c76DfuHwAXfRrgS5qwfHU6Rhm8";
    Cesium::BingMapsImageryProvider *imageryProvider1 = new Cesium::BingMapsImageryProvider(url, key);
    viewer.imageryLayers()->addImageryProvider(imageryProvider1);
    //创建事件
    Cesium::ScreenSpaceEventHandler *_eventHandler = new Cesium::ScreenSpaceEventHandler(handler);
    _eventHandler->setInputAction(&Handler::mouseUp, Cesium::ScreenSpaceEventType::LEFT_CLICK);//设置鼠标点击事件
    viewer.startAnimating(true);//启动opengl循环
    system("pause");
    return 0;
}

返回目录 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值