• Android Metro菜单


        今天继续说一下安卓的菜单,之前介绍了:。相信大家对于Metro风格并不陌生,下面就在安卓平台上实现一下这个效果,如图:

                                                     

                实现思路:

                                   利用动画来实现移动的效果,使用的是TranslateAnimation这个方法。先看一下布局文件:

       activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="#000000"
        android:orientation="vertical" >
    
        <!-- 第一层 -->
    
        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1"
            android:orientation="horizontal" >
    
            <!-- 第一层 横向 -->
    
    
            <!-- 第一层 横向左 -->
    
            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:layout_weight="1"
                android:orientation="vertical" >
    
                <LinearLayout
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_weight="1"
                    android:orientation="horizontal" >
    
                    <!-- 1 -->
    
                    <RelativeLayout
                        android:id="@+id/nine_one"
                        android:layout_width="fill_parent"
                        android:layout_height="fill_parent"
                        android:layout_weight="1"
                        android:background="#FFFF00" >
                    </RelativeLayout>
                    <!-- 2 -->
    
                    <RelativeLayout
                        android:id="@+id/nine_two"
                        android:layout_width="fill_parent"
                        android:layout_height="fill_parent"
                        android:layout_weight="1"
                        android:background="#FFC0CB" >
                    </RelativeLayout>
                </LinearLayout>
                <!-- 4 -->
    
                <RelativeLayout
                    android:id="@+id/nine_four"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_weight="1"
                    android:background="#EE30A7" >
                </RelativeLayout>
                <!-- 5 -->
    
                <RelativeLayout
                    android:id="@+id/nine_five"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_weight="1"
                    android:background="#EE4000" >
                </RelativeLayout>
            </LinearLayout>
            <!-- 第一层 横向右 -->
    
            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:layout_weight="2"
                android:orientation="vertical" >
    
                <!-- 3 -->
    
                <RelativeLayout
                    android:id="@+id/nine_three"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_weight="2"
                    android:background="#FF8C69" >
                </RelativeLayout>
                <!-- 6 -->
    
                <RelativeLayout
                    android:id="@+id/nine_six"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_weight="1"
                    android:background="#8C8C8C" >
                </RelativeLayout>
            </LinearLayout>
        </LinearLayout>
        <!-- 第二层 -->
    
        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="3"
            android:baselineAligned="false"
            android:orientation="horizontal" >
    
            <!-- 7 -->
    
            <RelativeLayout
                android:id="@+id/nine_seven"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:layout_weight="1"
                android:background="#8B3E2F" >
            </RelativeLayout>
            <!-- 8 -->
            <!-- 9 -->
    
            <RelativeLayout
                android:id="@+id/nine_nine"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:layout_weight="1"
                android:background="#A52A2A" >
            </RelativeLayout>
        </LinearLayout>
    
    </LinearLayout>

        它的效果是这样的:

                                                                                                         

               之后在MainActivity里面对每一个Layout进行动画移动就可以实现平移的效果了。

    MainActivity.java:

    import android.app.Activity;
    import android.content.Intent;
    import android.os.Bundle;
    import android.util.DisplayMetrics;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.view.Window;
    import android.view.animation.TranslateAnimation;
    import android.widget.RelativeLayout;
    import android.widget.Toast;
    
    /**
     * 
     */
    public class MainActivity extends Activity {
    	private View viewNine;
    	private LayoutInflater inflater;
    	private RelativeLayout nine_one, nine_two, nine_three, nine_four,
    			nine_five, nine_six, nine_seven, nine_nine;
    	private TranslateAnimation myAnimation_Right, myAnimation_Bottom;
    	private TranslateAnimation myAnimation_Left, myAnimation_Top;
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		requestWindowFeature(Window.FEATURE_NO_TITLE);
    		inflater = LayoutInflater.from(this);
    		viewNine = inflater.inflate(R.layout.activity_main, null);
    
    		nine_one = (RelativeLayout) viewNine.findViewById(R.id.nine_one);
    		nine_two = (RelativeLayout) viewNine.findViewById(R.id.nine_two);
    		nine_three = (RelativeLayout) viewNine.findViewById(R.id.nine_three);
    		nine_four = (RelativeLayout) viewNine.findViewById(R.id.nine_four);
    		nine_five = (RelativeLayout) viewNine.findViewById(R.id.nine_five);
    		nine_six = (RelativeLayout) viewNine.findViewById(R.id.nine_six);
    		nine_seven = (RelativeLayout) viewNine.findViewById(R.id.nine_seven);
    		nine_nine = (RelativeLayout) viewNine.findViewById(R.id.nine_nine);
    		setContentView(viewNine);
    
    		nine_four.setOnClickListener(new OnClickListener() {
    
    			@Override
    			public void onClick(View v) {
    
    				Intent intent=new Intent(MainActivity.this,OneActivity.class);
    				startActivity(intent);
    			}
    		});
    		nine_six.setOnClickListener(new OnClickListener() {
    
    			@Override
    			public void onClick(View v) {
    				
    			}
    		});
    		myAnimation();
    		addAnimation(); 
    	}
    
    	// 启动动画
    	private void addAnimation() {
    
    		nine_one.startAnimation(myAnimation_Right);
    		nine_two.startAnimation(myAnimation_Bottom);
    		nine_three.startAnimation(myAnimation_Left);
    		nine_four.startAnimation(myAnimation_Bottom);
    		nine_five.startAnimation(myAnimation_Left);
    		nine_six.startAnimation(myAnimation_Top);
    		nine_seven.startAnimation(myAnimation_Left);
    		nine_nine.startAnimation(myAnimation_Left);
    
    	}
    
    	// 动画定义
    	private void myAnimation() {
    		DisplayMetrics displayMetrics = new DisplayMetrics();
    		displayMetrics = this.getResources().getDisplayMetrics();
    		// 获得屏幕宽度
    		int screenWidth = displayMetrics.widthPixels;
    		// 获得屏幕高度
    		int screenHeight = displayMetrics.heightPixels;
    		
    		myAnimation_Right = new TranslateAnimation(screenWidth, 0, 0, 0);
    		myAnimation_Right.setDuration(1800);
    
    		myAnimation_Bottom = new TranslateAnimation(0, 0, screenHeight, 0);
    		myAnimation_Bottom.setDuration(1500);
    
    		myAnimation_Left = new TranslateAnimation(-screenWidth, 0, 0, 0);
    		myAnimation_Left.setDuration(2000);
    
    		myAnimation_Top = new TranslateAnimation(0, 0, -screenHeight, 0);
    		myAnimation_Top.setDuration(2500);
    	}
    
    	@Override
    	public boolean onCreateOptionsMenu(Menu menu) {
    		// Inflate the menu; this adds items to the action bar if it is present.
    		// getMenuInflater().inflate(R.menu.activity_main, menu);
    		return true;
    	}
    
    }
    

             虽然效果还可以,但是布局文件由于使用嵌套,这样毁造成绘制窗口时性能的问题。所以你对程序要求很严格,那么建议使用RelativewLayout来布局,并且减少使用嵌套。

            下载地址


              

  • 相关阅读:
    基础实验7-2.2 插入排序还是堆排序 (25分)
    进阶实验6-3.1 红色警报 (25分)--并查集
    基础实验3-2.2 单链表分段逆转 (25分)--单链表
    基础实验6-2.2 汉密尔顿回路 (25分)--邻接矩阵
    案例6-1.3 哥尼斯堡的“七桥问题” (25分)--dfs图连通+度判断
    基础实验8-1.1 单身狗 (25分)
    基础实验7-2.3 德才论 (25分)--排序
    基础实验7-2.4 PAT排名汇总 (25分)--结构体排序(快排)
    进阶实验4-3.4 笛卡尔树 (25分)--二叉排序树+堆排序
    基础实验4-2.7 修理牧场 (25分)-堆+哈夫曼树
  • 原文地址:https://www.cnblogs.com/dyllove98/p/3127600.html
Copyright © 2020-2023  润新知