一个基于百度地图的桌面软件(附工程源码)
2014-01-03 10:17
316 查看
光阴似箭,日月如梭,恍然间,2013就这样平平淡淡的过去了。想想工资卡上的余额,心中不免浮起蛋蛋的忧桑。如果再回到2013。。。。。罢了,青春就是如此,每个人都肆无忌惮的挥霍着,在年华正当之时。或许只有当岁月的烙印狠狠落下的那一刻,我们才会想起那再也回不去的美好年华,那落英缤纷的流年似水。
----------------------------------------------------------------------华丽分割线------------------------------------------------------------------------------------------
以上纯属扯淡,下面言归正传。本文介绍用Qt实现对百度地图的调用。
1.涉及到的点
Qt调用javascript代码(在Qt代码中调用百度js api);
调用百度webservice api(在Qt代码中调用百度webservice api);
解析返回的json串。
2.准备工作
到百度开发者中心申请key,要带着key,百度地图才能让咱调起来;
下载并编译jsoncpp,我们要用它解析json,请自行度娘;
准备http请求工具类,可参考新浪微博开放平台研究-实现微博自动评论(下),我们要访问百度的webservice接口。
3.实现
map.html文件,Qt中利用qwebview控件加载此html文件显示百度地图。
搜索函数,包含两方面内容:调用js接口,在地图上进行标注;调用webservice接口,在列表中显示信息。(这两点没太大关系,只是两种不同的方式)
下面这个函数是根据地名获取经纬度
以上是核心内容,就这么简单,下面贴个图:
![](http://img.blog.csdn.net/20140102195756125?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmxvZ3RpbWU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
猛击下载源码
----------------------------------------------------------------------华丽分割线------------------------------------------------------------------------------------------
以上纯属扯淡,下面言归正传。本文介绍用Qt实现对百度地图的调用。
1.涉及到的点
Qt调用javascript代码(在Qt代码中调用百度js api);
调用百度webservice api(在Qt代码中调用百度webservice api);
解析返回的json串。
2.准备工作
到百度开发者中心申请key,要带着key,百度地图才能让咱调起来;
下载并编译jsoncpp,我们要用它解析json,请自行度娘;
准备http请求工具类,可参考新浪微博开放平台研究-实现微博自动评论(下),我们要访问百度的webservice接口。
3.实现
map.html文件,Qt中利用qwebview控件加载此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;} </style> <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=你的key"></script> <title></title> </head> <body> <div id="allmap"></div> </body> </html> <script type="text/javascript"> var map = new BMap.Map("allmap"); map.centerAndZoom(new BMap.Point(116.404, 39.915), 11); map.addControl(new BMap.NavigationControl()); map.addControl(new BMap.ScaleControl()); map.addControl(new BMap.OverviewMapControl()); map.enableScrollWheelZoom(); map.setCurrentCity("北京"); //qt代码中要调用此方法,在地图上进行标注,key是搜索关键字,area是搜索地址 function search(key,area) { var local = new BMap.LocalSearch(map, { renderOptions:{map: map, autoViewport:true} }); local.searchNearby(key, area); } </script>
搜索函数,包含两方面内容:调用js接口,在地图上进行标注;调用webservice接口,在列表中显示信息。(这两点没太大关系,只是两种不同的方式)
//搜索,1:在地图上标注(调用js api),2:列表显示(调用webservice api) void BMap::search() { QString key = this->edit_key->text(); QString area = this->edit_area->text(); //调用js方法search QString method = QString("search(\"%1\", \"%2\")").arg(key).arg(area); QWebFrame *frame = webview->page()->mainFrame(); frame->evaluateJavaScript(method); //根据地名获取经纬度 QString code = this->geocode(area); HttpClient * http = new HttpClient(); QUrl url; //圆形区域内搜索 url.setUrl("http://api.map.baidu.com/place/v2/search"); url.addQueryItem("query",key); url.addQueryItem("output","json"); url.addQueryItem("ak","你的key"); url.addQueryItem("location",code); url.addQueryItem("radius","1000"); QNetworkRequest request; request.setUrl(url); QString ret = http->get(request); list_result->clearContents(); Json::Reader reader; Json::Value value; //解析json if (reader.parse(ret.toStdString(), value)) { value = value["results"]; list_result->setRowCount(value.size()); for (int i=0; i<value.size(); i++) { std::string name = value[i]["name"].asString(); std::string address = value[i]["address"].asString(); QTableWidgetItem *item = new QTableWidgetItem(QString::fromStdString(name)); this->list_result->setItem(i,0,item); item = new QTableWidgetItem(QString::fromStdString(address)); this->list_result->setItem(i,1,item); } } delete http; }
下面这个函数是根据地名获取经纬度
//根据地名获取经纬度 QString BMap::geocode(const QString &area) { QString ret; HttpClient * http = new HttpClient(); QUrl url; url.setUrl("http://api.map.baidu.com/geocoder/v2/"); url.addQueryItem("address",area); url.addQueryItem("city",tr("北京市")); url.addQueryItem("output","json"); url.addQueryItem("ak","你的key"); QNetworkRequest request; request.setUrl(url); QString retstr = http->get(request); Json::Reader reader; Json::Value value; if (reader.parse(retstr.toStdString(), value)) { value = value["result"]; value = value["location"]; ret+=QString::number(value["lat"].asDouble()); ret+=","; ret+=QString::number(value["lng"].asDouble()); } delete http; return ret; }
以上是核心内容,就这么简单,下面贴个图:
猛击下载源码
相关文章推荐
- 一个基于百度地图的桌面软件(附工程源码)
- 基于OGRE实现一个简单的3D游戏(软件工程作业2)
- 金山卫士开源软件之旅(二) 简单教程:如何创建一个基于金山卫士界面库的工程
- 基于QT的桌面文件软件管理程序源码
- 基于内嵌浏览器内核(如XULRunner、CEF)来开发桌面软件
- [置顶] webservice系列1---基于web工程上写一个基本数据类型的webservice
- 推荐一个桌面图标分类软件Fences
- 创建一个完整的CCS工程(基于F2812)
- 基于jquery实现一个滚动的分步注册向导-附源码
- EonerCMS——做一个仿桌面系统的CMS(八-带demo源码下载)
- 【Android】 基于Socket 的即时通信软件 YQ(源码下载)
- [转载]一个Linux下抓包软件(源码)
- 一个基于qt的桌面聊天系统的学习笔记(1)-邮件模块(2)收发信处理流程
- EonerCMS——做一个仿桌面系统的CMS(十-附最新源码)
- BaiduMap---百度地图官方Demo之MapFragment使用(创建一个基于Fragment的地图框架)
- 基于OpenCV单目相机的快速标定--源码、工程、实现过程
- 整合一个基于c#的RSA私钥加密公钥解密的Helper类,含源码
- 基于python3.6连接mysql,实现一个银行转账的小功能(源码)
- 最近做了一个c/s结构的软件客户端架构工作,其对象图是基于本文对象图做的(包括包结构)求围观,指点。
- 吴昊品工程级别项目 Round 3(追加) —— 一个基于android的手机防盗软件的实现