Android P visibilityawareimagebutton.setVisibility может вызываться только из одной и той же группы библиотек.
Я пытаюсь использовать новый Android P FloatingActionButton, который является частью com.google.android.material.floatingactionbutton.FloatingActionButton
и я получаю это предупреждение:
VisibilityAwareImageButton.setVisibility может вызываться только из одной и той же группы библиотек (groupId=com.google.android.material).
import com.google.android.material.floatingactionbutton.FloatingActionButton
import android.view.View
class MainActivity : AppCompatActivity() {
lateinit var demoFab: FloatingActionButton
override fun onCreate(savedInstanceState: Bundle?) {
demoFab = findViewById(R.id.demoFab)
demoFab.visibility = View.VISIBLE // the warning is here
}
}
Я попытался выполнить поиск, и единственный результат поиска относится к ответам на изменения видимости пользовательского интерфейса:
https://developer.android.com/training/system-ui/visibility
Я попытался изучить, как я мог видеть, был ли VISIBLE
значение int в этом com.google.android.material
пакет, и единственный, который я нашел, был com.google.android.material.floatingactionbutton.FloatingActionButton.VISIBLE
, но предупреждение все еще остается.
Build.gradle верхнего уровня
buildscript {
ext.kotlin_version = '1.2.41'
repositories {
google()
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:3.2.0-alpha14'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
classpath "com.google.gms:oss-licenses:0.9.2"
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
google()
jcenter()
mavenCentral()
maven { url "http://oss.sonatype.org/content/repositories/snapshots/" }
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
Уровень проекта build.gradle
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
apply plugin: 'com.google.gms.oss.licenses.plugin'
android {
compileSdkVersion 'android-P'
defaultConfig {
applicationId "com.codeforsanjose.maps.pacmap"
minSdkVersion 21
targetSdkVersion 'P'
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
splits {
abi {
enable true
reset()
include 'arm64-v8a', 'armeabi', 'armeabi-v7a', 'mips', 'x86', 'x86_64'
universalApk false
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
buildTypes {
release {
minifyEnabled true
shrinkResources true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
implementation 'androidx.appcompat:appcompat:1.0.0-alpha1'
implementation 'androidx.constraintlayout:constraintlayout:1.1.0'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test:runner:1.1.0-alpha2'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.0-alpha2'
implementation 'com.mapbox.mapboxsdk:mapbox-android-sdk:5.5.2'
//implementation 'com.mapbox.mapboxsdk:mapbox-android-sdk:6.1.0'
implementation 'com.mapbox.mapboxsdk:mapbox-android-plugin-locationlayer:0.5.0'
implementation 'com.mapbox.mapboxsdk:mapbox-android-navigation:0.13.0'
implementation 'com.mapbox.mapboxsdk:mapbox-android-navigation-ui:0.13.0'
implementation 'com.google.android.gms:play-services-oss-licenses:15.0.1'
implementation 'com.google.code.gson:gson:2.8.2'
implementation 'com.squareup.moshi:moshi:1.5.0'
implementation 'com.squareup.okhttp3:logging-interceptor:3.10.0'
implementation 'com.squareup.retrofit2:converter-gson:2.3.0'
implementation 'com.squareup.retrofit2:converter-moshi:2.4.0'
implementation "com.squareup.retrofit2:adapter-rxjava2:2.3.0"
implementation 'com.squareup.retrofit2:retrofit:2.4.0'
implementation 'io.reactivex.rxjava2:rxandroid:2.0.1'
implementation 'io.reactivex.rxjava2:rxkotlin:2.2.0'
}
редактировать:
Должен заметить, что я использую Android Studio версии 3.2 canary 14. Кажется, в этой версии было зарегистрировано несколько ошибок, и я подозреваю, что это одна из них.
редактировать 2:
Проблема по-прежнему существует с Android Studio версии 3.2 канарейка 15, но я нашел решение для этого с помощью show()
а также hide()
override fun onCreate(savedInstanceState: Bundle?) {
demoFab = findViewById(R.id.demoFab)
demoFab.show() // this works and doesn't have the warning
}
3 ответа
Используя метод 1
demoFab.show(); // in place of visible
demoFab.hide(); // in place of Invisible suppress the warning/error for me.
Используя метод 2
@SuppressLint("RestrictedApi") // also suppressed the warning
private void setUp() {
....//do what you want
}
Кажется, работает нормально, только чтобы привести его к виду.
(mFloatingActionButton as View).visibility = INVISIBLE
Конечно, вы должны помнить, что видимость может повлиять на другие компоненты, поэтому вы, вероятно, должны использовать show()
а также hide()
в то же время, чтобы другие компоненты были уведомлены об изменении.
Использование:
myButton.hide();
myClearButton.hide();
Типичным примером будет:
Скрытие и отображение кнопок, когда пользователь печатает или фокусируется на ресурсе EditText:
проверьте, печатает ли пользователь или имеет фокус:
mCommentField.setOnFocusChangeListener(new View.OnFocusChangeListener() {
@Override
public void onFocusChange(View view, boolean hasFocus) {
if (hasFocus) {
//user has focused
showBts();
} else {
//focus has stopped perform your desired action
hideButtons();
}
}
});
Спрятать и показать методы кнопки:
private void hideButtons() {
mCommentButton.hide();
mClearButton.hide();
}
private void showBts() {
mCommentButton. show();
mClearButton.show();
А в xml по умолчанию установите кнопки невидимыми, чтобы они отображались / отображались только тогда, когда пользователь имеет фокус или печатает:
android:visibility="invisible"
Это также работает:
findViewById(R.id.fab).setVisibility(View.GONE);
Для меня вышеуказанные методы не работали, поэтому я создал функцию расширения, чтобы она работала.
fun View.showView() {
this.visibility = View.VISIBLE
}
fun View.hideView() {
this.visibility = View.GONE
}
теперь звони как
binding.fabAdded.showView()
if(data){
fragmentPendingApprovalDetailsBinding.fabPendingList.show();
}else {
fragmentPendingApprovalDetailsBinding.fabPendingList.hide();
}
За com.google.android.material.floatingactionbutton.FloatingActionButton
Видимость
Используйте методы show и hide, чтобы оживить видимость FloatingActionButton. Анимация показа увеличивает виджет и исчезает, в то время как анимация скрытия сжимает виджет и исчезает.
Источник: https://material.io/develop/android/components/floating-action-button/
За android.support.design.widget.FloatingActionButton
использовать setVisibility()
Метод
Для Kotlin у меня есть метод расширения
fun viewsVisibility(visibility: Int, vararg views: View) {
for (view in views) { view.visibility = visibility }
}
Затем в коде вы можете сделать следующее
viewsVisibility(View.VISIBLE, demoFab)
viewsVisibility(View.GONE, demoFab)
viewsVisibility(View.INVISIBLE, demoFab, addFab, removeFab)
Ошибка исчезнет, и это дает гибкость для любого состояния видимости наряду с получением списка представлений для обработки. Много раз мне нужно обрабатывать более одного представления одновременно, как показано в последней строке примера.