Выдвижной ящик появляется во всех видах деятельности
Я разрабатываю приложение, которое содержит много действий
и я создал свое собственное меню (я не хочу использовать встроенную кнопку меню) с помощью скользящего ящика
поскольку скользящий выдвижной ящик находится в нижней части экрана и содержит мои кнопки меню
мне нужно, чтобы этот скользящий ящик появлялся во всех моих действиях.
Я попытался создать мероприятие и установить его в виде содержимого в XML файл, который содержит ящик, а затем расширяет эту активность во всех других действиях, но это решение не работает.
так что любые предложения?
Ответы
Ответ 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, перед скользящим слоем.