Android shape與selector標簽使用

来源:https://www.cnblogs.com/stars-one/archive/2022/05/23/16301244.html
-Advertisement-
Play Games

原文地址:Android shape與selector標簽使用 Android中提供一種xml的方式,讓我們可以自由地定義背景,比較常用的就是shape標簽和selector標簽 shape shape的翻譯為形狀的意思,一般用來定義背景的形狀,如長方形,線條,圓形 rectangle 矩形 預設 ...


原文地址:Android shape與selector標簽使用

Android中提供一種xml的方式,讓我們可以自由地定義背景,比較常用的就是shape標簽和selector標簽

shape

shape的翻譯為形狀的意思,一般用來定義背景的形狀,如長方形,線條,圓形

  • rectangle 矩形 預設
  • oval 橢圓
  • line 線條
  • ring 環形

簡單使用:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:tint="@color/white" android:shape="rectangle">
</shape>

tint是用來設置背景顏色

上述代碼即為白色的矩形,效果如下圖:

一般我們將shape當做根標簽來使用

corners 圓角

corners標簽,即為圓角的意思,可定義的屬性如下

屬性 說明
radius 定義4個方向圓角寬度
topRightRadius 右上角圓角寬度
bottomLeftRadius 左下角圓角寬度
bottomRightRadius 右下角圓角寬度
topLeftRadius 左上角圓角寬度
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:tint="@color/white" android:shape="rectangle">
    <corners android:radius="12dp"/>
</shape>

上述代碼即為圓角矩形的效果:

stroke 邊框

屬性 說明
color 邊框顏色
width 邊框寬度
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <corners android:radius="12dp"/>
    <stroke android:color="@color/read_dot_bg" android:width="1dp"/>
</shape>

註意: 這裡代碼中刪除了shape中的tint屬性,因為tint屬性會優先順序較高,導致邊框無法顯示出來!

solid 填充背景色

color 背景顏色

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
     android:shape="rectangle">
    <corners android:radius="12dp"/>
    <stroke android:color="@color/read_dot_bg" android:width="1dp"/>
    <solid android:color="@color/white"/>
</shape>

上述代碼,將背景設置了白色,且邊框也能正常顯示

gradient 漸變

屬性 說明
startColor 開始顏色
endColor 結束顏色
angle 角度 0 90 180 270 可以設置漸變的方向
type 漸變類型,linear:線性 radial:輻射狀 sweep:掃射

angle屬性記憶的方法是:先記住預設的方向,startColor到endColor,方向是從上到下,然後以逆時針為方向轉動,如果為0,則是逆時針轉動90°,以此類推

測試的方向,如果是45°的倍數,也是稍微有所區別

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
     android:shape="rectangle">
    <corners android:radius="12dp"/>
    <stroke android:color="@color/read_dot_bg" android:width="1dp"/>
    <solid android:color="@color/white"/>
    <gradient android:gradientRadius="5dp" android:startColor="@color/white" android:endColor="@color/font_blue"/>
</shape>

PS: 註意solid和gradient兩個標簽的順序,兩者聯用,位於xml下麵的會覆蓋上面的

圓形背景

圓形背景,即設置了shape屬性為oval

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <size
        android:width="5dp"
        android:height="5dp" />
    <solid android:color="#80011627" />
</shape>

同時,加上了個size標簽,用來定義寬高,這樣才會顯示出圓形,不然就是橢圓

這裡size標簽寬高似乎可以是任意值,因為是矢量,應用到View中會自動伸縮

PS:同理,如果想要正方形,設置shape屬性了rectangle,同時加上size標簽即可,如下圖

ripple 水波紋

水波紋,需要用ripple標簽,不過只支持Android5.0以上的版本,寫法如下

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:color="@color/colorPrimary"
        tools:targetApi="lollipop">
    <!--上面的是漣漪(水波紋)的顏色-->
    <!--下麵的則是背景色-->
    <item>
        <shape android:shape="rectangle">
            <solid android:color="@color/colorAccent" />
            <corners android:radius="4dp" />
        </shape>
    </item>
</ripple>

使用的話,View中background屬性引用上面的xml文件即可

在自定義 <ripple/> 時,我們一般把它放到 drawable-v21 文件夾下, 在drawable文件夾下放置相容低版本的普通 Drawable 文件,如 <shape/> 或者 <selector/>

selector 標簽

有時候需要自定義下按鈕的點擊變化背景等樣式,就可以用到此標簽來定義相關的點擊變化效果

常用屬性如下表所示:

屬性 說明
state_pressed 設置是否按壓狀態,一般在true時設置該屬性,表示已按壓狀態,預設為false
state_selected 設置是否選中狀態,true表示已選中,false表示未選中
state_checkable 設置是否勾選狀態,主要用於CheckBox和RadioButton,true表示已被勾選,false表示未被勾選
state_checked 設置勾選是否可用狀態,類似state_enabled,只是state_enabled會影響觸摸或點擊事件,state_checkable影響勾選事件
state_focused 設置是否獲得焦點狀態,true表示獲得焦點,預設為false,表示未獲得焦點
state_enabled 設置觸摸或點擊事件是否可用狀態,一般只在false時設置該屬性,表示不可用狀態

