Android Drawerlayout實現(xiàn)側滑菜單效果
更新時間:2017年10月24日 16:10:32 作者:污鴉
這篇文章主要為大家詳細介紹了Android Drawerlayout實現(xiàn)側滑菜單效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Drawerlayout側滑菜單的具體代碼,供大家參考,具體內容如下
1、Drawerlayout的xml布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="animtest.com.example.e531.drawerlayout_demo.MainActivity">
<!--側拉菜單-->
<android.support.v4.widget.DrawerLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/drlayout">
<!--主頁面的布局-->
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/fcontent">
</FrameLayout>
<!--拉菜單的布局 android:layout_gravity="start" 菜單在左邊 end 菜單在右邊 -->
<RelativeLayout
android:layout_width="240dp"
android:layout_height="match_parent"
android:layout_gravity="end"
android:background="#ffff00"
android:id="@+id/rel">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@mipmap/ic_launcher"
android:id="@+id/img"/>
<ListView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/lv"
android:layout_below="@id/img"></ListView>
</RelativeLayout>
</android.support.v4.widget.DrawerLayout>
</RelativeLayout>
2、在Activity中的具體使用方法
package animtest.com.example.e531.drawerlayout_demo;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.RelativeLayout;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private ListView listView;
private DrawerLayout drawerLayout;
private RelativeLayout rel;
private List<String> datas;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//查找組件
drawerLayout = (DrawerLayout) findViewById(R.id.drlayout);
listView = (ListView) findViewById(R.id.lv);
rel = (RelativeLayout) findViewById(R.id.rel);
//構造數(shù)據(jù)
datas = new ArrayList<String>();
for(int i=0;i<10;i++){
datas.add("菜單"+i);
}
//設置數(shù)組適配器
ArrayAdapter<String> adapter=new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1, datas);
listView.setAdapter(adapter);
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
//關閉側滑菜單
drawerLayout.closeDrawer(rel);
//drawerLayout.openDrawer(rel);//打開側滑菜單
//設置參數(shù)
ContentFragment contentFragment=new ContentFragment();
Bundle bundle=new Bundle();
bundle.putString("value",datas.get(position));
contentFragment.setArguments(bundle);
//切換fragment
getSupportFragmentManager().beginTransaction().replace(R.id.fcontent,contentFragment).commit();
}
});
drawerLayout.setDrawerListener(new DrawerLayout.DrawerListener() {
//slideOffset:側滑菜單 寬度的像素值
@Override
public void onDrawerSlide(View drawerView, float slideOffset) {
}
@Override
public void onDrawerOpened(View drawerView) {
Log.d("zzz","open");
}
@Override
public void onDrawerClosed(View drawerView) {
Log.d("zzz","close");
}
@Override
public void onDrawerStateChanged(int newState) {
Log.d("zzz","狀態(tài)改變:"+newState);
}
});
}
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
相關文章
Android編程實現(xiàn)EditText字數(shù)監(jiān)聽并顯示的方法
這篇文章主要介紹了Android編程實現(xiàn)EditText字數(shù)監(jiān)聽并顯示的方法,涉及Android EditText文本框事件監(jiān)聽與響應相關操作技巧,需要的朋友可以參考下2017-02-02
Android自定義View實現(xiàn)搜索框(SearchView)功能
這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)搜索框SearchView功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11
Android viewpager自動輪播和小圓點聯(lián)動效果
這篇文章主要為大家詳細介紹了Android viewpager自動輪播和小圓點聯(lián)動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
Android控件gridview實現(xiàn)單行多列橫向滾動效果
這篇文章主要為大家詳細介紹了Android控件gridview實現(xiàn)單行多列橫向滾動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12

