張萌&韓墨羽——Toolbar和DrawerLayout+SlideMenu 2種方式實現抽屜側滑

Toolbar和DrawerLayout+SlideMenu 2種方式實現抽屜側滑

效果圖
在這裏插入圖片描述
一.ToolBar常用的方法
二.DrawerLayout常用的方法
三.ToolBar和DrawerLayout綁定
四.ToolBar和DrawerLayout代碼
五.SlideMenu實現抽屜
1.SlideMenu的屬性:
2.代碼實現:
效果圖
1.Toolbar和DrawerLayout實現
Toolbar:標題欄
DrawerLayout:可以實現側滑
2.SlideMenu實現 第三方 需要導入moudle(slidemenu)

一.ToolBar常用的方法
Toolbar是在 Android 5.0 開始推出的一個 Material Design 風格的導航控件,以此來取代之前的Actionbar 。我們需要在工程中引入appcompat-v7的兼容包以便向下兼容, 使用android.support.v7.widget.Toolbar進行開發。在設計 Toolbar 的時候,Google也留給了開發者很多可定製修改的餘地,這些可定製修改的屬性在API文檔中都有詳細介紹,如:

1.supportRequestWindowFeature(Window.FEATURE_NO_TITLE);去掉標題欄;
2.Toolbar.setLogo(),設置logo圖片;
3.Toolbar.setTitle().設置標題;
4.Toolbar.setSubTitle()設置子標題;
5.Toolbar.setTitleTextColor(int color);設置標題文字顏色;
6.Toolbar.setSubtitleTextColor();設置子標題文字顏色;
7.setTitleMargin(int start, int top, int end, int bottom);設置標題margin值; 8.onCreateOptionsMenu,getMenuInflater().inflate(R.menu.menu,menu)
設置菜單在給Toolbar設置爲actionbar時使用;
9.Toolbar.setOnMenuItemClickListener();Toolbar綁定menu監聽;
10.Toolbar.inflateMenu(R.menu.menu)在Toolbar沒有替換actionbar時使用;
11.setSupportActionBar(mToolbar);設置toolbar替換actionbar;
12.getLayoutInflater().inflate(R.layout.view_tv,bar);Toolbar添加自定義view

二.DrawerLayout常用的方法
DrawerLayout.isDrawerOpen(Gravity.LEFT)是否開啓;
DrawerLayout.openDrawer(Gravity.LEFT);開啓抽屜
DrawerLayout.closeDrawer(Gravity.RIGHT);關閉抽屜

三.ToolBar和DrawerLayout綁定

private void bindToolBar() {
    //設置開關
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.app_name, R.string.app_name);
    //開啓同步
    toggle.syncState();
    //設置給drawerLayout
    drawerLayout.addDrawerListener(toggle);
}

四.ToolBar和DrawerLayout代碼
(0)先去掉自帶的ActionBar,在清單文件中

(1)佈局文件代碼:activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.day3.MainActivity"
    android:orientation="vertical">
    <android.support.v7.widget.Toolbar
        android:background="#bdbebf"
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="50dp">
    </android.support.v7.widget.Toolbar>
    <android.support.v4.widget.DrawerLayout
        android:id="@+id/drawer_layout"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <!--主界面,必須先寫-->
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center"
            >
            <TextView
                android:text="我是側拉主界面"
                android:textSize="50sp"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />
        </LinearLayout>
        <!--側滑部分  android:layout_gravity="left" 從左側滑出-->
        <LinearLayout
            android:layout_gravity="left"
            android:layout_width="200dp"
            android:layout_height="match_parent"
            android:gravity="center">
            <ListView
                android:id="@+id/lv"
                android:background="#b49797"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"></ListView>
        </LinearLayout>

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


</LinearLayout>

(2)java 代碼:MainActivity.java

public class MainActivity extends AppCompatActivity {
    Toolbar toolbar;
    DrawerLayout drawerLayout;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
      