文本選中變色示例

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!--選中的顏色-->
    <item android:color="@color/read_dot_bg" android:state_checked="true" />
    <!--未選中的顏色 -->
    <item android:color="@color/black" android:state_checked="false" />
    <!--預設的顏色-->
    <item android:color="@color/black" />
</selector>

checkbox選中效果變化示例

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!--選中的背景-->
    <item android:drawable="@drawable/radio_background_checked" android:state_checked="true" />
    <!--未選中背景 -->
    <item android:drawable="@drawable/radio_background_uncheck" android:state_checked="false" />
    <!--預設的背景-->
    <item android:drawable="@drawable/radio_background_normal" />
</selector>

補充

關於透明色效果

透明色是定義在#後面前面的兩個數值,是十六進位

PS:註意,似乎也有規則是在後面加上兩位數值代表透明度

如:#011627 -> #80011627透明色

其中80即為透明度的十六進位,表示透明度為50%,可以參考下麵透明度大全表格

<solid
    android:color="#4DFFFFF2">
</solid>

透明度大全

不透度對應16進位大全(0-100)
不透明度 16進位
0% 00
1% 03
2% 05
3% 08
4% 0A
5% 0D
6% 0F
7% 12
8% 14
9% 17
10% 1A
11% 1C
12% 1F
13% 21
14% 24
15% 26
16% 29
17% 2B
18% 2E
19% 30
20% 33
21% 36
22% 38
23% 3B
24% 3D
25% 40
26% 42
27% 45
28% 47
29% 4A
30% 4D
31% 4F
32% 52
33% 54
34% 57
35% 59
36% 5C
37% 5E
38% 61
39% 63
40% 66
41% 69
42% 6B
43% 6E
44% 70
45% 73
46% 75
47% 78
48% 7A
49% 7D
50% 80
51% 82
52% 85
53% 87
54% 8A
55% 8C
56% 8F
57% 91
58% 94
59% 96
60% 99
61% 9C
62% 9E
63% A1
64% A3
65% A6
66% A8
67% AB
68% AD
69% B0
70% B3
71% B5
72% B8
73% BA
74% BD
75% BF
76% C2
77% C4
78% C7
79% C9
80% CC
81% CF
82% D1
83% D4
84% D6
85% D9
86% DB
87% DE
88% E0
89% E3
90% E6
91% E8
92% EB
93% ED
94% F0
95% F2
96% F5
97% F7
98% FA
99% FC
100% FF

提問之前,請先看提問須知 點擊右側圖標發起提問 聯繫我 或者加入QQ群一起學習 Stars-One安卓學習交流群 TornadoFx學習交流群:1071184701
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 已有的docker容器增加新的埠映射 在運行容器時指定映射埠運行後,如果想要添加新的埠映射,使用兩種方式都可以,需要的朋友可以參考下 背景 一般在運行容器時,我們都會通過參數 -p(使用大寫的-P參數則會隨機選擇宿主機的一個埠進行映射)來指定宿主機和容器埠的映射,例如 docker run ...
  • 本文例子參考《STM32單片機開發實例——基於Proteus虛擬模擬與HAL/LL庫》 源代碼:https://github.com/LanLinnet/STM33F103R6 寫在前面 在前面幾節的基礎上,我們已經基本瞭解了STM32F103的GPIO、外部中斷、定時器、串口通信和一些片內外設,接 ...
  • ethtool ethtool的使用 不帶選項,預設輸出協商速率、最大速率、連接狀態等信息 -i | --driver 列印驅動信息 --set-priv-flags 設置網卡的私有屬性,比如將link-down-on-close置為true後可以使用ifconfig down去關閉網卡連接 -a ...
  • 一、概述 DataX 是阿裡雲 DataWorks數據集成 的開源版本,在阿裡巴巴集團內被廣泛使用的離線數據同步工具/平臺。DataX 實現了包括 MySQL、Oracle、OceanBase、SqlServer、Postgre、HDFS、Hive、ADS、HBase、TableStore(OTS) ...
  • 1、查詢用戶所擁有的安全形色: select su.FullName,r.Name,bu.name bussinessname from SystemUserRoles sur left join SystemUserBase su on su.SystemUserId = sur.SystemUs ...
  • **導讀:**數據安全立法2018年9月於十三屆全國人大常委會列入立法規劃。經過三次審議,在2021年6月10日,十三屆全國人大常委會第二十九次會議正式表決通過,並於2021年9月1日起施行。從法律角度來說,國家對於數據安全越來越重視,作為企業該如何針對數據安全法進行數據安全治理的規劃,最終進行對應 ...
  • 本期我們將帶來“分散式計算器”的開發,幫助大家瞭解聲明式開發範式的UI描述、組件化機制、UI狀態管理、渲染控制語法等核心機制和功能。 ...
  • 本期,我們通過介紹 OpenHarmony 的硬體資源池化框架,為大家揭曉 OpenHarmony 是如何實現多設備協同的。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...