Android怎么自定义开源库EasyView

其他教程   发布日期:2025年04月19日   浏览次数:242

这篇文章主要介绍“Android怎么自定义开源库EasyView”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android怎么自定义开源库EasyView”文章能帮助大家解决问题。

配置EasyView

这是一个简单方便的Android自定义View库,我一直有一个想法弄一个开源库,现在这个想法付诸实现了,如果有什么需要自定义的View可以提出来,不一定都会采纳,合理的会采纳,时间周期不保证,咱要量力而行呀,踏实一点。

1. 工程build.gradle 或 settings.gradle配置

代码已经推送到

  1. MavenCentral()
,在
  1. Android Studio 4.2
以后的版本中默认在创建工程的时候使用
  1. MavenCentral()
,而不是
  1. jcenter()

如果是之前的版本则需要在

  1. repositories{}
闭包中添加
  1. mavenCentral()
,不同的是,老版本的Android Studio是在工程的
  1. build.gradle
中添加,而新版本是工程的
  1. settings.gradle
中添加,如果已经添加,则不要重复添加。
  1. repositories {
  2. ...
  3. mavenCentral()
  4. }

2. 使用模块的build.gradle配置

例如在

  1. app
模块中使用,则打开app模块下的
  1. build.gradle
,在
  1. dependencies{}
闭包下添加即可,之后记得要
  1. Sync Now
  1. dependencies {
  2. implementation 'io.github.lilongweidev:easyview:1.0.2'
  3. }

使用EasyView

这是一个自定义View的库,会慢慢丰富里面的自定义View,我先画个饼再说。

一、MacAddressEditText

MacAddressEditText是一个蓝牙Mac地址输入控件,点击之后出现一个定制的Hex键盘,用于输入值。

1. xml中使用

首先是在xml中添加如下代码,具体参考app模块中的activity_main.xml。

  1. <com.easy.view.MacAddressEditText
  2. android:id="@+id/mac_et"
  3. android:layout_width="wrap_content"
  4. android:layout_height="wrap_content"
  5. app:boxBackgroundColor="@color/white"
  6. app:boxStrokeColor="@color/black"
  7. app:boxStrokeWidth="2dp"
  8. app:boxWidth="48dp"
  9. app:separator=":"
  10. app:textColor="@color/black"
  11. app:textSize="14sp" />

2. 属性介绍

这里使用了MacAddressEditText的所有属性,可以自行进行设置,使用说明参考下表。

属性 说明
app:boxBackgroundColor 设置输入框的背景颜色
app:boxStrokeColor 设置输入框的边框颜色
app:boxStrokeWidth 设置输入框的边框大小
app:boxWidth 设置输入框大小
app:separator Mac地址的分隔符,例如分号:
app:textColor 设置输入框文字颜色
app:textSize 设置输入框文字大小

3. 代码中使用

  1. MacAddressEditText macEt = findViewById(R.id.mac_et);
  2. String macAddress = macEt.getMacAddress();

&emsp; &emsp;macAddress可能会是空字符串,使用之前请判断一下,参考app模块中的MainActivity中的使用方式。

二、CircularProgressBar

CircularProgressBar是圆环进度条控件。

1. xml中使用

&emsp; &emsp;首先是在xml中添加如下代码,具体参考app模块中的activity_main.xml。

  1. <com.easy.view.CircularProgressBar
  2. android:id="@+id/cpb_test"
  3. android:layout_width="wrap_content"
  4. android:layout_height="wrap_content"
  5. android:layout_marginTop="30dp"
  6. app:maxProgress="100"
  7. app:progress="10"
  8. app:progressbarBackgroundColor="@color/purple_500"
  9. app:progressbarColor="@color/purple_200"
  10. app:radius="80dp"
  11. app:strokeWidth="16dp"
  12. app:text="10%"
  13. app:textColor="@color/teal_200"
  14. app:textSize="28sp" />

2. 属性介绍

这里使用了MacAddressEditText的所有属性,可以自行进行设置,使用说明参考下表。

属性 说明
app:maxProgress 最大进度
app:progress 当前进度
app:progressbarBackgroundColor 进度条背景颜色
app:progressbarColor 进度颜色
app:radius 半径,用于设置圆环的大小
app:strokeWidth 进度条大小
app:text 进度条中心文字
app:textColor 进度条中心文字颜色
app:textSize 进度条中心文字大小

3. 代码中使用

  1. CircularProgressBar cpbTest = findViewById(R.id.cpb_test);
  2. int progress = 10;
  3. cpbTest.setText(progress + "%");
  4. cpbTest.setProgress(progress);

参考app模块中的MainActivity中的使用方式。

三、TimingTextView

TimingTextView是计时文字控件

1. xml中使用

首先是在xml中添加如下代码,具体参考app模块中的activity_main.xml。

  1. <com.easy.view.TimingTextView
  2. android:id="@+id/tv_timing"
  3. android:layout_width="wrap_content"
  4. android:layout_height="wrap_content"
  5. android:layout_marginTop="30dp"
  6. android:text="计时文字"
  7. android:textColor="@color/black"
  8. android:textSize="32sp"
  9. app:countdown="false"
  10. app:max="60"
  11. app:unit="s" />

2. 属性介绍

这里使用了TimingTextView的自定义属性不多,只有3个,TextView的属性就不列举说明,使用说明参考下表。

属性 说明
app:countdown 是否倒计时
app:max 最大时间长度
app:unit 时间单位:s(秒)、m(分)、h(时)

3. 代码中使用

  1. TimingTextView tvTiming = findViewById(R.id.tv_timing);
  2. tvTiming.setMax(6);//最大时间
  3. tvTiming.setCountDown(false);//是否倒计时
  4. tvTiming.setUnit(3);//单位 秒
  5. tvTiming.setListener(new TimingListener() {
  6. @Override
  7. public void onEnd() {
  8. //定时结束
  9. }
  10. });
  11. //开始计时
  12. tvTiming.start();
  13. //停止计时
  14. //tvTiming.end();

以上就是Android怎么自定义开源库EasyView的详细内容,更多关于Android怎么自定义开源库EasyView的资料请关注九品源码其它相关文章!