android UI绘制加减号按钮

作者:夜辉疾风 时间:2023-09-11 02:55:28 

本文实例为大家分享了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.AddView
       android:id="@+id/add_view"
       android:layout_width="50dp"
       android:layout_height="50dp"
       android:layout_gravity="center_vertical"
       android:background="@drawable/bg_add_view" />

<EditText
       android: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.RemoveView
       android:id="@+id/remove_view"
       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" />
   <!-- 边框的颜色 -->
   <stroke
       android:width="0.5dp"
       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>
   <item
       android: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>
   <item
       android:bottom="0dp"
       android:left="0dp"
       android:right="0.5dp"
       android:top="0dp">
       <!--设置只有底部有边框-->
       <shape>
           <!-- 主体背景颜色值 -->
           <solid android:color="@android:color/white" />
       </shape>
   </item>
</layer-list>

减号的背景色配置和加号一样,只不过竖线的位置不同而已:


<item
       android:bottom="0dp"
       android:left="0.5dp"
       android:right="0dp"
       android:top="0dp">

我们可以在完全不用图片的情况下完成这个ui。

当然,还有很多可以优化的地方。比如设置padding,修改加减号颜色,就该布局大小,这些都是可以通过代码来实现的。

来源:https://blog.csdn.net/yehui928186846/article/details/51418791

标签:android,UI,按钮
0
投稿

猜你喜欢

  • java后台利用Apache poi 生成excel文档提供前台下载示例

    2023-05-15 08:51:45
  • Android学习之Broadcast的简单使用

    2023-11-19 15:18:02
  • SpringCloud超详细讲解负载均衡组件Ribbon源码

    2021-06-17 18:39:47
  • C#截图程序类似腾讯QQ截图实现代码

    2023-05-07 04:01:01
  • 使用maven开发springboot项目时pom.xml常用配置(推荐)

    2022-09-19 23:33:48
  • 关于@Autowired注入依赖失败的问题及解决

    2023-11-29 00:50:42
  • App内切换语言详解

    2023-04-12 11:21:44
  • 解决 INSTALL FAILED CONFLICTING PROVIDER的问题方法

    2023-01-31 11:42:49
  • 浅谈java中守护线程与用户线程

    2023-11-26 20:46:41
  • Android编程基于重力传感器实现横竖屏放向切换功能

    2022-11-30 00:38:54
  • Android 控件GridView使用案例讲解

    2023-07-14 17:33:28
  • Android 8.0升级不跳转应用安装页面的解决方法

    2022-03-20 03:30:13
  • 深入分析C# Task

    2022-10-24 12:39:00
  • 浅谈Visual C#进行图像处理(读取、保存以及对像素的访问)

    2023-04-04 20:25:00
  • java8 统计字符串字母个数的几种方法总结(推荐)

    2023-09-25 17:37:48
  • Android系统工具类详解

    2023-07-12 22:11:57
  • Android仿微信朋友圈图片查看器

    2023-01-27 18:07:20
  • 不安装excel使用c#创建excel文件

    2023-02-20 07:03:25
  • C# httpwebrequest访问HTTPS错误处理方法

    2021-10-31 02:40:49
  • SpringBoot中@ConditionalOnBean实现原理解读

    2023-04-25 14:24:54
  • asp之家 软件编程 m.aspxhome.com