文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

android UI如何绘制加减号按钮

2023-06-20 12:45

关注

小编给大家分享一下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,修改加减号颜色,就该布局大小,这些都是可以通过代码来实现的。

以上是“android UI如何绘制加减号按钮”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