preface
- in
Android
Performance 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:
- To reduce
The ontouch ()
The complexity of the - 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:
- Control the number of overdraws as much as possible =
2
Below (green), blue is ideal - Avoid overly drawn pinks and reds whenever possible
- No more than 3 overdraws (light red) over 1/4 of the screen size are allowed
4.2.4 Optimization scheme
- Remove the default
Window
background - Remove unnecessary backgrounds from controls
- Reduce the hierarchy of layout files (nesting)
- Custom control View optimization: Use clipRect(), quickReject()
Optimization 1: Remove the default Window background
- Background Common applications inherit the theme = by default
windowBackground
, 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:
ListView
与Item
List 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:
ViewPager
与Fragment
For aViewPager
More than +Fragment
Composed of home page interface, if eachFragment
Both 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()
- Effect: Sets a clipping area to the Canvas. Only the clipping area will be drawn
- Examples:
DrawerLayout
Layout = 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()
- Function: Determine the intersection with a rectangle
- 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 the
The Android 4.1
Performance data sampling & analysis tools provided in previous versions - Function test
Android
Operating status of each component of the system over time & providing solutions
- Collect and other operating information to help developers more intuitively analyze system bottlenecks and improve performance detection, including:
Android
Critical subsystems (e.gWindowManagerService
等Framework
Some key modules), service, View system- Features include: tracking system
I/O
Operations, kernel work queues,CPU
Load, 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 explains
Android
Rendering 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