如果您对android–更新材料导航抽屉头和抽屉导航app感兴趣,那么这篇文章一定是您不可错过的。我们将详细讲解android–更新材料导航抽屉头的各种细节,并对抽屉导航app进行深入的分析,此外还有
如果您对android – 更新材料导航抽屉头和抽屉导航app感兴趣,那么这篇文章一定是您不可错过的。我们将详细讲解android – 更新材料导航抽屉头的各种细节,并对抽屉导航app进行深入的分析,此外还有关于(Android)具有多窗格布局的导航抽屉、Android MVP和导航抽屉、android – 删除子部分和导航抽屉子菜单、android – 在导航抽屉中添加图标的实用技巧。
本文目录一览:- android – 更新材料导航抽屉头(抽屉导航app)
- (Android)具有多窗格布局的导航抽屉
- Android MVP和导航抽屉
- android – 删除子部分和导航抽屉子菜单
- android – 在导航抽屉中添加图标
android – 更新材料导航抽屉头(抽屉导航app)
所有这些信息首先由用户在应用程序的第一次启动时定义,因此当mainActivity启动时,图像和名称将加载到标头中.但我正在给用户提供在应用程序内修改这些内容的机会.如果用户转到配置文件frag,并选择新图像作为配置文件图片,或者如果他更改了名称,则此参数将不会在导航抽屉的标题中更新,直到应用程序关闭并再次加载.
这就是我在mainActivity中定义的方式:
public class MainActivity extends AppCompatActivity implements DrawerLayout.DrawerListener { private NavigationView navView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); .... navView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() { @Override public boolean onNavigationItemSelected(MenuItem menuItem) { menuItem.setChecked(true); displayFragment(menuItem.getItemId()); drawerLayout.closeDrawers(); return true; } }); }
没有必要实现DrawerLayout.DrawerListener,但是如上图所示,我已经完成了尝试实时更新标头.这些实现了下一个方法:
@Override public void onDrawerSlide(View drawerView,float slideOffset) { } @Override public void onDrawerOpened(View drawerView) { try { Contextwrapper cw = new Contextwrapper(getApplicationContext()); File directory = cw.getDir("profile",Context.MODE_PRIVATE); File mypath = new File(directory,"thumbnail.png"); Bitmap bitmap = BitmapFactory.decodeStream(new FileInputStream(mypath)); thumbview.setimageBitmap(bitmap); username = mPreferences.getString("NAME",null); nameview.setText(username); } catch (FileNotFoundException e) { Log.e("LOAD_IMAGE",e.getMessage(),e); thumbview.setimageResource(R.drawable.default_thumbnail); } } @Override public void onDrawerClosed(View drawerView) { } @Override public void onDrawerStateChanged(int newState) { }
在onDrawerOpened()方法中,我使用了与onCreate中使用的相同的代码来加载配置文件pic和名称.这应该在每次打开抽屉时更新这些参数,但是没有这样做,在我关闭并重新打开应用程序之前仍然不更新标题.
解决方法
public class MainActivity extends AppCompatActivity implements DrawerLayout.DrawerListener { private DrawerLayout drawerLayout; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); drawerLayout.setDrawerListener(this); ...
(Android)具有多窗格布局的导航抽屉
我很难为平板电脑的活动提供一个良好且可接受的布局,但是我不确定我的设计是否与Google的设计指南兼容.
简而言之:我的应用程序接收到一个网络嗅探器日志文件,并显示有关数据上不同功能的统计信息.例如,随着时间的流量,随着时间的PM,将流量显示为时间线,不同的图形,饼图等.
该活动的设计首先想到的是多窗格布局(如用于平板电脑的Gmail).第一个窗格将是上面指定的不同功能,第二个窗格将在第三个窗格上具有控件(它将显示图形)以过滤不同的数据,着色以及其他内容和设置.
问题在于,第二个窗格不是一个打开内容的列表(例如在Gmail中),而是一个控制第三个窗格的列表.
我对此的解决方案是只创建一个两窗格的布局:只有第二个(带有控件),当然还有第三个带有图形.功能列表将在导航抽屉中,用户必须滑动该导航抽屉才能切换到另一个功能.
该设计是否与Google的设计指南兼容?对用户来说是否合乎逻辑?
解决方法:
我不建议将导航抽屉用于平板电脑,至少不要在横向模式下使用.三个面板应该可以正常工作,并且您只能将导航抽屉用于纵向模式.
Android设计方法非常灵活,因此与其尝试使用最新的设计模式,不如找出最适合您数据的方法.
无论如何,一个应用程序可以在3个不同的面板中显示内容的一个很好的例子是Android wordpress应用程序.在这里查看:https://play.google.com/store/apps/details?id=org.wordpress.android
Android MVP和导航抽屉
是否有任何人都知道的首选方法或任何示例?
解决方法
android – 删除子部分和导航抽屉子菜单
我想删除子菜单中创建的不需要的空间.
有没有可能我可以从menu.xml类实现它?
这是我的navigation_drawer_menu.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:checkableBehavior="single">
<item
android:id="@+id/all"
android:checked="true"
android:icon="@drawable/ic_channels"
android:title="All Channels" />
.......
<item
android:id="@+id/other"
android:icon="@drawable/ic_other"
android:title="Others" />
</group>
<item android:title="">
<menu>
<item
android:id="@+id/setting"
android:icon="@drawable/ic_action_settings"
android:title="Settings" />
<item
android:id="@+id/about"
android:icon="@drawable/ic_about"
android:title="About" />
<item
android:id="@+id/share"
android:icon="@drawable/ic_share"
android:title="Share" />
</menu>
</item>
谢谢.
解决方法:
这就是我实现它的方式.因为您要为菜单添加标题,所以无法识别它是空的.
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:checkableBehavior="single">
<item
android:id="@+id/nav1"
android:checked="true"
android:title="Pos 1" />
<item
android:id="@+id/nav2"
android:title="Pos 2" />
</group>
<group
android:id="@+id/menu_two"
android:checkableBehavior="single">
<item
android:id="@+id/pos3"
android:title="Pos 3" />
<item
android:id="@+id/pos4"
android:title="Pos 4" />
</group>
</menu>
android – 在导航抽屉中添加图标
继承我的代码:
public class MainActivity extends ActionBaractivity { private ListView mDrawerList; private DrawerLayout mDrawerLayout; private ArrayAdapter<String> mAdapter; private ActionBarDrawerToggle mDrawerToggle; private String mActivityTitle; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mDrawerList = (ListView)findViewById(R.id.navList); mDrawerLayout = (DrawerLayout)findViewById(R.id.drawer_layout); mActivityTitle = getTitle().toString(); addDrawerItems(); setupDrawer(); FragmentManager fragmentManager = getSupportFragmentManager(); fragmentManager.beginTransaction().replace(R.id.flContent,new One()).commit(); getSupportActionBar().setdisplayHomeAsUpEnabled(true); getSupportActionBar().setHomeButtonEnabled(true); } private void addDrawerItems() { String[] osArray = { "Android","iOS","Windows","OS X","Linux" }; mAdapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,osArray); mDrawerList.setAdapter(mAdapter); mDrawerList.setonItemClickListener(new AdapterView.OnItemClickListener() { Fragment fragment = null; Class fragmentClass; @Override public void onItemClick(AdapterView<?> parent,View view,int position,long id) { switch (position) { case 1: fragmentClass = One.class; break; case 2: fragmentClass = Two.class; break; default: break; } try { fragment = (Fragment) fragmentClass.newInstance(); } catch (Exception e) { e.printstacktrace(); } // Insert the fragment by replacing any existing fragment FragmentManager fragmentManager=getSupportFragmentManager(); fragmentManager.beginTransaction().replace(R.id.flContent,fragment).commit(); // Highlight the selected item,update the title,and close the drawer mDrawerLayout.closeDrawers(); } }); } private void setupDrawer() { mDrawerToggle = new ActionBarDrawerToggle(this,mDrawerLayout,R.string.drawer_open,R.string.drawer_close) { /** Called when a drawer has settled in a completely open state. */ public void onDrawerOpened(View drawerView) { super.onDrawerOpened(drawerView); getSupportActionBar().setTitle("Navigation!"); invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu() } /** Called when a drawer has settled in a completely closed state. */ public void onDrawerClosed(View view) { super.onDrawerClosed(view); getSupportActionBar().setTitle(mActivityTitle); invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu() } }; mDrawerToggle.setDrawerIndicatorEnabled(true); mDrawerLayout.setDrawerListener(mDrawerToggle); } @Override protected void onPostCreate(Bundle savedInstanceState) { super.onPostCreate(savedInstanceState); // Sync the toggle state after onRestoreInstanceState has occurred. mDrawerToggle.syncState(); } @Override public void onConfigurationChanged(Configuration newConfig) { super.onConfigurationChanged(newConfig); mDrawerToggle.onConfigurationChanged(newConfig); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.menu_main,menu); return true; } @Override public boolean onoptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button,so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); //noinspection SimplifiableIfStatement if (id == R.id.action_settings) { return true; } // Activate the navigation drawer toggle if (mDrawerToggle.onoptionsItemSelected(item)) { return true; } return super.onoptionsItemSelected(item); } }
解决方法
<android.support.design.widget.NavigationView android:id="@+id/nav_view" android:layout_width="wrap_content" android:layout_height="match_parent" android:fitsSystemWindows="true" app:menu="@menu/activity_main_drawer"> </android.support.design.widget.NavigationView>
在activity_main_drawer菜单文件中,用他们的名字定义你的图标
<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android"> <group android:checkableBehavior="single"> <item android:id="@+id/nav_camara" android:icon="@android:drawable/ic_menu_camera" android:title="Camera" /> <item android:id="@+id/nav_gallery" android:icon="@android:drawable/ic_menu_gallery" android:title="gallery" /> <item android:id="@+id/nav_manage" android:icon="@android:drawable/ic_menu_manage" android:title="Manage" /> </group>
在MainActivity.java中调用每个项目的操作单击抽屉菜单
@Override public boolean onNavigationItemSelected(MenuItem menuItem) { // Handle navigation view item clicks here. int id = menuItem.getItemId(); if (id == R.id.nav_camara) { // Call your Action } else if (id == R.id.nav_gallery) { // Call your Action } else if (id == R.id.nav_manage) { // Call your Action } }
今天关于android – 更新材料导航抽屉头和抽屉导航app的讲解已经结束,谢谢您的阅读,如果想了解更多关于(Android)具有多窗格布局的导航抽屉、Android MVP和导航抽屉、android – 删除子部分和导航抽屉子菜单、android – 在导航抽屉中添加图标的相关知识,请在本站搜索。
本文标签: