Як визначити, чи відкрито шухляду навігації?


89

Назва все це пояснює. Все, що я хочу зробити, це знати, відкрито ящик навігації чи ні. Я багато шукав у мережі і знайшов метод, isDrawerOpen(int drawerGravity)але не зміг знайти задовільної відповіді, яка пояснює, як використовувати його в методі. Буду вдячний, якщо хтось мені це пояснить.

Спасибі заздалегідь!


3
boolean drawerOpen = mDrawerLayout.isDrawerOpen(mDrawerList). mDrawerLayout є шухлядою, а mDrawerList
списком

@Raghunandan Велике спасибі!
Чінмай Дабке

Відповіді:


213

Припускаючи, що ви визначили розкладку шухляди в xml:

DrawerLayout mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
...
if(mDrawerLayout.isDrawerOpen(GravityCompat.START)) {
  //drawer is open
}

Чи означає це, що шухляда відкрита?
Чінмай Дабке

8
Хоча це може бути очевидним для багатьох, я хотів би зазначити, що isDrawerOpen (GravityCompat.END)) слід використовувати, якщо шухляду відкрито праворуч (тобто android: layout_gravity = "right")
Гонг

3
Якщо ви хочете закрити, вам слід додати цей коментар у if staments drawer.closeDrawer (Gravity.START);
mehmet

32
 mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
    mDrawerToggle = new ActionBarDrawerToggle(
            this,                  /* host Activity */
            mDrawerLayout,         /* DrawerLayout object */
            R.drawable.ic_drawer,  /* nav drawer icon to replace 'Up' caret */
            R.string.drawer_open,  /* "open drawer" description */
            R.string.drawer_close  /* "close drawer" description */
            ) {

        /** Called when a drawer has settled in a completely closed state. */
        public void onDrawerClosed(View view) {
            super.onDrawerClosed(view);
            getActionBar().setTitle(mTitle);
        }

        /** Called when a drawer has settled in a completely open state. */
        public void onDrawerOpened(View drawerView) {
            super.onDrawerOpened(drawerView);
            getActionBar().setTitle(mDrawerTitle);
        }
    };

    // Set the drawer toggle as the DrawerListener
    mDrawerLayout.setDrawerListener(mDrawerToggle);

Цим слухач користується :)


Дякую, але я не використовую панель дій із шухлядою навігації. Просто потрібно використовувати його в методі!
Чінмай Дабке

20

Використання:

mDrawerLayout.isDrawerOpen () метод

Приклад:

    if(mDrawerLayout.isDrawerOpen(GravityCompat.START)) {
        mDrawerLayout.closeDrawer(Gravity.LEFT); //CLOSE Nav Drawer!
    }else{
        mDrawerLayout.openDrawer(Gravity.LEFT); //OPEN Nav Drawer!
    }

3
якщо шухляда відкрита, відкрийте шухляду, інакше закрийте шухляду: D
ataulm

5

Наступним чином ви можете виявити, що шухляда відкрита або закрита.

 public class YourActivity extends AppCompatActivity implements  DrawerLayout.DrawerListener {

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_dash_board);

        DrawerLayout drawer=(DrawerLayout)findViewById(R.id.container);
        drawer.setDrawerListener(this);
    }//onCreate()

    @Override
    public void onDrawerOpened(View arg0) {
      //write your code
    }

    @Override
    public void onDrawerClosed(View arg0) {
        //write your code
    }

    @Override
    public void onDrawerSlide(View arg0, float arg1) {
        //write your code
    }

    @Override
    public void onDrawerStateChanged(int arg0) {
        //write your code
    }
}//class

Використовуйте addDrawerListener, оскільки набір застарів
SeaRoth

3

відповідь shakeJ - правильна, і пам’ятайте, що ви можете використовувати onDrawerSlide, щоб мати можливість запускати інші функції ... наприклад, я використовував її для зміни кольору StatusBar.

        /** Called when a drawer has settled in a completely closed state. */
        public void onDrawerClosed(View view) {
            super.onDrawerClosed(view);
            isOpen = false;
        }

        /** Called when a drawer has settled in a completely open state. */
        public void onDrawerOpened(View drawerView) {
            super.onDrawerOpened(drawerView);
            isOpen = true;
        }
        public void onDrawerSlide(View drawerView,float slideOffset){
            super.onDrawerSlide(drawerView,slideOffset);
            if(!isOpen){
                setStatusBarColor("#00102b");
            }
            if(isOpen){
                setStatusBarColor("#EFEFF0");
            }
        }

