亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

android UI繪制加減號按鈕

瀏覽:3日期:2022-09-17 16:27:26

本文實例為大家分享了android UI繪制加減號按鈕的具體代碼,供大家參考,具體內容如下

在項目中我們常常會用到這么一個view。

android UI繪制加減號按鈕

這時候我們會選擇使用兩個圖片來相互切換。其實,只要會基本的2D繪圖這樣簡單的圖片自己繪制出來不在話下。

先給出我做出來的效果圖:

android UI繪制加減號按鈕

接下來,我將給出加號減號繪制的代碼以供大家參考:

以下是關鍵代碼

/** * +號 */public class AddView extends View { protected Paint paint; protected int HstartX, HstartY, HendX, HendY;//水平的線 protected int SstartX, SstartY, SsendX, SsendY;//垂直的線 protected int paintWidth = 2;//初始化加號的粗細為10 protected int paintColor = Color.BLACK;//畫筆顏色黑色 protected int padding = 3;//默認3的padding public int getPadding() {return padding; } //讓外界調用,修改padding的大小 public void setPadding(int padding) {SsendY = HendX = width - padding;SstartY = HstartX = padding; } //讓外界調用,修改加號顏色 public void setPaintColor(int paintColor) {paint.setColor(paintColor); } //讓外界調用,修改加號粗細 public void setPaintWidth(int paintWidth) {paint.setStrokeWidth(paintWidth); } public AddView(Context context, AttributeSet attrs) {super(context, attrs);initView(); } private void initView() {paint = new Paint();paint.setColor(paintColor);paint.setStrokeWidth(paintWidth); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {int widthSize = MeasureSpec.getSize(widthMeasureSpec);int widthMode = MeasureSpec.getMode(widthMeasureSpec);int width;if (widthMode == MeasureSpec.EXACTLY) { // MeasureSpec.EXACTLY表示該view設置的確切的數值 width = widthSize;} else { width = 60;//默認值}SstartX = SsendX = HstartY = HendY = width / 2;SsendY = HendX = width - getPadding();SstartY = HstartX = getPadding();//這樣做是因為加號寬高是相等的,手動設置寬高setMeasuredDimension(width, width); } @Override protected void onDraw(Canvas canvas) {super.onDraw(canvas);//水平的橫線canvas.drawLine(HstartX, HstartY, HendX, HendY, paint);//垂直的橫線canvas.drawLine(SstartX, SstartY, SsendX, SsendY, paint); }}

/** * -號 */public class RemoveView extends AddView { public RemoveView(Context context, AttributeSet attrs) {super(context, attrs); } @Override protected void onDraw(Canvas canvas) {//水平的橫線,減號不需要垂直的橫線了canvas.drawLine(HstartX, HstartY, HendX, HendY, paint); }}

其中主要的是計算橫線和豎線的位置。獲得view的寬度后,將view設置成正方形,然后就如如所示:

android UI繪制加減號按鈕

這樣,最主要的加減號做完了,其他的都是小意思了。

我把主要的xml文件貼出來:

主視圖:layout_add_remove.xml

<?xml version='1.0' encoding='utf-8'?><LinearLayout xmlns:android='http://schemas.android.com/apk/res/android' android:layout_width='wrap_content' android:layout_height='wrap_content' android:layout_margin='3dp' android:padding='2dp' android:background='@drawable/bg_add_remove_view' android:orientation='horizontal'> <com.android.ui.TextView.AddViewandroid: android:layout_width='50dp'android:layout_height='50dp'android:layout_gravity='center_vertical'android:background='@drawable/bg_add_view' /> <EditTextandroid:layout_width='wrap_content'android:layout_height='wrap_content'android:layout_gravity='center_vertical'android:layout_margin='3dp'android:background='@null'android:inputType='number'android:text='0' /> <com.android.ui.TextView.RemoveViewandroid: android:layout_width='50dp'android:layout_height='50dp'android:layout_gravity='center_vertical'android:background='@drawable/bg_remove_view' /></LinearLayout>

主視圖背景:bg_add_remove_view.xml

<?xml version='1.0' encoding='utf-8'?><shape xmlns:android='http://schemas.android.com/apk/res/android' android:shape='rectangle'> <!-- 設置圓角矩形 --> <corners android:radius='5dp' /> <!-- 文本框里面的顏色 --> <solid android:color='@android:color/white' /> <!-- 邊框的顏色 --> <strokeandroid: android:color='@android:color/darker_gray' /></shape>

加號背景:bg_add_view.xml

<?xml version='1.0' encoding='utf-8'?><selector xmlns:android='http://schemas.android.com/apk/res/android'><item android:drawable='@drawable/bg_add_true' android:state_pressed='true' /><item android:drawable='@drawable/bg_add_false' android:state_pressed='false' /></selector>

<?xml version='1.0' encoding='utf-8'?><layer-list xmlns:android='http://schemas.android.com/apk/res/android'> <!-- 邊框的顏色 --> <item><shape> <solid android:color='@android:color/darker_gray' /></shape> </item> <itemandroid:bottom='0dp'android:left='0dp'android:right='0.5dp'android:top='0dp'><!--設置只有底部有邊框--><shape> <!-- 主體背景顏色值 --> <solid android:color='@android:color/darker_gray' /></shape> </item></layer-list>

<?xml version='1.0' encoding='utf-8'?><layer-list xmlns:android='http://schemas.android.com/apk/res/android'> <!-- 邊框的顏色 --> <item><shape> <solid android:color='@android:color/darker_gray' /></shape> </item> <itemandroid:bottom='0dp'android:left='0dp'android:right='0.5dp'android:top='0dp'><!--設置只有底部有邊框--><shape> <!-- 主體背景顏色值 --> <solid android:color='@android:color/white' /></shape> </item></layer-list>

減號的背景色配置和加號一樣,只不過豎線的位置不同而已:

<itemandroid:bottom='0dp'android:left='0.5dp'android:right='0dp'android:top='0dp'>

我們可以在完全不用圖片的情況下完成這個ui。

當然,還有很多可以優化的地方。比如設置padding,修改加減號顏色,就該布局大小,這些都是可以通過代碼來實現的。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
主站蜘蛛池模板: 欧美黑人乱大交灬太大了视频 | 国产综合亚洲欧美日韩一区二区 | 国产狂喷白浆在线观看视频 | 国产在线a不卡免费视频 | 大人和孩做爰h视频在线观看 | 黄色三级一级片 | 国产一级又色又爽又黄大片 | 国产精品日韩欧美亚洲另类 | 六月丁香婷婷色狠狠久久 | 欧美一欧美一区二三区性 | 亚洲 欧美 自拍 另类 欧美 | 91香蕉视频苹果 | 色黄网站aaaaaa级毛片 | 免费在线观看一区二区 | 女18一级大黄毛片免费女人 | 成人亚洲视频 | 日韩a级毛片免费观看 | 女女女女dvd免费 | 欧美一级毛片欧美一级 | 亚洲视频欧洲视频 | 久久精品视香蕉蕉er大臿蕉 | 精品综合久久久久久97超人该 | 日本黄色片免费观看 | 久久亚洲人成网站 | 色天天影视 | 久久有这有精品在线观看 | 欧美一级特黄aa大片在线观看免费 | 久久久久在线观看 | 亚洲一区二区三区久久精品 | 国产尤物在线观看 | 亚洲成年网站在线观看 | 亚洲欧美在线视频 | 免费一级a毛片在线播放视 免费一级a毛片免费观看欧美大片 | 久久精品国产精品亚洲红杏 | 国产福利午夜自产拍视频在线 | 久久精品女人毛片国产 | 免费观看黄色在线视频 | 日本xxxwww免费视频软件 | 久久777 | 亚洲第一免费网站 | 亚洲综合99 |