Android P vidibilityawareimagebutton.setVisibility можна викликати лише з тієї ж групи бібліотек


143

Я намагаюся використовувати новий 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
    }
}

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

Я намагався шукати, і єдиний результат пошуку - це відповідь на зміни видимості інтерфейсу користувача:

Відповідь на зміни видимості інтерфейсу користувача

Я спробував дослідити, як я міг зрозуміти, чи є VISIBLEв цьому com.google.android.materialпакеті значення int і єдине, що я знайшов, було 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 каналу 14. Схоже, було повідомлення про помилки для цієї версії, і я підозрюю, що це одна з них.

редагувати 2:

Проблема все ще існує у Android Studio версії 3.2 canary 15, але я знайшов рішення для цього за допомогою show()таhide()

override fun onCreate(savedInstanceState: Bundle?) {
    demoFab = findViewById(R.id.demoFab)
    demoFab.show()    // this works and doesn't have the warning
}

Правильний пакет - android.support.design.widget.FloatingActionButton
Панкай Кумар

За допомогою Android P та Jetpack Fab було переміщено до цього пакету, саме це я намагаюся використовувати. developer.android.com/reference/com/google/android/material/…
Кайл Фальконер

@KyleFalconer Canary 15 тепер доступний, перевірте, чи оновлення може вирішити вашу проблему :)
Леві Морейра

2
@PankajKumar Yup, все ще зламаний, але я знайшов інше рішення для цього (до мого запитання додав "редагувати 2").
Кайл Фальконер

5
У цьому питанні описується помилка: issueetracker.google.com/isissue/115924750 На жаль, рішення та виправлення atm немає, тому, ймовірно, кожен із них, на кого це постраждало, повинен мати зірочку.
ChristophK

Відповіді:


266

Використання методу 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() {
    ....
}

оновлення:

Спосіб 3:

demoFab.setVisibility(View.GONE);
demoFab.setVisibility(View.INVISIBLE);
demoFab.setVisibility(View.VISIBLE);

Спосіб 4:

demoFab.visibility = View.GONE
demoFab.visibility = View.INVISIBLE
demoFab.visibility = View.VISIBLE

2
Це також додає прекрасну анімацію!
ROR

1
привіт, чи існують НЕВІДОМНІ методи?
Siarhei

Використання .show () може видалити попередження, але є одна проблема: якщо FAB встановив, наприклад, у XML, android: alpha = "0.5" для прозорості, прозорість тоді не працює. Як виправити цю проблему? Натомість я віддаю перевагу використовувати demoFab.visibility = View.VISIBLE, якщо .show () не може працювати на android: alpha
Fisher

методи показувати і ховати ідеально підходять для стандартних плаваючих кнопок дій.
FirestormXYZ

9

Здається, добре працює лише для того, щоб кинути його на вигляд.

(mFloatingActionButton as View).visibility = INVISIBLE

Звичайно, потрібно пам’ятати, що видимість може впливати на інші компоненти, тому, ймовірно, ви повинні використовувати show()і hide()в той же час переконуватись про інші компоненти про зміну.


5
що робити, якщо я хочу встановити видимість на GONE замість NEVISIBLE?
Чарлі

1
@charlie Яку різницю ви очікуєте між GONE та NEVISIBLE від плаваючої кнопки дії? Панель зазвичай лежить над іншою частиною макета, тому вона не займає місця.
Неймовірний

6

Використання:

 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"

Найкраща практика:

 android:visibility="Gone"

Використання відсутності видимості означає, що ваш погляд не займає місця у вашій макеті, тоді як "невидимий" займе зайвий простір у вашій макеті

У цьому прикладі: Мої перегляди знаходяться у ViewHolder, і я посилаюся на кнопки фрагмента aa з переглядом рецилер


3

Це також працює:

findViewById(R.id.fab).setVisibility(View.GONE);

Так, це є. Я використовував фрагмент у своєму прикладі: setVisibility (View.GONE); не завжди працює у фрагментах, особливо коли ви заявляли про свої погляди в viewHolder, який знаходиться в окремому власному класі, і ви просто посилаєтесь на Viewholder.
RileyManda

0

Для Котліна у мене є метод розширення

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)

Помилки не буде, і це надає гнучкість для будь-якого стану видимості, а також використання списку переглядів для обробки. Дуже багато разів мені потрібно обробляти більше, ніж один вид, як показано в заключному рядку прикладу.


0
if(data){
            fragmentPendingApprovalDetailsBinding.fabPendingList.show();
        }else {
            fragmentPendingApprovalDetailsBinding.fabPendingList.hide();
        }

0

Для com.google.android.material.floatingactionbutton.FloatingActionButton

Видимість

Використовуйте методи показу та приховування, щоб оживити видимість кнопки FloatingAction. Показ анімації зростає віджет і зникає в ньому, тоді як анімація приховування зменшує віджет і зникає.

Джерело: https://material.io/develop/android/components/floating-action-button/

Для android.support.design.widget.FloatingActionButton використання setVisibility()Метод


0

Для мене вищезгадані методи не працювали, тому я створив функцію розширення, щоб змусити її працювати.

fun View.showView() {
    this.visibility = View.VISIBLE
}

fun View.hideView() {
    this.visibility = View.GONE
}

тепер дзвоніть, як

binding.fabAdded.showView()
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.