Подтвердить что ты не робот

Выдвижной ящик появляется во всех видах деятельности

Я разрабатываю приложение, которое содержит много действий и я создал свое собственное меню (я не хочу использовать встроенную кнопку меню) с помощью скользящего ящика поскольку скользящий выдвижной ящик находится в нижней части экрана и содержит мои кнопки меню

мне нужно, чтобы этот скользящий ящик появлялся во всех моих действиях.

Я попытался создать мероприятие и установить его в виде содержимого в XML файл, который содержит ящик, а затем расширяет эту активность во всех других действиях, но это решение не работает.

так что любые предложения?

4b9b3361

Ответ 1

Расширение - это правильный путь. Просто верните setContentView в правильном направлении. Здесь рабочий пример, но вместо ящика я использую созданную табуляцию:

Определите макет с вашим ящиком следующим образом:

это act_layout.xml

<LinearLayout
  ...
  android:orientation="vertical"
>
  <YourDrawer
    ...
  />
  <FrameLayout
    android:id="@+id/act_content"
    ...
  >
    // Here will be all activity content placed
  </FrameLayout>
</LinearLayout>

Это будет ваш базовый макет, который будет содержать все другие макеты в кадре act_content. Затем создайте базовый класс активности и выполните следующие действия:

public abstract class DrawerActivity extends Activity {

    protected LinearLayout fullLayout;
    protected FrameLayout actContent;

    @Override
    public void setContentView(final int layoutResID) {
        // Your base layout here
        fullLayout= (LinearLayout) getLayoutInflater().inflate(R.layout.act_layout, null); 
        actContent= (FrameLayout) fullLayout.findViewById(R.id.act_content);

        // Setting the content of layout your provided to the act_content frame
        getLayoutInflater().inflate(layoutResID, actContent, true); 
        super.setContentView(fullLayout);

        // here you can get your drawer buttons and define how they 
        // should behave and what must they do, so you won't be 
        // needing to repeat it in every activity class
    }
}

Что мы делаем, в основном перехватываем все вызовы setContentView (int resId), раздуваем наш макет для ящика из xml, раздуваем наш макет для активности (посредством reId, предоставляемого при вызове метода), объединяем их по мере необходимости и устанавливаем как contentView активности.

EDIT: После того, как вы создали материал выше, просто приступайте к написанию приложения, как обычно, создайте макеты (без каких-либо упоминаний ящика), создайте действия, но вместо того, чтобы распространять простую активность, расширяйте DrawerActivity, например:

public abstract class SomeActivity extends DrawerActivity {

    protected void onCreate(Bundle bundle) {
        setContentView(R.layout.some_layout);
    }
}

Что происходит, это перехват setContentView (R.layout.some_layout). Ваш DrawerActivity загружает макет, который вы предоставили из xml, загружает стандартный макет для вашего ящика, объединяет их, а затем устанавливает его как contentView для активности.

Ответ 2

Наконец, через 3 года здесь полное решение этого важного вопроса, для которого, возможно, не полностью руководствовался г-н Орлов, отвечает.

Его метод для представления иерархии был полностью в порядке, но были некоторые небольшие ошибки, которые могут ввести в заблуждение начинающих разработчиков.

  • Как уже упоминал Гейб, вы можете избавиться от абстрактного в декларации.
  • Нет необходимости обертывать обоих дочерних элементов FrameLayout. Родитель может быть любым RelativeLayout, LinearLayout и т.д. Но самая важная часть заключается в том, что вы должны объявить FrameLayout перед слайдером.

Таким образом, 100% -ное рабочее разрешение будет таким:

activity_drawer.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >

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

<YourDrawer
    android:id="@+id/drawer_drawer"
    android:layout_width="match_parent"
    android:layout_height="fill_parent" >

</YourDrawer>

</RelativeLayout>

DrawerActivity.java

public class DrawerActivity extends Activity {

protected RelativeLayout fullLayout;
protected FrameLayout frameLayout;

@Override
public void setContentView(int layoutResID) {

    fullLayout = (RelativeLayout) getLayoutInflater().inflate(R.layout.activity_drawer, null);
    frameLayout = (FrameLayout) fullLayout.findViewById(R.id.drawer_frame);

    getLayoutInflater().inflate(layoutResID, frameLayout, true);

    super.setContentView(fullLayout);

    //Your drawer content...

}

}

MainActivity.java

public class MainActivity extends DrawerActivity {

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

}

}

Не забудьте объявить DrawerActivity в манифесте.

Надеюсь, что это помогло.

Ответ 3

Я знаю, что это на два года поздно, но для тех, кто хотел бы получить ответ здесь. У г-на Орлова был соответствующий ответ, нужно лишь несколько корректировок.

  • удалить реферат после публикации. (это вызывает ошибку)
  • ОБРАТИТЕ ваш скользящий ящик и FrameLayout с другим FrameLayout и установите ширину и высоту в match_parent. (Это позволяет отображать BOTH макеты).

ТАКЖЕ: Если вы хотите, чтобы ваш скользящий ящик появлялся поверх вашей компоновки (duh!), поместите рамкуLayout, которая находится после скользящегоDrawer, перед скользящим слоем.