2014-10-01 12 views
10

Próbuję ustawić widoczność przycisku w następujący sposób:Nie stanie dynamicznie ustawić setVisibility() parametr

public Bundle setActivityState(Bundle bundle){ 
    startBtn = (Button) findViewById(R.id.startSensorsBtn); 

    startBtn.setVisibility(
      getVisibilityState(bundle, PersistanceConstants.START_BTN_STATE) 
    );   

    return bundle; 
} 

public int getVisibilityState(Bundle bundle, String keyName){ 
    if (bundle.getInt(keyName) == View.VISIBLE){ 
     return View.VISIBLE; 
    } else if (bundle.getInt(keyName) == View.INVISIBLE){ 
     return View.INVISIBLE; 
    } else if (bundle.getInt(keyName) == View.GONE){ 
     return View.GONE; 
    } 

    return 0; 
} 

Ale otrzymuję błąd:

Must be one of: View.VISIBLE, View.INVISIBLE, View.GONE less... (Ctrl+F1) 
Reports two types of problems: 
- Supplying the wrong type of resource identifier. For example, when calling Resources.getString(int id), you should be passing R.string.something, not R.drawable.something. 
- Passing the wrong constant to a method which expects one of a specific set of constants. For example, when calling View#setLayoutDirection, the parameter must be android.view.View.LAYOUT_DIRECTION_LTR or android.view.View.LAYOUT_DIRECTION_RTL. 

podczas wywoływania

getVisibilityState(bundle, PersistanceConstants.START_BTN_STATE) 

Nie wiem, jak sobie z tym poradzić. Rozumiem, że oczekuje on określonego zestawu wartości, ale wiem tylko, że przekazałem do niego numer int. Co można tutaj zrobić?

+0

opublikuj swój dziennik błędów .. – Sats

+0

getVisibilityState osiągnie linię 'return 0;'? proszę, opublikuj swój dziennik błędów. – wendigo

+0

Niestety, nie wspomniałem o tym. Otrzymuję to podczas kompilacji w Androidzie. – jsbisht

Odpowiedz

18

Kiedy wiesz, co robisz, można stłumić tę kontrolę Android Studio lokalnie z

//noinspection ResourceType 

Na przykład,

//noinspection ResourceType 
startBtn.setVisibility(bundle.getInt(PersistanceConstants.START_BTN_STATE)); 
+1

Wow. To się udało. Dzięki dużo Laalto. – jsbisht

17

Trochę późno do partii, ale innym rozwiązaniem, jeśli używają tego dużo w kodzie i masz metodę zwracającą, że int jest zdefiniowanie własnej adnotacji widoczności, więc coś takiego:

public class MyStuff { 

    @IntDef({View.VISIBLE, View.INVISIBLE, View.GONE}) 
    @Retention(RetentionPolicy.SOURCE) 
    public @interface Visibility { 
    } 

    public @Visibility int getVisibility() { 
     return View.GONE; 
    } 
} 

Jeśli to zrobisz, wtedy AS nie będzie już narzekać, ponieważ zwracasz prawidłową int def.

Powiązane problemy