IT

Android P 가시성 knownimagebutton.setVisibility는 동일한 라이브러리 그룹에서 호출 할 수 있습니다.

lottoking 2020. 8. 3. 17:29
반응형

Android P 가시성 knownimagebutton.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
    }
}

여기에 이미지 설명을 입력하십시오

검색을 시도했지만 UI 가시성 변경에 응답하는 유일한 검색 결과는 다음과 같습니다.

https://developer.android.com/training/system-ui/visibility

나는 VISIBLEcom.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 canary 14를 사용하고 있다는 점에 유의해야합니다.이 버전에 대해보고 된 버그가있는 것 같으며 이것이 그중 하나 인 것 같습니다.

편집 2 :

문제는 여전히 안드로이드 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
}

방법 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);

보기에 캐스팅하기 위해 잘 작동하는 것 같습니다.

(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"

모범 사례 :

 android:visibility="Gone"

가시성을 사용하면 뷰가 레이아웃에서 공간을 차지하지 않고 "보이지 않음"이 레이아웃에서 불필요한 공간을 차지함을 의미합니다.

이 예에서 내 뷰는 ViewHolder에 있고 iam은 recylerview가있는 조각의 버튼을 참조합니다.


이것은 또한 작동합니다 :

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

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)

오류는 사라지고 처리 할 뷰 목록을 가져 와서 가시성 상태에 대한 유연성을 제공합니다. 마지막 예제 줄에 표시된 것처럼 한 번에 둘 이상의 뷰를 처리해야하는 경우가 많습니다.


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

참고 URL : https://stackoverflow.com/questions/50343634/android-p-visibilityawareimagebutton-setvisibility-can-only-be-called-from-the-s

반응형