Home | History | Annotate | Download | only in testing
      1 /*
      2  * Copyright (C) 2017 The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
      5  * except in compliance with the License. You may obtain a copy of the License at
      6  *
      7  *      http://www.apache.org/licenses/LICENSE-2.0
      8  *
      9  * Unless required by applicable law or agreed to in writing, software distributed under the
     10  * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
     11  * KIND, either express or implied. See the License for the specific language governing
     12  * permissions and limitations under the License.
     13  */
     14 
     15 package android.testing;
     16 
     17 import android.content.pm.ApplicationInfo;
     18 import android.graphics.PixelFormat;
     19 import android.view.View;
     20 import android.view.WindowManager;
     21 import android.view.WindowManager.LayoutParams;
     22 
     23 /**
     24  * Utilities to make testing views easier.
     25  */
     26 public class ViewUtils {
     27 
     28     /**
     29      * Causes the view (and its children) to have {@link View#onAttachedToWindow()} called.
     30      *
     31      * This is currently done by adding the view to a window.
     32      */
     33     public static void attachView(View view) {
     34         // Make sure hardware acceleration isn't turned on.
     35         view.getContext().getApplicationInfo().flags &=
     36                 ~(ApplicationInfo.FLAG_HARDWARE_ACCELERATED);
     37         WindowManager.LayoutParams lp = new WindowManager.LayoutParams(
     38                 LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT,
     39                 LayoutParams.TYPE_APPLICATION_OVERLAY,
     40                 0, PixelFormat.TRANSLUCENT);
     41         view.getContext().getSystemService(WindowManager.class).addView(view, lp);
     42     }
     43 
     44     /**
     45      * Causes the view (and its children) to have {@link View#onDetachedFromWindow()} called.
     46      *
     47      * This is currently done by removing the view from a window.
     48      */
     49     public static void detachView(View view) {
     50         view.getContext().getSystemService(WindowManager.class).removeViewImmediate(view);
     51     }
     52 }
     53