        setContentView(R.layout.activity_main);
        drawerLayout=findViewById(R.id.drawer_layout);
        initToolBar();//初始化bar
        bindToolBar();//綁定bar
    }
    private void initToolBar() {

        toolbar = findViewById(R.id.toolbar);
        //設置導航圖標.
        toolbar.setNavigationIcon(R.mipmap.ic_launcher);
        //設置toolbar的大標題
        toolbar.setTitle("天氣");
        toolbar.setLogo(R.mipmap.ic_launcher_round);
        //設置toolbar的小標題.
        toolbar.setSubtitle("Android");
      

    }
    //toolbar和drawerLayout綁定實現切換效果
    private void bindToolBar() {
        //設置開關
        ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.app_name, R.string.app_name);
        //開啓同步
        toggle.syncState();
        //設置給drawerLayout
        drawerLayout.addDrawerListener(toggle);
    }
}

五.SlideMenu實現抽屜
1.SlideMenu的屬性:
設置模式: setMode(SlidingMenu.LEFT);
設置觸摸屏幕的模式:setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
//TOUCHMODE_FULLSCREEN全屏;TOUCHMODE_MARGIN邊界;TOUCHMODE_NONE不能滑動
設置左側菜單滑動顯示的內容:slidingMenu.setMenu(R.layout.slide_menu);
設置左側滑動菜單的陰影寬度:slidingMenu.setShadowWidth(300);
設置滑動時的漸變程度:slidingMenu.setFadeDegree(0.5f);範圍0.0f-1.0f
設置淡入淡出的效果:slidingMenu.setFadeEnabled(true);
設置左側滑動菜單的陰影圖片(顏色):setShadowDrawable();
設置滑出時主頁面顯示的剩餘寬度:slidingMenu.setBehindOffset(200);

注意:
(1)attachToActivity():將slidemenu和Activity綁定
(2)setMenu():設置菜單顯示的內容
(3) Button bt = slidingMenu.getMenu().findViewById(R.id.bt1);爲側滑出來的菜單設置事件監聽
2.代碼實現:
(1)導入第三方moudle:slidemenu

(2)activity代碼中是實現

public class SlidingMenuActivity extends AppCompatActivity {
    private SlidingMenu slidingMenu;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sliding_menu);
        initmenu();
    }

    private void initmenu() {
        //TODO 1:創建菜單對象
        slidingMenu=new SlidingMenu(this);
        //TODO 2:設置屬性
        //SlidingMenu.RIGHT   SlidingMenu.LEFT
        slidingMenu.setMode(SlidingMenu.LEFT);//設置從哪邊出來
        //TOUCHMODE_FULLSCREEN全屏;TOUCHMODE_MARGIN邊界;TOUCHMODE_NONE不能滑動
        slidingMenu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);//在屏幕的任何位置左滑都可以顯示出來
        slidingMenu.setBehindOffset(200);//單位是像素px 側滑菜單滑出後,界面剩餘的寬度。
        slidingMenu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT);//綁定到指定的Context
        //TODO 3:設置佈局並且相應佈局上面的按鈕
      View view = LayoutInflater.from(this).inflate(R.layout.slide, null);
Button button=view.findViewById(R.id.bt_close);
button.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        //關閉抽屜
       // slidingMenu.showMenu();//顯示抽屜
        slidingMenu.showContent();//顯示主頁面
    }
});
slidingMenu.setMenu(view);//設置佈局        //TODO 4:設置監聽listener,監聽側滑菜單的打開和關閉.
        slidingMenu.setOnOpenedListener(new SlidingMenu.OnOpenedListener() {
            @Override
            public void onOpened() {
                Toast.makeText(SlidingMenuActivity.this, "打開了", Toast.LENGTH_SHORT).show();
            }
        });
        slidingMenu.setOnClosedListener(new SlidingMenu.OnClosedListener() {
            @Override
            public void onClosed() {
                Toast.makeText(SlidingMenuActivity.this, "側滑菜單關閉", Toast.LENGTH_SHORT).show();
            }
        });
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章