閱讀775 返回首頁    go 技術社區[雲棲]


教你如何創建類似QQ的android彈出菜單

大家可能看到android的自帶的係統菜單比較難看,如圖:
圖片1.png
很多應用都自己定義了係統菜單,
QQ遊覽器
圖片2.png
手機QQ
圖片3.png
我今天做的就是類似手機QQ的菜單,效果圖如下:
圖片4.png
這是我用PopupWindow重寫一個菜單 ,popupwindow實現彈出菜單功能非常實用,在有布局中經常出現,給用戶體驗非常不錯 ,主要是控製菜單的顯示和消失(動畫控製),另外對文字和圖片(大小最好都一樣,否則最後效果有點難看)分別做了適配,其中對文字的長度進行了處理。
下麵不用多說,進行代碼.需要提一下的是,屏蔽一下係統菜單,需要下麵兩步1. 需要創建至少一個係統菜單選項
圖片5.png
2. 在onMenuOpened方法裏顯示自己的菜單視圖,並返回FALSE圖片6.png 整體代碼:MenuLikeQQActivity.java
  1. package cn.mxgsa.menu;

  2. import java.util.List;
  3. import android.app.Activity;
  4. import android.os.Bundle;
  5. import android.view.Gravity;
  6. import android.view.KeyEvent;
  7. import android.view.Menu;
  8. import android.view.View;
  9. import android.view.ViewGroup.LayoutParams;
  10. import android.widget.AdapterView;
  11. import android.widget.AdapterView.OnItemClickListener;
  12. import android.widget.GridView;
  13. import android.widget.PopupWindow;
  14. import android.widget.Toast;

  15. public class MenuLikeQQActivity extends Activity {
  16.         
  17.         /**
  18.          * 定義popupwindow
  19.          */        
  20.         private PopupWindow popup;
  21.         /**
  22.          * 定義適配器
  23.          */
  24.         private MenuAdapter menuAdapter;
  25.         //菜單項列表
  26.         private List<MenuInfo> menulists;
  27.         //定義gridview
  28.         private GridView menuGridView;
  29.         
  30.         
  31.     /** Called when the activity is first created. */
  32.     @Override
  33.     public void onCreate(Bundle savedInstanceState) {
  34.         super.onCreate(savedInstanceState);
  35.         setContentView(R.layout.main);
  36.         initPopuWindows();
  37.     }
  38.     
  39.         @Override
  40.         public boolean onCreateOptionsMenu(Menu menu) {
  41.                 // TODO Auto-generated method stub
  42.                 return true;
  43.         }
  44.     
  45.         /**
  46.          * 設置PopupWindows
  47.          */
  48.     private void initPopuWindows() {
  49.             //初始化gridview
  50.                 menuGridView=(GridView)View.inflate(this, R.layout.gridview_menu, null);
  51.                 //初始化PopupWindow,LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT控製顯示
  52.                 popup = new PopupWindow(menuGridView, LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);
  53.                 // 設置menu菜單背景
  54.                 popup.setBackgroundDrawable(getResources().getDrawable(R.drawable.menu_background));
  55.                 // menu菜單獲得焦點 如果沒有獲得焦點menu菜單中的控件事件無法響應
  56.                 popup.setFocusable(true);
  57.                 //設置顯示和隱藏的動畫
  58.                 popup.setAnimationStyle(R.style.menushow);
  59.                 popup.update();
  60.                 //設置觸摸獲取焦點
  61.                 menuGridView.setFocusableInTouchMode(true);
  62.                 //設置鍵盤事件,如果按下菜單鍵則隱藏菜單
  63.                 menuGridView.setOnKeyListener(new android.view.View.OnKeyListener() {
  64.                         public boolean onKey(View v, int keyCode, KeyEvent event) {
  65.                                 // TODO Auto-generated method stub
  66.                                 if ((keyCode == KeyEvent.KEYCODE_MENU) && (popup.isShowing())) {
  67.                                         popup.dismiss();  
  68.                                         return true;
  69.                                         
  70.                                 }
  71.                                 return false;
  72.                         }

  73.                 });
  74.                 //添加菜單按鈕事件
  75.                 menuGridView.setOnItemClickListener(new OnItemClickListener() {
  76.                         public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
  77.                                 // TODO Auto-generated method stub
  78.                                 MenuInfo mInfo = menulists.get(arg2);
  79.                                 popup.dismiss();
  80.                                 if (mInfo.ishide) {
  81.                                         return;
  82.                                 }
  83.                                 switch (mInfo.menuId) {
  84.                                 case MenuUtils.MENU_ADD_FRIEND:
  85.                                         Toast.makeText(MenuLikeQQActivity.this, "添加好友", 1).show();
  86.                                         break;
  87.                                 case MenuUtils.MENU_ADD_GROUP:
  88.                                         Toast.makeText(MenuLikeQQActivity.this, "添加分組", 1).show();
  89.                                         break;
  90.                                 case MenuUtils.MENU_EXIT:
  91.                                         Toast.makeText(MenuLikeQQActivity.this, "退出應用", 1).show();
  92.                                         break;
  93.                                 case MenuUtils.MENU_GROUP_ACCURATE:

  94.                                         break;
  95.                                 case MenuUtils.MENU_GROUP_CATEGORY:

  96.                                         break;
  97.                                 case MenuUtils.MENU_HELP:
  98.                                         Toast.makeText(MenuLikeQQActivity.this, "檢查更新", 1).show();

  99.                                         break;
  100.                                 case MenuUtils.MENU_LOGOUT:
  101.                                         Toast.makeText(MenuLikeQQActivity.this, "切換用戶", 1).show();
  102.                                         break;
  103.                                 case MenuUtils.MENU_SERCH_FRIEND:
  104.                                         Toast.makeText(MenuLikeQQActivity.this, "搜索好友", 1).show();
  105.                                         break;
  106.                                 case MenuUtils.MENU_SETTING:
  107.                                         Toast.makeText(MenuLikeQQActivity.this, "設置", 1).show();
  108.                                         break;
  109.                                 }
  110.                         }
  111.                 });
  112.         }
  113.     
  114.     @Override
  115.         public boolean onMenuOpened(int featureId, Menu menu) {
  116.                 // TODO Auto-generated method stub
  117.                 if (popup != null) {
  118.                         menulists = MenuUtils.getMenuList();
  119.                         menuAdapter = new MenuAdapter(this, menulists);
  120.                         menuGridView.setAdapter(menuAdapter);
  121.                         popup.showAtLocation(this.findViewById(R.id.linearlayout), Gravity.BOTTOM, 0, 0);
  122.                 }
  123.                 return false;// 返回為true 則顯示係統menu
  124.         }

  125.         @Override
  126.         public boolean onPrepareOptionsMenu(Menu menu) {
  127.                 // TODO Auto-generated method stub
  128.                 menu.add("menu");
  129.                 return super.onPrepareOptionsMenu(menu);
  130.         }
  131. }
複製代碼

講述的很簡單,需要對大家有幫助下麵附應用的源碼  MenuLikeQQ.rar (149.85 KB, 下載次數: 2566) 

最後更新:2017-04-02 16:48:08

  上一篇:go javascript中未初始化的變量和未定義的變量的區別
  下一篇:go android自定義menu,PopUpWindow彈出菜單