Android P visibleawareimagebutton.setVisibility può essere chiamato solo dallo stesso gruppo di librerie


143

Sto cercando di utilizzare il nuovo Android P FloatingActionButton che fa parte del com.google.android.material.floatingactionbutton.FloatingActionButtone sto ricevendo questo avviso:

VisibilityAwareImageButton.setVisibility può essere chiamato solo dallo stesso gruppo di librerie (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
    }
}

inserisci qui la descrizione dell'immagine

Ho provato a cercare e l'unico risultato di ricerca riguarda la risposta alle modifiche alla visibilità dell'interfaccia utente:

Rispondi alle modifiche alla visibilità dell'interfaccia utente

Ho provato a esplorare come ho potuto vedere se c'era un VISIBLEvalore int in quel com.google.android.materialpacchetto e l'unico che ho trovato era com.google.android.material.floatingactionbutton.FloatingActionButton.VISIBLE, ma l'avviso rimane ancora.

Build.gradle di livello superiore

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 a livello di progetto

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'
}

modificare:

Dovrei notare che sto usando Android Studio versione 3.2 canary 14. Sembra che ci siano stati alcuni bug segnalati per questa versione e sospetto che questo sia uno di questi.

modifica 2:

Il problema persiste con Android Studio versione 3.2 canary 15, ma ho trovato una soluzione alternativa usando show()ehide()

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

Il pacchetto corretto è android.support.design.widget.FloatingActionButton
Pankaj Kumar

Con Android P e Jetpack, Fab è stato spostato in questo pacchetto, è quello che sto cercando di usare. developer.android.com/reference/com/google/android/material/…
Kyle Falconer

@KyleFalconer Canary 15 è ora disponibile, controlla se l'aggiornamento può risolvere il tuo problema :)
Levi Moreira,

2
@PankajKumar Yup, ancora rotto, ma ho trovato un'altra soluzione alternativa (aggiunto "modifica 2" alla mia domanda).
Kyle Falconer,

5
Questo problema descrive il bug: issuetracker.google.com/issues/115924750 Sfortunatamente, non esiste una soluzione o un atm di correzione, quindi probabilmente tutti quelli che ne sono interessati dovrebbero iniziare .
ChristophK,

Risposte:


266

Utilizzando il metodo 1

demoFab.show(); // in place of visible
demoFab.hide(); // in place of Invisible suppress the warning/error for me.

e metodo 2

@SuppressLint("RestrictedApi") // also suppressed the warning
private void setUp() {
    ....
}

aggiornare:

Metodo 3:

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

Metodo 4:

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

2
Questo aggiunge anche una bella animazione!
ror

1
ciao, ci sono metodi ANDATI e INVISIBILI?
Siarhei,

L'uso di .show () può rimuovere l'avvertimento, ma c'è un problema: se il FAB ha impostato, ad esempio in XML, android: alpha = "0,5" per la trasparenza, la trasparenza non funziona quindi. Come risolvere questo problema? Preferirò invece usare demoFab.visibility = View.VISIBLE se .show () non funziona su Android: alpha
Fisher

i metodi show and hide sono perfetti per i pulsanti di azione fluttuanti standard.
FirestormXYZ il

9

Sembra funzionare bene solo per proiettarlo in una vista.

(mFloatingActionButton as View).visibility = INVISIBLE

Naturalmente è necessario ricordare che la visibilità può influire su altri componenti, quindi è consigliabile utilizzarli show()e hide()allo stesso tempo assicurarsi che altri componenti vengano informati della modifica.


5
e se volessi impostare la visibilità su GONE anziché su INVISIBLE?
charlie,

1
@charlie Che differenza ti aspetti tra GONE e INVISIBLE da un pulsante di azione mobile? Un fab di solito si trova sopra il resto del layout, quindi non occupa spazio.
L'incredibile

6

Uso:

 myButton.hide();
 myClearButton.hide();

Un esempio tipico sarebbe:

Nascondere e mostrare i pulsanti quando l'utente sta digitando o si concentra su una risorsa EditText:

controlla se l'utente sta scrivendo o ha lo stato attivo:

 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();
            }
        }


    });

Nascondi e mostra i metodi dei pulsanti:

private void hideButtons() {

    mCommentButton.hide();
    mClearButton.hide();
}

private void showBts() {

    mCommentButton. show();
    mClearButton.show();

E nel tuo XML, imposta i pulsanti su invisibile per impostazione predefinita in modo che vengano visualizzati / mostrati solo quando un utente ha lo stato attivo o sta digitando:

android:visibility="invisible"

La migliore pratica:

 android:visibility="Gone"

L'uso della visibilità non significa che la visualizzazione non occupi spazio sul layout mentre "invisibile" occuperà spazio non necessario sul layout

In questo esempio: Le mie viste sono in ViewHolder e iam fanno riferimento ai pulsanti di un frammento con una vista recylerv


3

Questo funziona anche:

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

Sì. Nel mio esempio stavo usando un frammento: setVisibility (View.GONE); non funziona sempre in frammenti soprattutto quando hai dichiarato le tue viste in un viewHolder che è in una classe separata e stai semplicemente facendo riferimento al Viewholder.
RileyManda,

0

Per Kotlin ho un metodo di estensione

fun viewsVisibility(visibility: Int, vararg views: View) {
    for (view in views) { view.visibility = visibility }
}

Quindi in poi nel codice è possibile effettuare le seguenti operazioni

viewsVisibility(View.VISIBLE, demoFab) 
viewsVisibility(View.GONE, demoFab)
viewsVisibility(View.INVISIBLE, demoFab, addFab, removeFab)

L'errore sparirà e questo darà la flessibilità per qualsiasi stato di visibilità oltre a prendere un elenco di viste da gestire. Ci sono molte volte che devo gestire più di una vista alla volta, come mostrato nella riga di esempio finale.


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

0

Per com.google.android.material.floatingactionbutton.FloatingActionButton

Visibilità

Utilizzare i metodi show e hide per animare la visibilità di un FloatingActionButton. L'animazione mostra fa crescere il widget e lo sfuma, mentre l'animazione nasconde il widget lo fa svanire.

Fonte: https://material.io/develop/android/components/floating-action-button/

Per android.support.design.widget.FloatingActionButton usare il setVisibility()metodo


0

Per me sopra i metodi non hanno funzionato, quindi ho creato una funzione di estensione per farlo funzionare.

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

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

ora chiama come

binding.fabAdded.showView()
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.