2013-12-20 2 views
1

У меня есть DrawerLayout в приложении для Android, он отлично работает, но он не делает того, что я хочу. Я хочу реализовать DrawerLayout, который всегда «открыт» или подглядывает, поэтому он может отображать значки пунктов меню, и он может полностью открываться, чтобы отобразить полный список меню (так что значок + текст меню). Это возможно?Android DrawerLayout lock half open

Это мой класс и XML в настоящее время:

public class MainActivity extends Activity { 

private DrawerLayout mDrawerLayout; 
private ActionBarDrawerToggle mDrawerToggle; 

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

    mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout); 
    mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow, GravityCompat.RELATIVE_HORIZONTAL_GRAVITY_MASK); 

    getActionBar().setDisplayHomeAsUpEnabled(true); 
    getActionBar().setHomeButtonEnabled(true); 

    mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout, R.drawable.ic_drawer, R.string.drawer_open, R.string.drawer_close) { 
     public void onDrawerClosed(View view) { 
      getActionBar().setTitle("App title"); 
      invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu() 
     } 

     public void onDrawerOpened(View drawerView) { 
      getActionBar().setTitle("Menu"); 
      invalidateOptionsMenu(); // creates call to onPrepareOptionsMenu() 
     } 
    }; 
    mDrawerLayout.setDrawerListener(mDrawerToggle); 

} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    if (mDrawerToggle.onOptionsItemSelected(item)) { 
     return true; 
    } else { 
     return false; 
    } 
} 

@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); 
    // Pass any configuration change to the drawer toggls 
    mDrawerToggle.onConfigurationChanged(newConfig); 
} 

} 

XML:

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:id="@+id/drawer_layout" 
android:layout_width="match_parent" 
android:layout_height="match_parent" > 

<FrameLayout 
    android:id="@+id/content_frame" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" > 

</FrameLayout> 

<RelativeLayout 
    android:id="@+id/left_drawer" 
    android:layout_width="80dp" 
    android:layout_height="match_parent" 
    android:layout_gravity="start" 
    android:background="#eee" > 

    <ListView 
     android:id="@+id/drawerMenu" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" > 
    </ListView> 
</RelativeLayout> 
</android.support.v4.widget.DrawerLayout> 

Я реализовать меню позже, мне просто нужно знать, как держать DrawerLayout в сохраняющихся " peek-a-boo ".

ответ

1

Я, наконец, натолкнулся на информацию, чтобы сделать это. Вы можете использовать для него другой вид макета. Вместо DrawerLayout вы можете использовать SlidingPaneLayout.