<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    super

    android中點中overlay彈出帶尾巴的氣泡的實現(xiàn)




    就是上面的樣子

    做這個過程中我碰到兩個問題:
    1:如何做帶尾巴的氣泡View
    2:如何把這個View添加到MapView中.


    1:如何做帶尾巴的氣泡View
    我是采用背景圖的方式來實現(xiàn)的.當然,普通的PNG在View 縮放的時候會失真,尤其是那個尖尖的尾巴.
    后來采用9.png的格式,才完成了不變形的效果.9.png格式的Png可以用SDK\Tools\draw9patch.bat來處理,只要把普通的png的邊上標志一下就可以了,具體draw9patch.bat如何使用這里就不說了,網(wǎng)上有很多文檔,自己查查就知道了.
    我生成的9.png就是下面這個樣子,注意四周的黑線.就是9png拉伸時的標識


    有了這個png,直接放到你的工程下的res/drawable目錄就可以了,
    然后在res/layout目錄下建立你的view的xml文件,比如叫overlay_pop.xml,我的是這樣的:

    <?xml version="1.0" encoding="UTF-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
     android:orientation="vertical"
     android:background="@drawable/bubble_background" <!--這就是那個9.png-->
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:paddingLeft="5px"
     android:paddingTop="5px"
     android:paddingRight="5px"
     android:paddingBottom="20px"    <!--注意加上padding,否則view里面的東西就畫到邊框上了-->
       >
        <TextView android:id="@+id/map_bubbleTitle"
           android:ellipsize="marquee"
           android:layout_width="match_parent"
           android:layout_height="wrap_content"
           android:gravity="center_horizontal"
           android:singleLine="true"
           style="@style/map_BubblePrimary" /> <!--style可以沒有,我這里第一個TextView表示標題,用的是大字體-->
        <TextView  android:id="@+id/map_bubbleText"
           android:layout_width="match_parent"
           android:layout_height="wrap_content"
           android:singleLine="false"
           style="@style/map_BubbleSecondary" /><!--style可以沒有,我這里第二個TextView表示描述信息,用的是大字體-->
    </LinearLayout>


    這樣popView就建立好了


    2:如何把這個View添加到MapView中.
    通常是在mapView中點擊某個位置,彈出popView
    或者點擊某個Overlay彈出popView,這里用點擊Overlay來說明,

    overlay有onTap()方法,你可以實現(xiàn)自己的overlay,overideonTap()方法,彈出popView,
    也可以使用setOnFocusChangeListener(),在listener中實現(xiàn)彈出popView,.
    我是用的listener,因為setOnFocusChangeListener在失去焦點也會觸發(fā),我可以再失去焦點的時候隱藏popView.

    MapView是繼承自ViewGroup的,因此,MapView有addView()方法,同時還有MapView.LayoutParams
    MapView.LayoutParams 可以根據(jù)GeoPoint來定位,我就是利用這個特性來定位彈出的popView的.

    PointItemizedOverlay overlay = new PointItemizedOverlay(drawable); <!--這是我繼承自ItemizedOverlay的overlay,主要就是畫一個圖片,寫一個名稱,很簡單,這里不貼具體代碼了-->

    public class BaseMapActivity extends MapActivity {

     /**
      * 地圖View
      */
     protected MapView mapView;

     /**
      * 彈出的氣泡View
      */
     private View popView;
    /**
        監(jiān)聽器
    */
     private final ItemizedOverlay.OnFocusChangeListener onFocusChangeListener = new ItemizedOverlay.OnFocusChangeListener() {

      @Override
      public void onFocusChanged(ItemizedOverlay overlay, OverlayItem newFocus) {
          //創(chuàng)建氣泡窗口
     

       if (popView != null) {
          popView.setVisibility(View.GONE);
       }

       if (newFocus != null) {

        MapView.LayoutParams geoLP = (MapView.LayoutParams) popView.getLayoutParams();
        geoLP.point = newFocus.getPoint();//這行用于popView的定位
        TextView title = (TextView) popView.findViewById(R.id.map_bubbleTitle);
        title.setText(newFocus.getTitle());

        TextView desc = (TextView) popView.findViewById(R.id.map_bubbleText);
        if (newFocus.getSnippet() == null || newFocus.getSnippet().length() == 0) {
         desc.setVisibility(View.GONE);
        } else {
         desc.setVisibility(View.VISIBLE);
         desc.setText(newFocus.getSnippet());
        }
        mapView.updateViewLayout(popView, geoLP);
        popView.setVisibility(View.VISIBLE);
       }
      }
     };




         public void onCreate(Bundle savedInstanceState) {
              super.onCreate(savedInstanceState);
                /**
                省略其他代碼
               **/

              //初始化氣泡,并設(shè)置為不可見

           popView = inflater.inflate(R.layout.overlay_popup, null);
           mapView.addView( popView,
                 new MapView.LayoutParams(MapView.LayoutParams.WRAP_CONTENT, MapView.LayoutParams.WRAP_CONTENT,
               null, MapView.LayoutParams.BOTTOM_CENTER));
              //由于我的氣泡的尾巴是在下邊居中的,因此要設(shè)置成MapView.LayoutParams.BOTTOM_CENTER.
              //這里沒有給GeoPoint,在onFocusChangeListener中設(shè)置
           views.add(popView);
          popView.setVisibility(View.GONE);

        添加overlay
        PointItemizedOverlay overlay = new PointItemizedOverlay(drawable);
        //設(shè)置顯示/隱藏泡泡的監(jiān)聽器
        overlay.setOnFocusChangeListener(onFocusChangeListener);
        overlay.addOverlay(/*你自己的overlayItem*/);
        overlay.addOverlay(/*你自己的overlayItem*/);
        overlay.addOverlay(/*你自己的overlayItem*/);

        }
    }

    這樣就基本完工了.




    posted on 2010-08-12 15:03 王衛(wèi)華 閱讀(5698) 評論(7)  編輯  收藏 所屬分類: android

    Feedback

    # re: android中點中overlay彈出帶尾巴的氣泡的實現(xiàn)[未登錄] 2010-08-23 14:19 康翌

    您好,能給我一個簡單的關(guān)于在map上點擊標簽彈出一個氣泡提示框的小demo,由于初學(xué),所以您的代碼里面缺少的東西我不知道在那邊能夠不齊,謝謝。
    cumtkangyi@gmail.com  回復(fù)  更多評論   

    # re: android中點中overlay彈出帶尾巴的氣泡的實現(xiàn) 2010-09-24 18:52 yugeng

    你好:
    請問一下文中後段的 views.add(popView); 這是宣告為何呢??
    不是已經(jīng)使用mapview.add(popView,....)了嗎?

    再請教"加overlay"
    PointItemizedOverlay overlay = new PointItemizedOverlay(drawable);
    drawable又是為何宣告呢??

    萬分感激 謝謝  回復(fù)  更多評論   

    # re: android中點中overlay彈出帶尾巴的氣泡的實現(xiàn) 2010-09-28 11:50 yugeng

    @yugeng
    感謝指導(dǎo)....
    我已經(jīng)試出來了...
    thanks  回復(fù)  更多評論   

    # re: android中點中overlay彈出帶尾巴的氣泡的實現(xiàn) 2010-10-13 10:06 bywuyu

    您好能把具體的代碼給我發(fā)一份么?Thx
    bywuyu@gmail.com  回復(fù)  更多評論   

    # re: android中點中overlay彈出帶尾巴的氣泡的實現(xiàn) 2010-10-21 15:39 pl

    我也不懂這里的views.add(popView); 是什么意思?
    幫忙解釋一下,先謝了  回復(fù)  更多評論   

    # re: android中點中overlay彈出帶尾巴的氣泡的實現(xiàn)[未登錄] 2010-11-30 22:37 james

    popView = inflater.inflate(R.layout.overlay_popup, null);
    這句怎么用,看網(wǎng)上解釋的是inflater是用來獲取overlay布局的方法。但是給的例程里你“null”的部分寫的是menu,而且例子是放到onCreateContextMenu(ContextMenu menu)里的,這個倒是可以理解是在menu里在放置自己的布局。  回復(fù)  更多評論   

    # re: android中點中overlay彈出帶尾巴的氣泡的實現(xiàn)[未登錄] 2010-11-30 22:45 james

    知道了,搞錯了用該定義成LayoutInflater inflater = getLayoutInflater();   回復(fù)  更多評論   



    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 成人免费激情视频| 亚洲第一页中文字幕| 一本色道久久88亚洲精品综合 | 97免费人妻在线视频| 男女交性无遮挡免费视频| 亚洲综合久久精品无码色欲| 亚洲色偷偷综合亚洲AVYP| 日韩精品视频免费网址| 69视频在线是免费观看| 国产免费一区二区视频| 一个人看的免费观看日本视频www| 亚洲熟妇无码AV| 亚洲一区电影在线观看| 久久精品国产亚洲AV麻豆网站| 黑人精品videos亚洲人| 亚洲日本一区二区三区在线不卡| 国外成人免费高清激情视频| 在线天堂免费观看.WWW| 亚洲电影免费观看| 四虎影视在线影院在线观看免费视频 | 又大又粗又爽a级毛片免费看| 成人无码区免费视频观看 | 亚洲国产精品久久丫| 亚洲一区二区三区电影| 亚洲av日韩av不卡在线观看| 亚洲欧洲日产国码av系列天堂| 中文字幕无码精品亚洲资源网| 亚洲一区视频在线播放| 亚洲精品国产日韩无码AV永久免费网| 国产美女做a免费视频软件| 午夜神器成在线人成在线人免费| 成年女人免费v片| 成人黄18免费视频| 日韩人妻无码免费视频一区二区三区 | 中文字幕成人免费高清在线视频 | 又粗又大又长又爽免费视频| 青青青国产色视频在线观看国产亚洲欧洲国产综合| 卡一卡二卡三在线入口免费| 午夜时刻免费入口| 永久黄网站色视频免费直播| 免费一级毛片在线观看|