• 打造属于自己的安卓menu


    首先,我们来看看这张图吧


    看下面的menu菜单,是原装的菜单,好丑陋哦,类似于小编这么爱美的人来说,纯粹就是天大的打击,接受不起。于是,小编就发奋图强,努力,努力,再努力,终于,将菜单改的漂亮了一点,不信你看看。


    看到了吧,面对这么漂亮的menu菜单你怎么会不心动呢?心动不如行动,仔细看看下面我是怎么实现的吧:

    新建一布局文件menu_main.xml,源代码如下:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout
    	android:id="@+id/widget32"
    	android:layout_width="fill_parent"
    	android:layout_height="fill_parent"
    	android:orientation="vertical"
    	xmlns:android="http://schemas.android.com/apk/res/android">
    	<LinearLayout
    		android:id="@+id/widget33"
    		android:layout_width="fill_parent"
    		android:layout_height="wrap_content"
    		android:padding="5dp"
    		android:background="@drawable/menu_bg"
    		android:layout_gravity="center_horizontal">
    		<LinearLayout
    			android:id="@+id/menu_update_btn"
    			android:layout_width="wrap_content"
    			android:layout_height="wrap_content"
    			android:orientation="vertical"
    			android:gravity="center"
    			android:layout_weight="1"
    			android:background="@drawable/menu_btn_bg"
    			android:layout_gravity="center_horizontal">
    			<ImageView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:src="@drawable/btn_update" />    			   
        		<TextView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:text="更新系统" 
    	    		android:textColor="#eee"/> 
    		</LinearLayout>
    		<LinearLayout
    			android:id="@+id/menu_aboutus_btn"
    			android:layout_width="wrap_content"
    			android:layout_height="wrap_content"
    			android:orientation="vertical"
    			android:gravity="center"
    			android:layout_weight="1"
    			android:background="@drawable/menu_btn_bg"
    			android:layout_gravity="center_horizontal">
    			<ImageView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:src="@drawable/btn_aboutus" />    			   
        		<TextView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:text="关于我们" 
    	    		android:textColor="#eee"/>  
    		</LinearLayout>
    		<LinearLayout
    			android:id="@+id/menu_systeminf_btn"
    			android:layout_width="wrap_content"
    			android:layout_height="wrap_content"
    			android:orientation="vertical"
    			android:gravity="center"
    			android:layout_weight="1"
    			android:background="@drawable/menu_btn_bg"
    			android:layout_gravity="center_horizontal">
    			<ImageView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:src="@drawable/btn_systeminf" />    			   
        		<TextView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:text="系统信息" 
    	    		android:textColor="#eee"/> 
    		</LinearLayout>
    		<LinearLayout
    			android:id="@+id/menu_close_btn"
    			android:layout_width="wrap_content"
    			android:layout_height="wrap_content"
    			android:orientation="vertical"
    			android:gravity="center"
    			android:layout_weight="1"
    			android:background="@drawable/menu_btn_bg"
    			android:layout_gravity="center_horizontal">
    			<ImageView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:src="@drawable/btn_close" />    			   
        		<TextView 
    	    	    android:layout_width="wrap_content" 
    	    		android:layout_height="wrap_content" 
    	    		android:text="退出系统" 
    	    		android:textColor="#eee"/>  
    		</LinearLayout>
    	</LinearLayout>
    </LinearLayout>

    布局完成之后,在想要出现menu的Activity添加onKeyDown事件,代码为:

    public boolean onKeyDown(int keyCode, KeyEvent event) 
        {
        	if (keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) 
        	{  //获取 back键    		
            	if(menu_display)
            	{
            		//如果 Menu已经打开 ,先关闭Menu
            		menuWindow.dismiss();
            		menu_display = false;
            	}
            	else 
            	{
            		Intent intent = new Intent();
                	intent.setClass(MainActivity.this,ExitActivity.class);
                	startActivity(intent);
            	}
        	}
        	
        	else if(keyCode == KeyEvent.KEYCODE_MENU)
        	{   //获取 Menu键			
    			if(!menu_display)
    			{
    				//获取LayoutInflater实例
    				inflater = (LayoutInflater)this.getSystemService(LAYOUT_INFLATER_SERVICE);
    				//这里的main布局是在inflate中加入的哦,以前都是直接this.setContentView()的吧?呵呵
    				//该方法返回的是一个View的对象,是布局中的根
    				layout = inflater.inflate(R.layout.menu_main, null);
    				
    				//下面我们要考虑了,我怎样将我的layout加入到PopupWindow中呢???很简单
    				menuWindow = new PopupWindow(layout,LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT); //后两个参数是width和height
    				//menuWindow.showAsDropDown(layout); //设置弹出效果
    				//menuWindow.showAsDropDown(null, 0, layout.getHeight());
    				menuWindow.showAtLocation(this.findViewById(R.id.mainmymusic), Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 0, 0); //设置layout在PopupWindow中显示的位置
    				//如何获取我们main中的控件呢?也很简单
    				mUpdateBtn=(LinearLayout)layout.findViewById(R.id.menu_update_btn);
    				mAboutusBtn=(LinearLayout)layout.findViewById(R.id.menu_aboutus_btn);
    				mSysteminfBtn=(LinearLayout)layout.findViewById(R.id.menu_systeminf_btn);						
    				mCloseBtn = (LinearLayout)layout.findViewById(R.id.menu_close_btn);
    								
    				//下面对每一个Layout进行单击事件的注册吧。。。
    				//比如单击某个MenuItem的时候,他的背景色改变
    				//事先准备好一些背景图片或者颜色
    				mUpdateBtn.setOnClickListener (new View.OnClickListener() {					
    					public void onClick(View arg0) {						
    						Toast.makeText(MainActivity.this, "没有更新的系统版本", Toast.LENGTH_LONG).show();
    			        	menuWindow.dismiss(); //响应点击事件之后关闭Menu
    					}
    				});
    				
    				mAboutusBtn.setOnClickListener (new View.OnClickListener() {					
    					public void onClick(View arg0) {						
    						Toast.makeText(MainActivity.this, "我们是一个民间组织哦~~", Toast.LENGTH_LONG).show();
    			        	menuWindow.dismiss(); //响应点击事件之后关闭Menu
    					}
    				});
    				
    				mSysteminfBtn.setOnClickListener (new View.OnClickListener() {					
    					public void onClick(View arg0) {						
    						Toast.makeText(MainActivity.this, "我的随身听音乐", Toast.LENGTH_LONG).show();
    			        	menuWindow.dismiss(); //响应点击事件之后关闭Menu
    					}
    				});
    				
    				mCloseBtn.setOnClickListener (new View.OnClickListener() {					
    					public void onClick(View arg0) {						
    						//Toast.makeText(Main.this, "退出", Toast.LENGTH_LONG).show();
    						Intent intent = new Intent();
    			        	intent.setClass(MainActivity.this,ExitActivity.class);
    			        	startActivity(intent);
    			        	menuWindow.dismiss(); //响应点击事件之后关闭Menu
    					}
    				});	
    				
    				
    				menu_display = true;			
    			}
    			else
    			{
    				//如果当前已经为显示状态,则隐藏起来
    				menuWindow.dismiss();
    				menu_display = false;
    			}			
    			return false;
    		}
        	return false;
        }

    上面,还需要定义几个变量,需要定义的变量为:

    private LinearLayout mCloseBtn,mSysteminfBtn,mAboutusBtn,mUpdateBtn;
    private boolean menu_display = false;
    private PopupWindow menuWindow;
    private LayoutInflater inflater;
    private View layout;
    至此,漂亮的menu出来了,心动了吧?那就赶紧打开自己的工程试试吧……

  • 相关阅读:
    css之盒子模型
    meta小结
    css小结
    html标签及用法小结
    Css基础(2)
    Css基础(1)
    Html基础(2)
    Html基础(1)
    Markdown基础
    演示二
  • 原文地址:https://www.cnblogs.com/lzugis/p/6539915.html
Copyright © 2020-2023  润新知