音量彈框 背景有鋸齒不夠絲滑

image.png

處理方式1:自定義背景替換掉原本背景框

Index: frameworks/base/packages/SystemUI/src/com/android/systemui/volume/VolumeDialogImpl.java
===================================================================
@@ -634,8 +634,8 @@
     }
 
     private boolean isLandscape() {
-        return mContext.getResources().getConfiguration().orientation ==
-                Configuration.ORIENTATION_LANDSCAPE;
+        // return false;
+        return mContext.getResources().getConfiguration().orientation ==Configuration.ORIENTATION_LANDSCAPE;
     }
 
     private boolean isRtl() {
@@ -2038,7 +2038,7 @@
         background.setLayerSize(0, mDialogWidth,
                 !isLandscape()
                         ? mDialogRowsView.getHeight()
-                        : mDialogRowsView.getHeight() + mDialogCornerRadius);
+                        : mDialogRowsView.getHeight() +mDialogCornerRadius);
         // Inset the top so that the color only renders below the ringer drawer, which has its own
         // background. In landscape, reduce the inset slightly since we are using the background to
         // fill in the corners of the closed ringer drawer.
@@ -2045,7 +2045,7 @@
         background.setLayerInsetTop(0,
                 !isLandscape()
                         ? mDialogRowsViewContainer.getTop()
-                        : mDialogRowsViewContainer.getTop() - mDialogCornerRadius);
+                        : mDialogRowsViewContainer.getTop()- mDialogCornerRadius); 
 
         // Set gravity to top-right, since additional rows will be added on the left.
         background.setLayerGravity(0, Gravity.TOP | Gravity.RIGHT);
@@ -2063,9 +2063,10 @@
                 }
             });
             mRingerAndDrawerContainer.setClipToOutline(true);
+            mTopContainer.setBackgroundResource(R.drawable.volume_drawer_land_bg);
+        }else {
+            mTopContainer.setBackground(background);
         }
-
-        mTopContainer.setBackground(background);
     }
 
     private final VolumeDialogController.Callbacks mControllerCallbackH

繪制背景

Index: frameworks/base/packages/SystemUI/res/drawable/volume_drawer_land_bg.xml
===================================================================
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!--
+  ~ Copyright (C) 2021 The Android Open Source Project
+  ~
+  ~ Licensed under the Apache License, Version 2.0 (the "License");
+  ~ you may not use this file except in compliance with the License.
+  ~ You may obtain a copy of the License at
+  ~
+  ~      http://www.apache.org/licenses/LICENSE-2.0
+  ~
+  ~ Unless required by applicable law or agreed to in writing, software
+  ~ distributed under the License is distributed on an "AS IS" BASIS,
+  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+  ~ See the License for the specific language governing permissions and
+  ~ limitations under the License
+  -->
+<layer-list xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:androidprv="http://schemas.android.com/apk/prv/res/android">
+   <!-- 主體部分 -->
+    <item>
+        <shape android:shape="rectangle">
+            <solid android:color="@android:color/transparent"/> <!-- 紅色 -->
+            <size android:width="@dimen/volume_dialog_panel_width" />
+        </shape>
+    </item>
+    <item
+        android:left="@dimen/volume_dialog_panel_width">
+        <shape>
+            <size android:width="@dimen/volume_dialog_panel_width" />
+            <solid android:color="?androidprv:attr/colorSurface" />
+            <corners android:radius="@dimen/volume_dialog_panel_width_half"/>
+        </shape>
+    </item>
+</layer-list>
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末拾徙,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子饲梭,更是在濱河造成了極大的恐慌跛蛋,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件昏兆,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機醉箕,發(fā)現死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來徙垫,“玉大人讥裤,你說我怎么就攤上這事∫霰ǎ” “怎么了己英?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長吴旋。 經常有香客問我损肛,道長,這世上最難降的妖魔是什么邮府? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任荧关,我火速辦了婚禮,結果婚禮上褂傀,老公的妹妹穿的比我還像新娘忍啤。我一直安慰自己,他們只是感情好仙辟,可當我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布同波。 她就那樣靜靜地躺著,像睡著了一般叠国。 火紅的嫁衣襯著肌膚如雪未檩。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天粟焊,我揣著相機與錄音冤狡,去河邊找鬼。 笑死项棠,一個胖子當著我的面吹牛悲雳,可吹牛的內容都是我干的。 我是一名探鬼主播香追,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼合瓢,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了透典?” 一聲冷哼從身側響起晴楔,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤顿苇,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后税弃,有當地人在樹林里發(fā)現了一具尸體纪岁,經...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年钙皮,在試婚紗的時候發(fā)現自己被綠了蜂科。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡短条,死狀恐怖导匣,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情茸时,我是刑警寧澤贡定,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站可都,受9級特大地震影響缓待,放射性物質發(fā)生泄漏。R本人自食惡果不足惜渠牲,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一旋炒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧签杈,春花似錦瘫镇、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至鹦付,卻和暖如春尚粘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背敲长。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工郎嫁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人祈噪。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓泽铛,卻偏偏與公主長得像,于是被迫代替她去往敵國和親钳降。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5腌巾? 答:HTML5是最新的HTML標準遂填。 注意:講述HT...
    kismetajun閱讀 27,486評論 1 45
  • 前言 終于在周末抽出時間來整理了一下有關文字邊框/背景效果的代碼铲觉,之前在寫這個效果的時候也是經歷了很多坎坷。在前期...
    沙琪瑪dd閱讀 6,448評論 7 24
  • 用兩張圖告訴你吓坚,為什么你的 App 會卡頓? - Android - 掘金 Cover 有什么料撵幽? 從這篇文章中你...
    hw1212閱讀 12,724評論 2 59
  • [TOC] 1 JAVA: String為什么這么設計 在源碼中string是用final 進行修飾,它是不可更改...
    寄浮生閱讀 814評論 0 0
  • OC語言基礎 1.類與對象 類方法 OC的類方法只有2種:靜態(tài)方法和實例方法兩種 在OC中礁击,只要方法聲明在@int...
    奇異果好補閱讀 4,273評論 0 11