zoukankan      html  css  js  c++  java
  • 一个基于百度地图的桌面软件(附工程源码)

    光阴似箭,日月如梭,恍然间,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文件显示百度地图。

    <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 { 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;
    }


    以上是核心内容,就这么简单,下面贴个图:


    猛击下载源码

  • 相关阅读:
    ELK 安装与配置
    redis参数与持久化原理
    python_way ,day26 django_admin 自定义
    python_way ,day25 wmi
    docker系列详解<一>之docker安装
    SpringCloud学习系列<一>版本介绍
    docker 安装MongoDB以及设置用户
    Caused by: java.lang.IllegalArgumentException
    tomcat启动时间5分钟左右org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [342,445] milliseconds.
    Spring 全局异常拦截根据业务返回不同格式数据 自定义异常
  • 原文地址:https://www.cnblogs.com/fuhaots2009/p/3503173.html
Copyright © 2011-2022 走看看