色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

android UI繪制加減號(hào)按鈕

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

本文實(shí)例為大家分享了android UI繪制加減號(hào)按鈕的具體代碼,供大家參考,具體內(nèi)容如下

在項(xiàng)目中我們常常會(huì)用到這么一個(gè)view。

android UI繪制加減號(hào)按鈕

這時(shí)候我們會(huì)選擇使用兩個(gè)圖片來(lái)相互切換。其實(shí),只要會(huì)基本的2D繪圖這樣簡(jiǎn)單的圖片自己繪制出來(lái)不在話(huà)下。

先給出我做出來(lái)的效果圖:

android UI繪制加減號(hào)按鈕

接下來(lái),我將給出加號(hào)減號(hào)繪制的代碼以供大家參考:

以下是關(guān)鍵代碼

/** * +號(hào) */public class AddView extends View { protected Paint paint; protected int HstartX, HstartY, HendX, HendY;//水平的線(xiàn) protected int SstartX, SstartY, SsendX, SsendY;//垂直的線(xiàn) protected int paintWidth = 2;//初始化加號(hào)的粗細(xì)為10 protected int paintColor = Color.BLACK;//畫(huà)筆顏色黑色 protected int padding = 3;//默認(rèn)3的padding public int getPadding() {return padding; } //讓外界調(diào)用,修改padding的大小 public void setPadding(int padding) {SsendY = HendX = width - padding;SstartY = HstartX = padding; } //讓外界調(diào)用,修改加號(hào)顏色 public void setPaintColor(int paintColor) {paint.setColor(paintColor); } //讓外界調(diào)用,修改加號(hào)粗細(xì) 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設(shè)置的確切的數(shù)值 width = widthSize;} else { width = 60;//默認(rèn)值}SstartX = SsendX = HstartY = HendY = width / 2;SsendY = HendX = width - getPadding();SstartY = HstartX = getPadding();//這樣做是因?yàn)榧犹?hào)寬高是相等的,手動(dòng)設(shè)置寬高setMeasuredDimension(width, width); } @Override protected void onDraw(Canvas canvas) {super.onDraw(canvas);//水平的橫線(xiàn)canvas.drawLine(HstartX, HstartY, HendX, HendY, paint);//垂直的橫線(xiàn)canvas.drawLine(SstartX, SstartY, SsendX, SsendY, paint); }}

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

其中主要的是計(jì)算橫線(xiàn)和豎線(xiàn)的位置。獲得view的寬度后,將view設(shè)置成正方形,然后就如如所示:

android UI繪制加減號(hào)按鈕

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

我把主要的xml文件貼出來(lái):

主視圖: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'> <!-- 設(shè)置圓角矩形 --> <corners android:radius='5dp' /> <!-- 文本框里面的顏色 --> <solid android:color='@android:color/white' /> <!-- 邊框的顏色 --> <strokeandroid: android:color='@android:color/darker_gray' /></shape>

加號(hào)背景: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'><!--設(shè)置只有底部有邊框--><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'><!--設(shè)置只有底部有邊框--><shape> <!-- 主體背景顏色值 --> <solid android:color='@android:color/white' /></shape> </item></layer-list>

減號(hào)的背景色配置和加號(hào)一樣,只不過(guò)豎線(xiàn)的位置不同而已:

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

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

當(dāng)然,還有很多可以?xún)?yōu)化的地方。比如設(shè)置padding,修改加減號(hào)顏色,就該布局大小,這些都是可以通過(guò)代碼來(lái)實(shí)現(xiàn)的。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Android
相關(guān)文章:
主站蜘蛛池模板: 黄色三级免费网站 | 99爱免费观看视频在线 | 日韩一级一欧美一级国产 | 999久久久 | 欧美日韩国产亚洲一区二区三区 | 国产精品久久久久久久久免费观看 | 男女一级爽爽快视频 | 亚洲成人精品 | 男女视频在线观看免费高清观看 | 色九九| 久久夜色精品国产噜噜亚洲a | 性a视频 | 欧美一级毛片无遮挡 | 亚洲一区二区影视 | 欧美日韩一区二区中文字幕视频 | 久久欧美成人精品丝袜 | 一区二区三区不卡在线 | 久久亚洲综合中文字幕 | 日韩精品一区二区三区毛片 | 91精品国产一区二区三区四区 | 国产成人午夜片在线观看 | 欧美三级超在线视频 | 99视频精品全部在线播放 | 国产精品极品美女自在线看免费一区二区 | 日本高清色视频www 日本高清在线精品一区二区三区 | 精品欧美成人高清视频在线观看 | 特黄特色一级特色大片中文 | 手机看a | 九九九九精品视频在线播放 | 国产一区二区在线看 | 美女被免费网站在线软件 | 亚洲欧美一区二区三区在线观看 | 天天舔夜夜操 | 日本综合欧美一区二区三区 | 国产免费人成在线看视频 | 欧美三级一级 | 白嫩美女一级毛片免费看 | 国产精品资源手机在线播放 | 免费看三级毛片 | 国产成人亚洲综合欧美一部 | 欧美一级鲁丝片 |