3

Виявити DrawerLayoutвідкритий, закритий, розсунути DrawerLayout.DrawerListener

DrawerLayout drawerLayout:
drawerLayout.addDrawerListener(new DrawerLayout.DrawerListener() {
    /**
     * Called when a drawer's position changes.
     *
     * @param slideOffset The new offset of this drawer within its range, from 0-1
     *                    Example when you slide drawer from left to right, slideOffset will increase from 0 - 1 (0 when drawer closed and 1 when drawer display full)
     */
    @Override
    public void onDrawerSlide(@NonNull View drawerView, float slideOffset) {

    }

    @Override
    public void onDrawerOpened(@NonNull View drawerView) {
        // do something when drawer opened
    }

    @Override
    public void onDrawerClosed(@NonNull View drawerView) {
        // do something when drawer closed
    }

    /**
     * Called when the drawer motion state changes. The new state will
     * be one of {@link #STATE_IDLE}, {@link #STATE_DRAGGING} or {@link #STATE_SETTLING}.
     */
    @Override
    public void onDrawerStateChanged(int newState) {

    }
});

Ящик чеків відкрито

if(drawerLayout.isDrawerOpen(GravityCompat.START)) // or  GravityCompat.END

1

Метод однаковий у Котліні.

  1. Ініціалізувати DrawerLayout View

    val drawerLayout: DrawerLayout = findViewById(R.id.drawer_layout)

  2. Перевірте, чи шухляда відкрита

    if(drawerLayout.isDrawerOpen(GravityCompat.START)){ Log.d("Drawer","open") }

Якщо ви хочете вчинити дії автоматично, коли шухляду відкрито або закрито, ви можете зробити наступне.

  1. У своїй основній діяльності створіть внутрішній клас, який є підкласом DrawerLayout.DrawerListener . Клас DrawerLayout реалізує інтерфейс DrawerListener.

    inner class CustomDrawer : DrawerLayout.DrawerListener{
      override fun onDrawerStateChanged(newState: Int) {
      }
    
      override fun onDrawerSlide(drawerView: View, slideOffset: Float) {
        imm.hideSoftInputFromWindow(drawerView?.getWindowToken(), 0)
      }
    
      override fun onDrawerClosed(drawerView: View) {
        imm.hideSoftInputFromWindow(drawerView?.getWindowToken(), 0)
      }
    
      override fun onDrawerOpened(drawerView: View) {
        imm.hideSoftInputFromWindow(drawerView?.getWindowToken(), 0)
      }
    }
  2. Введіть свою дію у функцію, яку ви хочете використовувати. У моєму прикладі я закриваю програмну клавіатуру, якщо користувач взаємодіє з панеллю навігації. Оголосіть InputMethodManager таким чином у своїй основній діяльності:

    var imm: InputMethodManager = this.getSystemService(Activity.INPUT_METHOD_SERVICE)

  3. Додайте власний DrawerListener до drawerLayout (я помістив його в метод onCreate)

    var drawerListener = CustomDrawer() drawerLayout.addDrawerListener(drawerListener)


1

Можливо, я запізнився, але можу поділитися новою оновленою інформацією. У даному коді я встановлюю шухляду відкриття / закриття у функції onclick. Якщо шухляда відкривається, ніж вона буде закрита в іншому випадку, це рішення базується на RXava DrawerLayout (androidx.drawerlayout.widget.DrawerLayout). У своєму коді я відкриваю розкладку ящиків справа наліво.

 @Override
    public void onClick(View view) {

  if (drawerLayout.isDrawerVisible(GravityCompat.END)) {
                    drawerLayout.closeDrawer(GravityCompat.END);
  }else {
                    drawerLayout.openDrawer(GravityCompat.END);
  }

}

Примітка: Якщо ви відкриваєте висувний ящик з правого боку, використовуйте "GravityCompat.END", а він відкритий з лівого боку, тоді використовуйте "GravityCompat.START" . Насолоджуйтесь кодуванням .....

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.