Android 侧拉菜单时标题做动画

我们在app上或网上经常会看到这样的效果,如图:

Android 侧拉菜单时标题做动画_第1张图片

其实想实现这个效果很简单,需要用到v4包和v7包。

效果分析:

首先,这个效果大体上有ToolBar 和 DrawerLayout组成,所以我们把跟布局设置成LinearLayout 方向设为垂直方向;然后放置v7包中的ToolBar和V4包中的DrawerLayout,然后在DrawerLayout中写好内容区域与侧拉菜单区域,代码如下:

xml代码:


    //这是toolbar
    <android.support.v7.widget.Toolbar
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/toolbar"
        android:fitsSystemWindows="true"
        android:background="@color/colorPrimary"
        android:minHeight="?attr/actionBarSize"
        android:theme="@style/Theme.Drawer.ArrowAnimation" />

    //这是侧拉菜单
    <android.support.v4.widget.DrawerLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/drawer" >

        <TextView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="这是内容区域"
            />

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_gravity="start"
            android:orientation="vertical"
            android:background="@android:color/white"
            >

            <TextView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:text="这是菜单区域"
                android:gravity="center"
                />

        </LinearLayout>

    </android.support.v4.widget.DrawerLayout>

上面代码中的 android:minHeight="?attr/actionBarSize" 属性为系统属性,size跟手机屏幕不同有改变。

引用的主题android:theme="@style/Theme.Drawer.ArrowAnimation"代码如下:

<style name="Theme.Drawer.ArrowAnimation" parent="AppTheme"> <!-- 箭头 --> <item name="drawerArrowStyle">@style/AppTheme.DrawerArrowToggle</item> </style>
    <!-- 箭头颜色 -->
    <style name="AppTheme.DrawerArrowToggle" parent="Base.Widget.AppCompat.DrawerArrowToggle"> <item name="color">@android:color/white</item> </style>

上面的准备工作做好后,在代码中先把ToolBar和DrawerLayout加载出来,然后创建一个ActionBarDrawerToggle类,并重写onPostCreate、onOptionsItemSelected、onConfigurationChanged方法即可,然后就可以编译运行啦!

java代码:


    private Toolbar toolbar;
    private DrawerLayout mDrawerLayout;
    private ActionBarDrawerToggle mActionBarDrawerToggle;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_main);

        toolbar = (Toolbar) findViewById(R.id.toolbar);
        mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer);
        mActionBarDrawerToggle = new ActionBarDrawerToggle(this,mDrawerLayout,toolbar, 0,0);
        mDrawerLayout.setDrawerListener(mActionBarDrawerToggle);

    }

    @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        mActionBarDrawerToggle.syncState();
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if (mActionBarDrawerToggle.onOptionsItemSelected(item)) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    @Override
    public void onConfigurationChanged(Configuration newConfig) {
        super.onConfigurationChanged(newConfig);
        mActionBarDrawerToggle.onConfigurationChanged(newConfig);
    }


OK,教程结束,点击免费下载代码






如果感觉上面效果比较少的话,可以查看这个:

这里写图片描述

GitHub链接:material-menu






Android新手一个,求大神指点~~

你可能感兴趣的:(android,动画,toolbar)