preface

  • inAndroidPerformance optimization strategies are very important in development
  • This article focuses on rendering optimization in performance optimization. I hope you enjoyed it.

directory


1. Affected performance

The main impact of drawing performance is: page display speed in Android applications


2. How does it affect performance

The essence of drawing that affects Android performance: the drawing time of the page

One page is measured and drawn recursively


3. Optimize your thinking

The main optimization directions are as follows:

  1. To reduceThe ontouch ()The complexity of the
  2. Avoid overdrawing(Overdraw)

4. Specific optimization plan

  • Specific as follows

  • Below, I examine each optimization in detail

4.1. Reduce the complexity of view.ondraw ()

Do not create new local objects in 4.1.1 onDraw ()

4.1.2 Avoid onDraw () performing heavy & time-consuming operations

4.2 Avoid overdrawing

4.2.1 Introduction to overdrawing

4.2.2 Forms of over-drawing

Overdrawing will result in different color blocks on the screen, as shown below

Attached: Illustration

4.2.3 Optimization principle of over-drawing

Many overdraws are unavoidable, such as the text & background in the above example; Overdrawing can only be avoided if possible:

  1. Control the number of overdraws as much as possible =2Below (green), blue is ideal
  2. Avoid overly drawn pinks and reds whenever possible
  3. No more than 3 overdraws (light red) over 1/4 of the screen size are allowed

4.2.4 Optimization scheme

  1. Remove the defaultWindowbackground
  2. Remove unnecessary backgrounds from controls
  3. Reduce the hierarchy of layout files (nesting)
  4. Custom control View optimization: Use clipRect(), quickReject()

Optimization 1: Remove the default Window background

  • Background Common applications inherit the theme = by defaultwindowBackground, such as the default Light theme:
<style name="Theme.Light">
    <item name="isLightTheme">true</item>
    <item name="windowBackground">@drawable/screen_background_selector_light</item>
    ...
</style>
Copy the code
  • In general, the default Window background is useless: if the background is not removed, all screens will be drawn one more time

  • Solution Removes the default Window background

Method 1: Add the following line attribute <item name= to the subject of the application"android:windowBackground">@android:color/transparent</item> <! --> <item name="android:windowBackground">@null</item> // Method 2: Remove getWindow().setBackgroundDrawable(null) using the following code in the BaseActivity onCreate() method; <! - or - > getWindow (). SetBackgroundDrawableResource (android. R.c olor. Transparent);Copy the code

Optimization 2: Remove unnecessary backgrounds from controls

For example, there are two common scenarios:

  • Scenario 1:ListViewItemList of pp.(ListView)And its inner child controls(Item)The background is the same = white, so the child control can be removed(Item)Background in layout

  • Scenario 2:ViewPagerFragmentFor aViewPagerMore than +FragmentComposed of home page interface, if eachFragmentBoth have a background color, that is, the ViewPager does not need to be set and can be removed

For more scenarios, you can use the Hierarchy View tool, as described in the article: Hierarchy View for transition drawing

Optimization 3: Reduce the hierarchy of layout files (reduce unnecessary nesting)

  • Principle: Reduce unnecessary nesting ->> fewer UI levels ->> low likelihood of overdrawing
  • Optimization: Use layout tags<merge>& Suitable layout type

This is a detailed layout optimization guide (including include, Viewstub, merge).

Optimization solution 4: Custom control View optimization: Use clipRect(), quickReject()

  • clipRect()
    1. Effect: Sets a clipping area to the Canvas. Only the clipping area will be drawn
    2. Examples:DrawerLayoutLayout = left drawer layout

@Override protected boolean drawChild(Canvas canvas, View child, long drawingTim // ... 1. Traverse the DrawerLayout child view to get the DrawerLayoutfor (int i = 0; i < childCount; i++) {
            final View v = getChildAt(i);
            if(v == child || v.getVisibility() ! = VISIBLE || ! hasOpaqueBackground(v) || ! isDrawerView(v) || v.getHeight() < height) {continue; } // a. If the left drawer layout // take the right edge of the drawer layout as the left edge of the clipping area and set the clipping area of the original main layout, as shown in the figure aboveif (checkDrawerViewAbsoluteGravity(v, Gravity.LEFT)) {
                final int vright = v.getRight();
                if(vright > clipLeft) clipLeft = vright; B. For the right drawer layout // Take the left edge of the drawer layout as the right edge of the clipping area and set the clipping area of the original main layout}else {
                final int vleft = v.getLeft();
                if(vleft < clipRight) clipRight = vleft; }} // 2. Use clipRect () to set the display range of the original main layout = clipping area, Make it display // only in the red box area of the figure above (that does not block drawer layout) to avoid overdrawing canvas. ClipRect (clipLeft, 0, clipRight, getHeight()); }... }Copy the code
  • quickreject()
    1. Function: Determine the intersection with a rectangle
    2. Specific measures: if it is judged that it intersects with the rectangle, the intersecting area can be skipped to reduce excessive drawing

4.3 Other optimization schemes

conclusion

At this point, about the rendering optimization program is finished.

5. Layout tuning tools

  • Background Although the above optimization strategies have been noted, layout performance problems are inevitable in actual development
  • The solution uses layout tuning tools

Hierarchy Viewer, Profile GPU Rendering and Systrace are mainly introduced here

5.1 Hierarchy Viewer

  • This section describes the UI performance monitoring tool provided by Android Studio.

  • Function visualization of UI layout design structure & various attribute information to help us optimize layout design

That is: easy to View the Activity layout, the attributes of each View, layout measurement – layout – drawing time

  • Hierarchy Viewer usage guide

5.2 Profile GPU Rendering

  • Introduces a graph monitoring tool

  • Function rendering, rendering performance tracking

It can reflect the current drawing time in real time

  • Horizontal axis = time, vertical axis = time per frame; Refresh rendering from left to right over time

Provides a standard time. If the time is higher than the standard time, the current frame is lost

For more details, see: Profile GPU Rendering User Guide

5.3 Systrace

  • Introduction to theThe Android 4.1Performance data sampling & analysis tools provided in previous versions
  • Function testAndroidOperating status of each component of the system over time & providing solutions
  1. Collect and other operating information to help developers more intuitively analyze system bottlenecks and improve performance detection, including:AndroidCritical subsystems (e.gWindowManagerServiceFrameworkSome key modules), service, View system
  2. Features include: tracking systemI/OOperations, kernel work queues,CPULoad, etc., provides good data on UI display performance analysis, especially on issues such as poor animation playback, rendering lag, etc
  • Systrace Usage Guide

6. Summary

  • This paper mainly explainsAndroidRendering optimization in performance optimization

I’m going to take a closer look at performance optimization in Android, and those of you who are interested can stay tuned to my rare-earth mining blog


Thumb up, please! Because your encouragement is the biggest power that I write!