如圖這樣的效果,我們平時直接可以在 xml 寫死。
寫法很簡單。
<?xml version="1.0" encoding="utf-8"?><!--白色圓角線條背景圖-->
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<corners android:radius="15dp" />
<stroke
android:width="1dp"
android:color="@color/white" />
</shape>
但是如果它的樣式會動态變化。
一種還好,我們可以再寫一個 xml 檔案。
但是如果有好幾種,再一一寫一個對應的 xml 檔案就有點被動了。
這個時候,我們可以在 java 或 kotlin 代碼中去設定,這裡我用 kotlin 寫一下。
//dp1 是 1dp 對應的像素值,機關為 float
var tvBg = GradientDrawable().apply {
shape = GradientDrawable.RECTANGLE//樣式,矩形
cornerRadius = dp1 * 16f//圓角
setStroke(dp1, ContextCompat.getColor(act, R.color.white)//邊框的大小和顔色
}
tv_btn_reserve.background = tvBg
是不是很簡單呀。