2015-12-15 21 views
8

Sto tentando di impedire l'espansione della barra di stato e ho utilizzato alcuni esempi in cui le persone stanno cercando di ignorare il pulsante home. Tutte le soluzioni puntano all'utilizzo di WindowManager.LayoutParams.TYPE_KEYGUARD, ho letto here, che se si utilizza TYPE_KEYGUARD, il target minimo deve essere inferiore a 14. TYPE_KEYGUARD è deprecato, quindi avrò bisogno di un aggiramento anche per questo. È completamente rimosso dall'SDK 21.Il target minimo deve essere inferiore a 14 quando WindowManager.LayoutParams.TYPE_KEYGUARD utilizzato

DOMANDA: Che cos'è una soluzione alternativa in modo che sia possibile ignorare la barra di stato e mantenere la build di destinazione su 19?

Ho un progetto istituito per costruire in questo modo:

android { 
    compileSdkVersion 17 
    buildToolsVersion "21.1.2" 

    defaultConfig { 
     applicationId "com.mycompany.ediary" 
     minSdkVersion 12 
     targetSdkVersion 12 
    } 

    buildTypes { 
     release { 
     minifyEnabled false 
     proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt' 
     } 
    } 
} 

Ho provato il consiglio here senza alcun risultato. Vorrei che targetSdkVersion fosse 19, ma se lo cambio a 19, ottengo l'IllegalArgumentException. StackTrace:

11-26 13:41:57.963 28667-28667/com.assistek.ediary E/AndroidRuntime﹕ FATAL EXCEPTION: main 
Process: com.assistek.ediary, PID: 28667 
java.lang.IllegalArgumentException: Window type can not be changed after the window is added. 
    at android.os.Parcel.readException(Parcel.java:1550) 
    at android.os.Parcel.readException(Parcel.java:1499) 
    at android.view.IWindowSession$Stub$Proxy.relayout(IWindowSession.java:903) 
    at android.view.ViewRootImpl.relayoutWindow(ViewRootImpl.java:5301) 
    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1507) 
    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1061) 
    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5885) 
    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:767) 
    at android.view.Choreographer.doCallbacks(Choreographer.java:580) 
    at android.view.Choreographer.doFrame(Choreographer.java:550) 
    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:753) 
    at android.os.Handler.handleCallback(Handler.java:739) 
    at android.os.Handler.dispatchMessage(Handler.java:95) 
    at android.os.Looper.loop(Looper.java:135) 
    at android.app.ActivityThread.main(ActivityThread.java:5254) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:372) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 

mio onCreate:

@Override 
protected void onCreate(Bundle savedInstanceState) { 

    requestWindowFeature(Window.FEATURE_NO_TITLE); 
    super.onCreate(savedInstanceState); 
    ... 
} 

mio onAttachedToWindow:

@Override 
public void onAttachedToWindow() { 
    super.onAttachedToWindow(); 
    getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); 
    this.getWindow().setType(WindowManager.LayoutParams.TYPE_KEYGUARD); 

    if (!GlobalVars.testing) { 
     GlobalVars.preventStatusBarExpansion(this); 
    } 
    } 

E il codice che impedisce l'espansione barra di stato (adattato da this post):

public static void preventStatusBarExpansion(Context context) { 
    WindowManager manager = ((WindowManager) context.getApplicationContext() 
      .getSystemService(Context.WINDOW_SERVICE)); 

    WindowManager.LayoutParams localLayoutParams = new WindowManager.LayoutParams(); 
    localLayoutParams.type = WindowManager.LayoutParams.TYPE_SYSTEM_ERROR; 
    localLayoutParams.gravity = Gravity.TOP; 
    localLayoutParams.flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE| 

      // this is to enable the notification to recieve touch events 
      WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL | 

      // Draws over status bar 
      WindowManager.LayoutParams.FLAG_LAYOUT_IN_SCREEN; 

    localLayoutParams.width = WindowManager.LayoutParams.MATCH_PARENT; 
    localLayoutParams.height = (int) (50 * context.getResources() 
      .getDisplayMetrics().scaledDensity); 
    localLayoutParams.format = PixelFormat.TRANSPARENT; 

    customViewGroup view = new customViewGroup(context); 

    manager.addView(view, localLayoutParams); 
} 

public static class customViewGroup extends ViewGroup { 

    public customViewGroup(Context context) { 
     super(context); 
    } 

    @Override 
    protected void onLayout(boolean changed, int l, int t, int r, int b) { 
    } 

    @Override 
    public boolean onInterceptTouchEvent(MotionEvent ev) { 
     Log.v("customViewGroup", "**********Intercepted"); 
     return true; 
    } 
} 
+1

Prova questo post: https://stackoverflow.com/ domande/19920052/disable-the-notification-panel-from-being-down-down – DH28

risposta

6

Aggiornamento onAttachedToWindow come mostrato di seguito e cercare

@Override 
public void onAttachedToWindow() { 
    if (!GlobalVars.testing) { 
     GlobalVars.preventStatusBarExpansion(this); 
    } 
    super.onAttachedToWindow(); 
} 

e aggiungere aggiornamento OnCreate con

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    requestWindowFeature(Window.FEATURE_NO_TITLE); 
    super.onCreate(savedInstanceState); 
    getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); 
    this.getWindow().setType(WindowManager.LayoutParams.TYPE_KEYGUARD); 
    ... 
} 

Per Api sopra 14 utilizzo

this.getWindow().setType(WindowManager.LayoutParams.TYPE_KEYGUARD_DIALOG); 
+0

Grazie per la risposta. Lo proverò! –

+0

È stato risolto il problema? – SachinS

+0

Ottiene ancora l'eccezione IllegalArgument. Ha funzionato per un po ', poi improvvisamente ha smesso di funzionare. –