qml调用百度地图api实现卫星地球模式画路书轨迹

总结下类型转换:

pro文件中加入依赖的模块

这里我对工作中matlab的程序需要实现的功能进行讲解:

   QT += qml quick webview webchannel websockets webengine

引入头文件 websockettransport.h

#ifndef WEBSOCKETTRANSPORT_H
#define WEBSOCKETTRANSPORT_H

#include <QWebChannelAbstractTransport>
#include <QJsonDocument>
#include <QJsonObject>
#include <QDebug>

class WebSocketTransport : public QWebChannelAbstractTransport
{
   Q_OBJECT

public:
   Q_INVOKABLE void sendMessage(const QJsonObject &message) override
   {
       QJsonDocument doc(message);
       emit messageChanged(QString::fromUtf8(doc.toJson(QJsonDocument::Compact)));
   }

   Q_INVOKABLE void textMessageReceive(const QString &messageData)
   {
       QJsonParseError error;
       QJsonDocument message = QJsonDocument::fromJson(messageData.toUtf8(), &error);
       if (error.error)
       {
           qWarning() << "Failed to parse text message as JSON object:" << messageData
                      << "Error is:" << error.errorString();
           return;
       } else if (!message.isObject())
       {
           qWarning() << "Received JSON message that is not an object: " << messageData;
           return;
       }
       emit messageReceived(message.object(), this);
   }

signals:
   void messageChanged(const QString & message);
};

#endif // WEBSOCKETTRANSPORT_H

main文件加入

#include <QQmlApplicationEngine>
#include <QQuickWindow>
#include <QGuiApplication>
#include <QtWebView>
#include <QWebChannel>
#include <QWebSocketServer>
#include "./include/websockettransport.h"

int main(int argc, char *argv[])
{
//    QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
//    QCoreApplication::setAttribute(Qt::AA_UseOpenGLES);
   QApplication app(argc, argv);

   // don't forget about this
   QtWebView::initialize();
   qmlRegisterType<WebSocketTransport>("io.decovar.WebSocketTransport", 1, 0, "WebSocketTransport");

   QSurfaceFormat format;
   format.setDepthBufferSize(24);
   format.setStencilBufferSize(8);
   format.setVersion(3, 2);
   format.setProfile(QSurfaceFormat::CoreProfile);
   QSurfaceFormat::setDefaultFormat(format);

   QQmlApplicationEngine engine;
   engine.load(QUrl(QLatin1String("qrc:/main.qml")));
   if (engine.rootObjects().isEmpty()){
       QMessageBox::warning(NULL, "Warning!", "qml加载异常!");
       return -1;
   }
   return app.exec();
}

qml

   QtObject {
                   id: someObject
                   WebChannel.id: "backend"
                   property string someProperty: "qml data"
                   signal someSignal(var wxName, var dataLen, var jd, var wd);
                   signal beginPlay(var order);

                   function changeText(newText) {
                       return "New text length: ";
                   }
               }

               WebSocketTransport {
                   id: transport
               }

               WebSocketServer {
                   id: server
                   listen: true
                   port: 55222
                   onClientConnected: {
                       if(webSocket.status === WebSocket.Open) {
                           channel.connectTo(transport)
                           webSocket.onTextMessageReceived.connect(transport.textMessageReceive)
                           transport.onMessageChanged.connect(webSocket.sendTextMessage)
                       }
                   }
                   onErrorStringChanged: {
                       console.log(qsTr("Server error: %1").arg(errorString));
                   }
                   Component.onCompleted: {
                       console.log(server.url + "已连接");
                   }
               }

               WebView {
                       id: webView
                       anchors.fill: parent
                       anchors.margins: 5
                       url: "qrc:/map/index.html"
                       onLoadingChanged: {
                           if (loadRequest.errorString)
                               { console.error(loadRequest.errorString); }
                       }
                   }

               WebChannel {
                       id: channel
                       registeredObjects: [someObject]
              	}

//给前端wx图    这是一个cpp给qml发的信号
       onShowWx: {
           someObject.someSignal(wxName, dataLen, jd, wd);
       }
需要注意的是不能将webView画在如Rectangle类这种控件的里面,否则地图会出现跑点,3D图出不来等一系列问题,需要将其单独放在Page或者底层继承自widget类的控件中才行

index.html

<!DOCTYPE html>
<html>
<head>
   <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
   <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
   <style type="text/css">
       body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;font-family:"微软雅黑";}
   </style>
   <script type="text/javascript" src="http://api.map.baidu.com/api?type=webgl&v=1.0&ak=HDMmTOItpjjwIugxR3TNuPNmRqQrBWBl"></script>
   <script type="text/javascript" src="http://api.map.baidu.com/library/LuShu/gl/src/LuShu_min.js"></script>
   <script type="text/javascript" src="qrc:/js/qwebchannel.js"></script>
   <title>地球模式</title>
</head>
<body>
<div id="allmap"></div>
</body>
</html>
<script type="text/javascript">
   var img = document.createElement("img");
   img.src = "../pic/卫星.png";
   // 百度地图API功能
   var map = new BMapGL.Map("allmap");                     // 创建Map实例
   map.centerAndZoom(new BMapGL.Point(118.5, 27.5), 5);    // 初始化地图,设置中心点坐标和地图级别
   map.enableScrollWheelZoom(true);                        //开启鼠标滚轮缩放
   map.setMapType(BMAP_EARTH_MAP);                         // 设置地图类型为地球模式
   map.addControl(new BMapGL.ScaleControl());              // 添加比例尺控件

   var wxMbData = {};
   var polylineList = {};

   // here will be our QtObject from QML side
   var backend;
   var someProperty;

   function startLushu(polyline) {
       var fly = '';
       lushu = new BMapGLLib.LuShu(map, polyline.getPath(), {
           geodesic: true,
           autoCenter: true,
           icon: new BMapGL.Icon(fly, new BMapGL.Size(48, 48), { anchor: new BMapGL.Size(24, 24) }),
           speed: 1000000,
           enableRotation: true
       });
       setTimeout('lushu.start()', 4000);
   }

   window.onload = function()
   {
       var socket = new WebSocket("ws://127.0.0.1:55222");
       socket.onopen = function()
       {
           new QWebChannel(socket, function(channel) {
               backend = channel.objects.backend;
               someProperty = backend.someProperty;

               backend.beginPlay.connect(function(beginStr){
                  alert("begin play");
               });
               backend.someSignal.connect(function(wxName, dataLen, jd, wd) {
                   var j=0;
                   var maxLen = 0;
                   for(var i=0;i<wxName.length;i++){
                       var path = [];
                       maxLen = maxLen + dataLen[i];

                       for(j;j<maxLen;j++){
                           path.push(new BMapGL.Point(jd[j], wd[j]));
                       }
                       wxMbData[wxName[i]] = path;

                       var polyline = new BMapGL.Polyline(path, {
                           clip: false,
                           // geodesic: true,
                           strokeWeight: 1
                       });
                       polylineList[wxName[i]] = polyline;

                       map.addOverlay(polyline);
                       startLushu(polyline);
                   }
                   this.map.clearOverlay();
               });
           });
       };

       socket.onerror = function(evt)
       {
           alert("on error");
       }

       socket.onmessage = function (evt)
       {
           var received_msg = evt.data;
           alert("Message is received: " + received_msg);
       };

       socket.onclose = function(evt)
       {
           alert("Connection is closed: " + evt.code + " - " + evt.reason);
       };
   }
</script>

注意

该文章仅个人学习使用,欢迎大家一起交流学习

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宇智波盆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值