WedX - журнал о программировании и компьютерных науках

Navbar - не будет идти впереди тела при прокрутке

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

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

Макет xml для этой страницы также ниже.

Что случается:

введите здесь описание изображения

XML:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="https://schemas.android.com/apk/res/android"
xmlns:app="https://schemas.android.com/apk/res-auto"
android:id="@+id/RelativeLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical"
android:theme="@style/AppTheme">



  <RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/NwApt"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="55dp"
        android:background="@color/colorS"
        android:padding="5dp"
        android:text="New Appointment"
        android:textColor="@color/PTextColour"
        android:textSize="18sp" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="@dimen/activity_horizontal_margin"

        android:orientation="vertical">


        <EditText
            android:id="@+id/NEngNme"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"

            android:layout_marginTop="75dp"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Engineer Name"
            android:inputType="textPersonName" />

        <EditText
            android:id="@+id/NItm"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Item"
            android:inputType="textPersonName" />

        <EditText
            android:id="@+id/NDate"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Date"
            android:inputType="date" />


        <EditText
            android:id="@+id/NTime"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Time"
            android:inputType="time" />


        <EditText
            android:id="@+id/NLoc"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"

            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Location"
            android:inputType="textPersonName" />


        <EditText
            android:id="@+id/NTstNotes"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"

            android:layout_weight="1"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Tester Notes"
            android:inputType="textMultiLine" />

        <EditText
            android:id="@+id/NScdNotes"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"

            android:layout_weight="1"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Scheduler Notes"
            android:inputType="textMultiLine" />


        <CheckBox
            android:id="@+id/NntsChkBx"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"

            android:layout_weight="1"
            android:text="Show Notes at appointment" />


        <CheckBox
            android:id="@+id/NaptChkBx"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"

            android:text="Missed Appointment" />


        <LinearLayout
            android:id="@+id/NButtons"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:weightSum="2">

            <Button
                android:id="@+id/NSveNts"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:text="Save Notes" />

            <Button
                android:id="@+id/NSndEml"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:text="Send Email" />
        </LinearLayout>

        </LinearLayout>
       </RelativeLayout>

   </RelativeLayout>

  • Перейдите по этой ссылке, чтобы узнать, как использовать макет координат и this для использования координатного макета с drawerlayout. 22.12.2017
  • Это похоже на много переделки, учитывая все страницы, которые у меня есть, есть ли какой-нибудь более простой способ или мне придется использовать этот подход? 22.12.2017
  • Нет, на самом деле это не так. Вам просто нужно использовать вторую ссылку для этой проблемы. Смотрите принятый ответ. 22.12.2017
  • ~ см. мой ответ. 22.12.2017

Ответы:


1

activity_edit_appointment.xml содержит DrawerLayout в качестве родительского представления с последующими дочерними элементами в виде CoordniatorLayout и NavigationView, например:

<android.support.v4.widget.DrawerLayout 
xmlns:android="https://schemas.android.com/apk/res/android"
xmlns:app="https://schemas.android.com/apk/res-auto"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:focusableInTouchMode="true">

<android.support.design.widget.CoordinatorLayout
    xmlns:app="https://schemas.android.com/apk/res-auto"
    android:id="@+id/overview_coordinator_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">


        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimaryDark"
            app:layout_scrollFlags="enterAlways|scroll" />

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <include layout="@layout/your_contents" />

    </android.support.v4.widget.NestedScrollView>


</android.support.design.widget.CoordinatorLayout>

<android.support.design.widget.NavigationView
    android:id="@+id/nvView"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:background="@android:color/white"
    app:headerLayout="@layout/nav_header"
    app:menu="@menu/navigationdrawer_main" />
  </android.support.v4.widget.DrawerLayout>


your_contents.xml будет содержать представления, которые вы хотите отображать для текущей активности.

 <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="16dp"
        android:orientation="vertical">
        <EditText
            android:id="@+id/NEngNme"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="75dp"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Engineer Name"
            android:inputType="textPersonName" />

        <EditText
            android:id="@+id/NItm"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Item"
            android:inputType="textPersonName" />

        <EditText
            android:id="@+id/NDate"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Date"
            android:inputType="date" />

        <EditText
            android:id="@+id/NTime"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Time"
            android:inputType="time" />

        <EditText
            android:id="@+id/NLoc"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Location"
            android:inputType="textPersonName" />

        <EditText
            android:id="@+id/NTstNotes"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Tester Notes"
            android:inputType="textMultiLine" />

        <EditText
            android:id="@+id/NScdNotes"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:background="@android:drawable/editbox_background_normal"
            android:ems="10"
            android:hint="Scheduler Notes"
            android:inputType="textMultiLine" />


        <CheckBox
            android:id="@+id/NntsChkBx"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="Show Notes at appointment" />


        <CheckBox
            android:id="@+id/NaptChkBx"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="Missed Appointment" />


        <LinearLayout
            android:id="@+id/NButtons"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:weightSum="2">

            <Button
                android:id="@+id/NSveNts"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:text="Save Notes" />

            <Button
                android:id="@+id/NSndEml"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:text="Send Email" />
        </LinearLayout>

    </LinearLayout>

вы можете поместить свой навигационный ящик в эти 2 xml-файла: nav_header.xml (предоставит вам заголовок, такой как приложение gmail) и navigationdrawer_main.xml (укажите свои записи ящика в этом файле меню)

Чтобы дать название панели инструментов, вы можете сделать это либо программно или просто присвойте android:label="Edit Appointment" тегу activity этого действия в AndroidManifest.xml.

22.12.2017
  • жаль, я думаю, что я замедляю получение там!! Теперь, используя код выше, хотя я получаю, что DrawerLayout должен быть измерен с ошибкой MeasureSpec.EXACTLY, я вижу, что это как-то связано с высотой/шириной, просто не могу найти проблему ... есть ли шанс, что вы точно знаете, что вызывает это? 22.12.2017
  • Новые материалы

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

    Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
    Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..

    Учебные заметки: создание моего первого пакета Node.js
    Это мои обучающие заметки, когда я научился создавать свой самый первый пакет Node.js, распространяемый через npm. Оглавление Глоссарий I. Новый пакет 1.1 советы по инициализации..

    Забудьте о Matplotlib: улучшите визуализацию данных с помощью умопомрачительных функций Seaborn!
    Примечание. Эта запись в блоге предполагает базовое знакомство с Python и концепциями анализа данных. Привет, энтузиасты данных! Добро пожаловать в мой блог, где я расскажу о невероятных..


    Для любых предложений по сайту: [email protected]