package com.example.navigationdrawer5;
import java.util.Locale;
import android.app.Activity;
import android.app.Fragment;
import android.app.SearchManager;
import android.content.Intent;
import android.content.res.Configuration;
import android.content.res.Resources;
import android.os.Bundle;
import android.support.v4.app.ActionBarDrawerToggle;
import android.support.v4.widget.DrawerLayout;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.Toast;
public class DrawerActivity extends Activity {
private DrawerLayout drawerLayout;
private ActionBarDrawerToggle drawerToggle;
private ListView drawerList;
private String[] planetTitles;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_drawer);
planetTitles = getResources().getStringArray(R.array.planets_array);
drawerLayout = (DrawerLayout) findViewById(R.id.drawerLayout);
drawerList = (ListView) findViewById(R.id.drawerList);
drawerList.setAdapter(new ArrayAdapter<String>(this, R.layout.drawer_list_item, planetTitles));
drawerList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
selectItem(position);
}
});
getActionBar().setDisplayHomeAsUpEnabled(true);
getActionBar().setHomeButtonEnabled(true);
drawerToggle = new ActionBarDrawerToggle(
this,
drawerLayout,
R.drawable.ic_drawer,
R.string.drawer_open,
R.string.drawer_close) {
@Override
public void onDrawerClosed(View drawerView) {
int position = drawerList.getCheckedItemPosition();
getActionBar().setTitle(planetTitles[position]);
invalidateOptionsMenu();
super.onDrawerClosed(drawerView);
}
@Override
public void onDrawerOpened(View drawerView) {
getActionBar().setTitle(R.string.app_name);
invalidateOptionsMenu();
super.onDrawerOpened(drawerView);
}
};
drawerLayout.setDrawerListener(drawerToggle);
if (savedInstanceState == null) {
selectItem(0);
}
}
private void selectItem(int position) {
Fragment fragment = new DrawerFragment();
Bundle args = new Bundle();
args.putInt(DrawerFragment.ARG_PLANET_ID, position);
fragment.setArguments(args);
getFragmentManager().beginTransaction().replace(R.id.contentFrame, fragment).commit();
drawerList.setItemChecked(position, true);
drawerLayout.closeDrawer(drawerList);
getActionBar().setTitle(planetTitles[position]);
}
@Override
protected void onPostCreate(Bundle savedInstanceState) {
super.onPostCreate(savedInstanceState);
//5、必须在此处同步状态
drawerToggle.syncState();
}
@Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
drawerToggle.onConfigurationChanged(newConfig);
}
@Override
public boolean onPrepareOptionsMenu(Menu menu) {
boolean isDrawerOpen = drawerLayout.isDrawerOpen(drawerList);
menu.findItem(R.id.action_search).setVisible(!isDrawerOpen);
return super.onPrepareOptionsMenu(menu);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.drawer, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
//6.需要在此处调用触发器处理下action bar上的item选择事件
if (drawerToggle.onOptionsItemSelected(item)) {
return true;
}
switch (item.getItemId()) {
case R.id.action_search:
Intent intent = new Intent(Intent.ACTION_WEB_SEARCH);
intent.putExtra(SearchManager.QUERY, getActionBar().getTitle());
if (intent.resolveActivity(getPackageManager()) != null) {
startActivity(intent);
} else {
Toast.makeText(this, "没找到浏览器", Toast.LENGTH_LONG).show();
}
break;
}
return super.onOptionsItemSelected(item);
}
public static class DrawerFragment extends Fragment {
private static final String ARG_PLANET_ID = "planet_id";
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
ImageView view = (ImageView) inflater.inflate(R.layout.drawer_content, container, false);
Resources res = getActivity().getResources();
int planetId = getArguments().getInt(ARG_PLANET_ID);
int imageid = res.getIdentifier(res.getStringArray(R.array.planets_array)[planetId].toLowerCase(Locale.getDefault()), "drawable", getActivity().getPackageName());
view.setImageResource(imageid);
return view;
}
}
}
<!-- 1、使用android.support.v4.widget.DrawerLayout布局 -->
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/drawerLayout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<FrameLayout
android:id="@+id/contentFrame"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<!-- 2、左侧滑出的list,宽度需要固定下,不要满屏 -->
<!-- 3、 android:layout_gravity="start"-->
<!-- 4、 android:choiceMode="singleChoice"-->
<ListView
android:id="@+id/drawerList"
android:layout_width="180dp"
android:layout_height="match_parent"
android:layout_gravity="start"
android:background="#111"
android:choiceMode="singleChoice"/>
</android.support.v4.widget.DrawerLayout>
分享到:
相关推荐
使用ToolBar和Drawlayout实现侧滑栏并且修改默认图标
DrawLayout侧边栏效果实现的代码
android Drawlayout 左右侧滑动菜单
DrawLayout结合ToolBar实现带动画的菜单
这套代码实现了状态栏完全透明的沉侵式效果
drawlayout覆盖在statusBar之上的Drawlayout,statusBar颜色可设置。
Fragment的嵌套和侧滑菜单DrawLayout加标签页SlidingTabLayout或PagerTabStrip的使用demo. Android studio项目
DrawLayout简单使用实例.rar,太多无法一一验证是否可用,程序如果跑不起来需要自调,部分代码功能进行参考学习。
android 的Draw
想做一个APP,设计中有侧边栏这个功能,所以现在开始学习下侧边栏的实现。 在官方的UI空间中已经给出了DrawerLayout这个侧滑的菜单空间。 因为在使用DrawerLayout的时候遇到了些问题,花了一天是时间才搞定,这里来...
主要为大家详细介绍了一个简单的toolabar结合drawlayout的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
It has smooth zoom-in, zoom-out animation when switched from one fragment to another. Still in Active Development. Version Installation Gradle Add it in your root build.gradle at the end of ...
NULL 博文链接:https://429899791.iteye.com/blog/2420478
这是使用Drawerlayout实现的双向侧滑菜单,代码很简单易懂
每天提供一张精选的妹纸图片,一个精选的休息视频,几个精选的Android,ios,web等方面的技术干货 屏幕截图 下载 最近版本是 应用设计 用户界面 App基本包含以下几个页面: 主页显示今日的一些干货内容,纳入与干货...
在前一张中我们并没有使用drawLayout.setDrawerListener(); 对应的参数对象就是DrawerLayout.DrawerListener: public interface DrawerListener { void onDrawerSlide(View var1, float var2); void ...
DrawLayout这个自定义的空间很常见,qq,网易新闻,知乎等等,都有这种效果,那这种效果是怎样实现的呢?本篇博客将带你来怎样实现它。