• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Codejie's C++ Space

            Using C++

            Android DEV : Show a window on Baidu Map

             

                周末同學說想弄個基于Baidu地圖的應用, 于是就開始研究這個SDK來. 其中應用有個需求, 需要點擊地圖上的標記時, 顯示一組按鈕. 于是按照常規的作法失業了InfoWindow, 如下.

                //panel is a view, some buttons in it.
                final InfoWindow iw = new InfoWindow(panel, marker.getPosition(), null);
                //getMap() return BaiduMap
                activity.getMap().showInfoWindow(iw);
             

             

                倒是不難, 但處理點擊事件時發現有問題了. 根據文檔, 此時顯示出來的InfoWindow實際是View的Bitmap圖片, 也就意味著根本沒法區分View上的Buttons了, 更別說能處理Button的點擊事件了. 怪不得, 文檔中對于整個InfoWindow只有一個ClickListener, 還不含有View信息.

                這樣只能"曲線救國"了, InfoWindow不能用, 那就直接在MapView中彈出個PopupWindow吧. (順手敲打測試代碼, 就記錄用)

             

                final View panel = UserPanel.make(activity);
                Point p = activity.getMap().getProjection().toScreenLocation(marker.getPosition());
            
                final PopupWindow pw = new PopupWindow(panel);
                pw.setWidth(ViewGroup.LayoutParams.WRAP_CONTENT);
                pw.setHeight(ViewGroup.LayoutParams.WRAP_CONTENT);
                pw.setFocusable(true);
                pw.setOutsideTouchable(true);
                //getMapView() return MapView, not BaiduMap any more
                pw.showAtLocation(activity.getMapView(), Gravity.LEFT | Gravity.BOTTOM,p.x, p.y );
            
                final Button btn = (Button) panel.findViewById(R.id.button2);
                btn.setOnClickListener(new View.OnClickListener() {
                    @Override
                    public void onClick(View view) {
                        pw.dismiss();
                    }
                });

             

                搞定,人長個腦袋總是有用的...

             

                測試中發現個問題, 如果地圖發生放縮, Window彈出的位置會不準確, 很是奇怪, 按理MapView發生變化時, 其Projection應該能夠實時跟隨變化的, 這個問題回頭需要再看看.

                <---- 回過頭的分割線 ---->
                位置不準確的問題是由于View和Screen坐標系不同, 以及MapView自身size共同影響的, 錯怪了Projection了..

            posted on 2014-06-18 20:22 codejie 閱讀(2419) 評論(0)  編輯 收藏 引用 所屬分類: G7

            公告

            Using C++

            導航

            統計

            留言簿(73)

            隨筆分類(513)

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            97精品久久天干天天天按摩| 久久久久亚洲AV成人片| 精品久久久久久久中文字幕| 久久久不卡国产精品一区二区| 久久久久无码专区亚洲av| 91精品国产91久久久久久| 亚洲国产天堂久久综合| 久久婷婷五月综合色奶水99啪| 91亚洲国产成人久久精品网址| 亚洲另类欧美综合久久图片区| 成人综合伊人五月婷久久| 久久久久国产精品嫩草影院| 久久这里只有精品18| 伊人久久大香线蕉AV一区二区| 亚洲国产天堂久久综合| 少妇久久久久久被弄高潮| 久久99国产精品久久99果冻传媒| 久久久艹| 久久精品国产乱子伦| 精品一区二区久久| 亚洲国产精品无码久久久蜜芽 | 亚洲狠狠久久综合一区77777| 精品人妻伦一二三区久久| 久久综合给久久狠狠97色| 最新久久免费视频| 久久久久久无码国产精品中文字幕| 97精品依人久久久大香线蕉97| 免费一级做a爰片久久毛片潮| 国产精品一久久香蕉产线看| 伊人久久大香线蕉AV色婷婷色| 污污内射久久一区二区欧美日韩| 国产高潮久久免费观看| 久久综合丝袜日本网| 久久99久久99小草精品免视看| 97久久综合精品久久久综合| 九九精品99久久久香蕉| 久久99精品国产自在现线小黄鸭 | 欧美日韩中文字幕久久久不卡| 国产精品久久久久乳精品爆| 久久精品成人| 欧美亚洲另类久久综合婷婷|