赞
踩
这个地图组件写了很多年了,最初设计的比较粗糙,最开始只是为了满足项目需要,并没有考虑太多拓展性,比如最初都是按照百度地图写死在代码中,经过这几年大量的现场实际应用,以及大量的用户提出的改进意见,逐渐萌生了彻底重新编写对应地图相关的代码,比如基类子类的设计,各种功能接口通过js函数交互,而不是一堆代码写在网页中。
之前的地图示例写的比较粗糙,想到什么写到什么,功能堆积比较严重,一直在做加法,导致越发臃肿,包括界面上的功能演示也比较不直观,所以这次特意花点时间全部重构,包括所有示例都重构,对于过多的示例演示,单独起了个目录存放一个个小示例的代码,拆分开来,使得该分组的功能学习起来非常的方便,之前是一堆示例代码堆积在一个类中,找起来也要费时间,程序员最烦的就是一个代码文件中特别多的代码,能够做到分组拆分就拆分。
include ($$PWD/../core_map/core_map.pri)
include ($$PWD/../core_webview/core_webview.pri)
#include "webview.h"
#include "mapbase.h"
//实例化浏览器控件
WebView *webView = new WebView(this);
//加入到布局
webView->setLayout(ui->gridLayout);
//实例化地图类/参数2表示何种地图内核
MapBase *mapObj = MapHelper::getMapObj(this, MapCore_BaiDu);
//传入网页控件用于执行函数
mapObj->setWebView(webView);
//加载地图
mapObj->load();
QString js;
//设置地图级别(值越大放大/越小缩小)
js = "setZoom(9)";
//街道图卫星图切换(0-街道图/1-卫星图/2-混合图)
js = "setMapType(1)";
//添加一个标记(北京那边)
js = QString("addMarker('测试点', '测试地址', '', '', 100, '%1', 2)").arg("116.475836,40.251114");
//最终通过浏览器控件执行
webView->runJs(js);
//实例化浏览器控件
WebView *webView = new WebView(this);
//加入到布局
webView->setLayout(ui->verticalLayout);
//打开网址
webView->load("https://www.xxx.com", "", "");
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。