Главная страница
Навигация по странице:

  • LinearLayout

  • RelativeLayout

  • Project name

  • TableLayout (TL)

  • RelativeLayout (RL)

  • презентация. Тема 5. Виды Layouts. Ключевые отличия и свойства. LinearLayout отображает элементы в виде одной строки (если он Horizontal) или одного столбца (если он Vertical). Мы говорили об этом на прошлом уроке, когда изучали использование файлов при смене ориентации. TableLayout


    Скачать 0.85 Mb.
    НазваниеLinearLayout отображает элементы в виде одной строки (если он Horizontal) или одного столбца (если он Vertical). Мы говорили об этом на прошлом уроке, когда изучали использование файлов при смене ориентации. TableLayout
    Анкорпрезентация
    Дата10.11.2022
    Размер0.85 Mb.
    Формат файлаpdf
    Имя файлаТема 5. Виды Layouts. Ключевые отличия и свойства.pdf
    ТипУрок
    #781956
    Урок 5. Виды Layouts. Ключевые отличия и свойства. Расположение элементов на экране зависит отв которой они находятся. В этом уроке мы рассмотрим основные виды Layout.
    LinearLayout – отображает элементы в виде одной строки (если он
    Horizontal) или одного столбца (если он Vertical). Мы говорили об этом на прошлом уроке, когда изучали использование файлов при смене ориентации.
    TableLayoutотображает элементы в виде таблицы, по строками столбцам.
    RelativeLayout – для каждого элемента настраивается его положение относительно других элементов.
    AbsoluteLayout – для каждого элемента указывается явная позиция на экране в системе координат (x,y) Рассмотрим эти виды
    LinearLayout (LL) Этот вид ViewGroup по умолчанию предлагается при создании новых файлов. Он действительно удобен и достаточно гибок, чтобы создавать экраны различной сложности. LL имеет свойство Orientation, которое определяет, как будут расположены дочерние элементы – горизонтальной или вертикальной линией. Сделаем простой и наглядный пример. Создайте проект
    Project name: P0061_Layouts
    Build Target: Android 2.3.3
    Application name: Layouts
    Package name: ru.startandroid.develop.layouts
    Create Activity: MainActivity Откроем файл main.xml, и поместите в него следующий код Теперь корневой элементу нас LinearLayout с вертикальной ориентацией. Перетащите слева в корневой LinearLayout три кнопки. Они выстроились вертикально.
    1
    Составлено по материалам startandroid.ru
    Теперь вменяем для LL свойство Orientation на horizontal и сохраняем (CTRL+SHIFT+S) – кнопки выстроились горизонтально.
    GroupView можно вкладывать друг в друга. Вложим в один LL два других. Удалите в main.xml все элементы (три кнопки) кроме корневого LL. Ориентацию корневого LL укажем вертикальную и добавим в него два новых горизонтальных LL. В списке элементов слева они находятся в разделе
    Layouts. Напоминаю, что вы можете перетаскивать элементы из списка не только на экран, но и на конкретный элемент на вкладке Outline. В каждый горизонтальный LL добавим потри кнопки. Получилось два горизонтальных ряда кнопок. Убедитесь, что у горизонтальных LinearLayout высота (height) установлена в wrap_content.

    TableLayout (TL)
    TL состоит из строк TableRow (TR). Каждая TR в свою очередь содержит элементы, формирующие столбцы. Те. кол-во View в TR – это кол-во столбцов. Но кол-во столбцов в таблице должно быть равным для всех строк. Поэтому, если в разных TR разное кол-во элементов (столбцов, то общее кол-во определяется пос максимальным кол-вом. Рассмотрим на примере. Создадим файл tlayout.xml. с корневым элементом TableLayout
    Добавим в корневой TableLayout три строки (из раздела
    Layouts слева) ив каждую строку добавим по две кнопки. Результат наша таблица имеет три строки и два столбца. Добавим в первую строку еще пару кнопок. Кол-во столбцов для всех строк теперь равно 4, т.к. оно определяется по строке с максимальным кол-вом элементов, те. по первой строке. Для второй и третьей строки третий и четвертый столбцы просто ничем не заполнены. Во вторую строку добавим TextView и Button, и текст в добавленном
    TextView сделаем пустым. В третьей строке сделаем тоже самое. Мы видим, что эти элементы легли в третий и четвертый столбец. И тку нас без текста и на экране невиден, кажется, что третий столбец во второй и третьей строке пустой.
    Ширина столбца определяется по самому широкому элементу из этого столбца. Введем текст в один из TextView и видим, что он расширил столбец. Давайте уберем элементы четвертого столбца и построим такой экран. Попробуйте сами сделать также в качестве упражнения.
    TL может содержать не только TR, но и обычные View. Добавьте, например, Button прямо в TL, а не в TR и увидите, что она растянулась на ширину всей таблицы.
    RelativeLayout (RL)
    В этом виде Layout каждый элемент может быть расположен определенным образом относительно указанного элемента. Виды отношений
    1) слева, справа, сверху, снизу указанного элемента
    (layout_toLeftOf, layout_toRightOf, layout_above, layout_below)
    2) выравненным полевому, правому, верхнему, нижнему краю указанного элемента (layout_alignLeft, layout_alignRight, layout_alignTop, layout_alignBottom)
    3) выравненным полевому, правому, верхнему, нижнему краю родителя (layout_alignParentLeft, layout_alignParentRight, layout_alignParentTop, layout_alignParentBottom)
    4) выравненным по центру вертикально, по центру горизонтально, по центру вертикально и горизонтально относительно родителя
    (layout_centerVertical, layout_centerHorizontal, layout_centerInParent) Создадим rlayout.xml и скопируем туда такой код Здесь у нас корневой элемент - RelativeLayout. Получился такой экран Подробнее по ссылке.
    Нам интересен код. Сразу кратко опишу незнакомые атрибуты и их значения android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/entry" Слово android в названии каждого атрибута – это namespace. Запомните это, потому что далее мы будем опускать его при объяснениях.
    id – это ID элемента,
    layout_width (ширина элемента) и layout_height (высота элемента) могут задаваться в абсолютных значениях, а могут быть следующими fill_parent или match_parent) (максимально возможная ширина или высота в пределах родителя) и wrap_content (ширина или высота определяется по содержимому элемента. Сейчас вернемся к нашим элементам. В примере мы видим TextView,
    EditText и два Button – OK и Cancel. Давайте подробно разберем интересующие нас атрибуты.
    Вы можете добавлять элементы и экспериментировать сих размещением. Обратите внимание, что у элемента может не быть ID (android:id). Например, для TextView он обычно ненужен, т.к. они чаще всего статичны, и мы к ним почти не обращаемся при работе приложения. Другое дело EditText – мы работаем с содержимым текстового поля, и Button – нам надо обрабатывать нажатия и соответственно знать, какая именно кнопка нажата. В будущем мы увидим еще одну необходимость задания ID для View- элемента.
    AbsoluteLayout (AL) Обеспечивает абсолютное позиционирование элементов на экране. Вы указываете координаты для левого верхнего угла компонента. Создадим layout.xml с корневым AbsoluteLayout
    Теперь попробуйте перетаскиванием добавить различные элементы на экран. Они не выстраиваются, как при LinearLayout или TableLayout, а ложатся там, куда вы их перетащили. Те. это абсолютное позиционирование. Открываем код и видим, что для задания координат используются layout_x и layout_y. Поначалу кажется, что это наиболее удобный и интуитивно понятный способ расположения элементов на экране - они сразу располагаются там, где
    надо. Но это только в случае, когда вы разрабатываете для экрана с конкретным разрешением. Если открыть такое приложение на другом экране, все элементы сместятся и получится не так, как вы планировали. Поэтому этот
    Layout не рекомендуется использовать. И его совместимость с будущими версиями Android не гарантируется О других видах ViewGroup по ссылке


    написать администратору сайта