- Русские Блоги
- Разница между атрибутами видимости VISIBLE, INVISIBLE и GONE в Android
- Андроид: разница между невидимым и ушел?
- 7 ответов:
- Android: почему setVisibility (View.GONE); Или setVisibility (View.INVISIBLE); не работает
- Android studio visibility gone
- Войти
- Layouts (разметка)
- FrameLayout
- LinearLayout
- TableLayout
- RelativeLayout
- ScrollView
- Атрибуты элементов
- android:layout_width и android:layout_height
- android:layout_gravity
- android:layout_margin
- android:weight
Русские Блоги
Разница между атрибутами видимости VISIBLE, INVISIBLE и GONE в Android
В разработке для Android большинство элементов управления имеют атрибут видимости, а есть три атрибута: «видимый», «невидимый» и «пропавший». В основном используется для настройки отображения и скрытия элементов управления. Некоторые люди могут задаться вопросом, в чем разница между невидимым и ушедшим? ? ? Итак, с этим вопросом мы смотрим на следующее:
Это устанавливается следующим образом в файле XML и коде Java:
Видимый (видимый)
XML-файл: android: visibility = «visible»
Java-код: view.setVisibility (View.VISIBLE);
Невидимый (невидимый)
XML-файл: android: visibility = «invisible»
Java-код: view.setVisibility (View.INVISIBLE);
Спрятаться
XML-файл: android: visibility = «ушел»
Java-код: view.setVisibility (View.GONE);
Чтобы различить три, я построил Купол для демонстрации, сначала перейдем к кодексу Купола, после демонстрации я знаю разницу между ними:
- xml version = «1.0» encoding = «utf-8» ?>
- LinearLayout xmlns:android = «http://schemas.android.com/apk/res/android»
- android:layout_width = «fill_parent»
- android:layout_height = «fill_parent»
- android:orientation = «vertical» >
- LinearLayout
- android:layout_width = «fill_parent»
- android:layout_height = «wrap_content»
- android:orientation = «horizontal»
- android:layout_marginBottom = «20dip» >
- TextView
- android:layout_width = «wrap_content»
- android:layout_height = «wrap_content»
- android:layout_weight = «1»
- android:background = «#F00»
- android:text = «TextView1»
- android:textSize = «23sp»
- android:visibility = «visible»/>
- TextView
- android:id = «@+id/mainTV2»
- android:layout_width = «wrap_content»
- android:layout_height = «wrap_content»
- android:layout_weight = «1»
- android:background = «#00F»
- android:text = «TextView2»
- android:textSize = «23sp»
- android:visibility = «visible»/>
- LinearLayout >
- Button
- android:id = «@+id/mainBtn1»
- android:layout_width = «fill_parent»
- android:layout_height = «wrap_content»
- android:text = «TextView2 ВИДИМ»
- android:onClick = «mianOnClickListener»/>
- Button
- android:id = «@+id/mainBtn2»
- android:layout_width = «fill_parent»
- android:layout_height = «wrap_content»
- android:text = «TextView2 невидим»
- android:onClick = «mianOnClickListener»/>
- Button
- android:id = «@+id/mainBtn3»
- android:layout_width = «fill_parent»
- android:layout_height = «wrap_content»
- android:text = «TextView2 ушел»
- android:onClick = «mianOnClickListener»/>
- LinearLayout >
Пока последние три кнопки являются атрибутами, которые контролируют видимость TextView
- package com.chindroid.visibility;
- import android.app.Activity;
- import android.os.Bundle;
- import android.view.View;
- import android.widget.TextView;
- public class MainActivity extends Activity <
- /** TextView2 */
- private TextView mainTV2 = null ;
- @Override
- public void onCreate(Bundle savedInstanceState) <
- super .onCreate(savedInstanceState);
- setContentView(R.layout.main);
- // Инициализируем данные
- initData();
- >
- / ** Метод инициализации контроля * /
- private void initData() <
- mainTV2 = (TextView)findViewById(R.id.mainTV2);
- >
- /**
- Метод реагирования на событие нажатия кнопки в MainActivity
- *
- * @param v
- */
- public void mianOnClickListener(View v) <
- switch (v.getId()) <
- case R.id.mainBtn1: < // Событие ответа кнопки 1
- // Установить TextView2 как видимый
- mainTV2.setVisibility(View.VISIBLE);
- break ;
- >
- case R.id.mainBtn2: < // Событие ответа кнопки 2
- // Установить TextView2 как невидимый
- mainTV2.setVisibility(View.INVISIBLE);
- break ;
- >
- case R.id.mainBtn3: < // Ответное событие кнопки 3
- // Установить TextView2, чтобы скрыть
- mainTV2.setVisibility(View.GONE);
- break ;
- >
- default :
- break ;
- >
- >
- >
При запуске программы оба TextViews видны
Когда мы нажимаем первую кнопку и устанавливаем для свойства TextView2visibility значение INVISIBLE, процедура выглядит следующим образом:
Когда мы нажимаем третью кнопку и устанавливаем свойство TextView2visibility в GONE, процедура выглядит следующим образом:
Когда мы снова нажмем первую кнопку и установим свойство TextView2visibility в VISIBLE, TextView2 снова будет представлен, как показано на следующем рисунке:
VISIBLE: сделать элемент управления видимым
Невидимый: установите элемент управления невидимым
GONE: установить контроль, чтобы скрыть
Основное различие между INVISIBLE и GONE заключается в следующем: когда свойство видимости элемента управления равно INVISIBLE, интерфейс резервирует пространство, занимаемое элементом управления view, а когда свойство элемента управления равно GONE, интерфейс не сохраняет пространство, занимаемое элементом управления view.
Источник
Андроид: разница между невидимым и ушел?
в чем разница между invisible и gone для состояния видимости вида?
7 ответов:
этот вид невидим, но он по-прежнему занимает место для целей компоновки.
этот вид невидим, и он не занимает никакого места для целей компоновки.
вид.Ушел этот вид невидим, и он не занимает никакого места для цели макета.
вид.Невидимый этот вид невидим, но он по-прежнему занимает место для целей компоновки.
позволяет очистить идею с фотографии.
предположим, что у вас есть три кнопки, как показано ниже
теперь, если вы установите видимость кнопки два как невидимый ( View.INVISIBLE ), то вывод будет
и когда вы устанавливаете видимость кнопки два как ушел ( View.GONE ), то выход будет
надеюсь, что это прояснит ваши сомнения.
для ListView или GridView есть еще одно отличие, когда видимость изначально установлена в
функция getView () адаптера называется
функция getView () адаптера не вызывалась, что предотвращает загрузку представлений, когда это не нужно
невидимка:
вид должен быть нарисован, и это требует времени.
ушли:
вид не должен быть нарисован.
Я хотел бы добавить к правильным и успешным ответам, что если вы инициализируете представление с видимостью как View.GONE , представление могло быть не инициализировано, и вы получите некоторые случайные ошибки.
например, если вы инициализируете макет как View.GONE а затем вы пытаетесь запустить анимацию, из моего опыта у меня есть моя анимация работает случайным образом раз. Иногда да, иногда нет.
поэтому перед обработкой (изменение размера, перемещение, что угодно) представление, вы должны инициализировать его как View.VISIBLE или View.INVISIBLE чтобы отобразить его (нарисовать его) на экране, а затем обработать его.
вид.Невидимый->вид невидим, но он будет занимать некоторое пространство в макете
вид.Ушел->вид не виден, и он не будет занимать никакого места в макете
когда вы делаете его ушел каждый раз компиляции программы компонент инициализируется, что означает, что вы удаляете компонент из макета и когда вы делаете его невидимым компонент будет занимать то же место в макете, но каждый раз, когда вам не нужно, чтобы инициализировать его.
Если вы установили Visibility=Gone, то вам нужно инициализировать компонент..как
например кнопка _mButton = новая кнопка (это);
_mButton = (Кнопка) findViewByid (R. id. mButton);
Так что это займет больше времени по сравнению с Visibility = invisible.
Источник
Android: почему setVisibility (View.GONE); Или setVisibility (View.INVISIBLE); не работает
Я хочу, чтобы мой DatePicker и кнопка были невидимыми в начале. И когда я нажимаю свою волшебную кнопку, я хочу установитьVisibility (View.Visible);
Проблема здесь в том, что когда setVisibility(View.GONE) или setVisibility(View.INVISIBLE) ничего не меняется, и компонент все еще отображается.
Я вижу немало вещей не так. Во-первых, у вас нет определенной волшебной кнопки, и для нее нет обработчика событий.
Также вы не должны использовать:
Используйте только один из двух. Из документации для Android :
View.GONE Это представление невидимо, и для макета не требуется свободного места.
View.INVISIBLE Этот вид невидим, но он по-прежнему занимает пространство для макета.
В вашем примере вы переопределяете назначение View.GONE с помощью View.INVISIBLE .
Аналогично для других виджетов:
Вы можете рассматривать это как видимость и отображение стиля CSS.
Сначала просмотрите свой код:
Здесь вы устанавливаете видимость в одно и то же поле, поэтому проблема. Я даю один образец для этой демонстрации примера
View.GONE Это представление невидимо, и для макета не требуется свободного места.
View.INVISIBLE Этот вид невидим, но он по-прежнему занимает пространство для макета.
Сегодня у меня был сценарий, где я выполнял следующие действия:
Прямо на следующем кадре я выполнял проверку в другом месте для видимости этого представления. И угадай что? Проходило следующее условие:
Помещая точки останова, вы видите, что видимость меняется на GONE , но прямо на следующем кадре она волшебным образом становится VISIBLE . Я пытался понять, как, черт возьми, это может случиться.
Оказывается, на это представление была применена анимация, которая внутренне вызывала представление, чтобы изменить его видимость до VISIBLE до завершения анимации:
Если вы отлаживаете, вы увидите, что myViewGroup действительно меняет видимость на GONE , но прямо на следующем кадре он снова станет видимым для запуска анимации.
Итак, если вы сталкиваетесь с такой ситуацией, убедитесь, что вы не выполняете проверку в режиме оживления представления.
Вы можете удалить все анимации в представлении через View.clearAnimation () .
Потому что вы устанавливаете видимость как true, так и false. Попробуйте setVisible(0) для видимого true. and setVisible(4) до видимого false.
Источник
Android studio visibility gone
Войти
Авторизуясь в LiveJournal с помощью стороннего сервиса вы принимаете условия Пользовательского соглашения LiveJournal
Layouts (разметка)
Любая Activity (деятельность, окно приложения) состоит из Views и ViewGroups. View — виджет, который рисуется на экране, например, кнопка, текстовое поле, список. Все такие виджеты наследуются от класса android.view.View.
ViewGroup — разметка, позволяющая расположить один или несколько View. Разметки наследуются от класса android.view.ViewGroup, который в свою очередь наследуется от android.view.View. Это значит что дочерними элементами разметки могут быть не только View, но и сами разметки
Примеры ViewGroups:
— FrameLayout
— LinearLayout
— TableLayout
— RelativeLayout
— ScrollView
Рассмотрим их более подробно.
FrameLayout
FrameLayout — разметка для отображения одного элемента. Дочерние View или ViewGroup в FrameLayout выравниваются по верхнему левому углу. Разметка может содержать несколько элементов, но тогда они будут перекрывать друг друга. Например:
FrameLayout удобно использовать для нескольких элементов, которые скрываются и показываются программно, таким образом что в каждый момент времени видимым оказывается только один из них. Для управления видимостью элемента используется атрибут android:visibility в xml или метод setVisibility (int visibility), где visibility принимает одно из трех значений: LinearLayoutРазметка для отображения одного или нескольких элементов в одну линию, горизонтально или вертикально. Для выбора ориентации используется атрибут android:orientation с двумя возможными значениями «horizontal» и «vertical»
|