百度地图api,使用QT同时绘制多个标注

myMap.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{width: 100%;height: 100%;margin:0;font-family:"微软雅黑";}
                #allmap{height:500px;width:100%;}
                #r-result{width:100%; font-size:14px;}
        </style>
        <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=用自己的ak"></script>
        <title>城市名定位</title>
</head>
<body>
        <div id="allmap"></div>
        <div id="r-result">
                经度: <input id="longitude" type="text" style="width:100px; margin-right:10px;" />
                纬度: <input id="latitude" type="text" style="width:100px; margin-right:10px;" />
                <input type="button" value="查询" onclick="theLocation()" />
        </div>
</body>
</html>
<script type="text/javascript">
        // 百度地图API功能
        var map = new BMap.Map("allmap",{
        minZoom : 1,
        maxZoom : 20
        });
        //初始化地图,设置坐标点在哪
        map.centerAndZoom(new BMap.Point(117,31),20);
        map.enableScrollWheelZoom(true);

        //设置标注图片
        var icon = new BMap.Icon("car_4.png",new BMap.Size(35,30),{
                        anchor:new BMap.Size(35,0)
         });

        // 用经纬度设置地图中心点
        function theLocation(){
               if(document.getElementById("longitude").value != "" && document.getElementById("latitude").value != ""){
                        map.clearOverlays();
                        var new_point = new BMap.Point(document.getElementById("longitude").value,document.getElementById("latitude").value);
                        var marker = new BMap.Marker((new_point),{
            icon:icon
    });
                        map.addOverlay(marker);              // 将标注添加到地图中
                        map.panTo(new_point);
                }
       }
       
       translateCallback = function addpoint1(data){
        if(data.status === 0) {
        var marker1 = new BMap.Marker(data.points[0]);
        map.addOverlay(marker1);
        }
    }
    
        function send(){
            map.clearOverlays();
            }
       
        function addpoint (x,y){
                
                //map.clearOverlays(); //更新前先清除之前的标注
                
                var convertor = new BMap.Convertor();
                var pointArr = [];
                var ggPoint = new BMap.Point(x,y);
                pointArr.push(ggPoint);
                //map.clearOverlays();
                //var ggPoint = new BMap.Point(x,y);
                var marker = new BMap.Marker((ggPoint),{
            icon:icon
    });
                map.addOverlay(marker);
                convertor.translate(pointArr,1,5,translateCallback)
    }
</script>

qt构造函数内代码:

qApp->setApplicationName("padcollectionclient");

    QString sFilePath = QCoreApplication::applicationDirPath();
    sFilePath += "/my.html";

    ui->lineEdit->setText(sFilePath);
    //connect(ui->lineEdit,SIGNAL(returnPressed()),this,SLOT(loadNavigate()));

    //设置ActiveX控件为IEMicrosoft Web Browser
    //设置ActiveX控件的id,最有效的方式就是使用UUID
    //此处的{8856F961-340A-11D0-A96B-00C04FD705A2}就是Microsoft Web Browser控件的UUID
    ui->axWidget->setControl(QString::fromUtf8("{8856F961-340A-11D0-A96B-00C04FD705A2}"));
    //ui->axWidget->setObjectName(QString::fromUtf8("webWidget"));//设置控件的名称
    //ui->axWidget->setFocusPolicy(Qt::StrongFocus);//设置控件接收键盘焦点的方式:鼠标单击、Tab键
    //ui->axWidget->setProperty("DisplayAlerts",false); //不显示任何警告信息。
    //ui->axWidget->setProperty("DisplayScrollBars",true); // 显示滚动条

    loadNavigate();

loadNavigate() :

QString Utr = ui->lineEdit->text().trimmed();
ui->axWidget->dynamicCall("Navigate(const QString&)",Utr);

on_pushButton_clicked()  :

QString str = "send()";
QAxObject *document = ui->axWidget->querySubObject("Document");
QAxObject *parentWindow = document->querySubObject("parentWindow");
parentWindow->dynamicCall("execScript(QString,QString)",str,"JavaScript");


// 1
QString x = ui->lineEdit_2->text();
double xx = x.toDouble();
QString y = ui->lineEdit_3->text();
double yy = y.toDouble();

// 2
QString x_2 = ui->lineEdit_4->text();
double xx_2 = x_2.toDouble();
QString y_2 = ui->lineEdit_5->text();
double yy_2 = y_2.toDouble();

// 3
QString x_3 = ui->lineEdit_6->text();
double xx_3 = x_3.toDouble();
QString y_3 = ui->lineEdit_7->text();
double yy_3 = y_3.toDouble();

// 3
QString x_4 = ui->lineEdit_8->text();
double xx_4 = x_4.toDouble(); QString y_4 = ui->lineEdit_9->text(); double yy_4 = y_4.toDouble(); double lon[4], lat[4]; lon[0] = xx; lon[1] = xx_2; lon[2] = xx_3; lon[3] = xx_4; lat[0] = yy; lat[1] = yy_2; lat[2] = yy_3; lat[3] = yy_4; qDebug() << "x :" << xx << " " << "y :" << yy << endl << "x :" << xx_2 << " " << "y :" << yy_2 << endl << "x :" << xx_3 << " " << "y :" << yy_3 << endl << "x :" << xx_4 << " " << "y :" << yy_4 << endl; for (int i = 0; i < 4; i++) { QString command = QString("addpoint(%1,%2)").arg(QString::number(lon[i], 'f', 6)).arg(QString::number(lat[i], 'f', 6)); QAxObject *document = ui->axWidget->querySubObject("Document"); QAxObject *parentWindow = document->querySubObject("parentWindow"); parentWindow->dynamicCall("execScript(QString,QString)",command,"JavaScript"); }

运行后:

 

 

 

不少铁汁需要,我还是放个下载地址吧:

(文件内car.png和my.html文件放在debug目录内)

链接:https://pan.baidu.com/s/1TjSfwowWy8UOjavAIN468A
提取码:0810

 
posted @ 2019-08-21 13:12  一个野指针  阅读(1945)  评论(28编辑  收藏  举报