1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > qml调用百度地图api实现卫星地球模式画路书轨迹

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

时间:2018-12-25 08:01:27

相关推荐

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

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

总结下类型转换:pro文件中加入依赖的模块引入头文件 websockettransport.hmain文件加入qmlindex.html注意

总结下类型转换:

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_OBJECTpublic: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 thisQtWebView::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: someObjectWebChannel.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: serverlisten: trueport: 55222onClientConnected: {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: webViewanchors.fill: parentanchors.margins: 5url: "qrc:/map/index.html"onLoadingChanged: {if (loadRequest.errorString){console.error(loadRequest.errorString); }}}WebChannel {id: channelregisteredObjects: [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./api?type=webgl&v=1.0&ak=HDMmTOItpjjwIugxR3TNuPNmRqQrBWBl"></script><script type="text/javascript" src="http://api./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 sidevar 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>

注意

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。