これはシンプルで便利な Android カスタム View ライブラリです.以前からオープン ソースのライブラリを作成したいと考えていました.このアイデアは実行に移されました.提案する必要があるカスタム View がある場合、それは採用されない可能性があります. , そしてそれは合理的です. 採用, 期間は保証されていません, 私たちはできることをしなければなりません.
EasyView を構成する
1. プロジェクト build.gradle または settings.gradle 構成
コードは にプッシュされておりMavenCentral()
、今後のバージョンでプロジェクトを作成する際に、 ではなくAndroid Studio 4.2
デフォルトで使用されます。MavenCentral()
jcenter()
If it is the previous version, it needs to be repositories{}
added in theclosure mavenCentral()
. 違いは、古いバージョンの Android Studio がbuild.gradle
プロジェクトに追加され、新しいバージョンがsettings.gradle
プロジェクトに追加されることです.既に追加されている場合は、繰り返し追加しないでください。
repositories {
...
mavenCentral()
}
复制代码
2. モジュールの build.gradle 構成を使用する
たとえば、app
モジュールで使用されている場合は、アプリ モジュールの下で開きbuild.gradle
、dependencies{}
クロージャの下に追加してくださいSync Now
。
dependencies {
implementation 'io.github.lilongweidev:easyview:1.0.2'
}
复制代码
EasyView を使用する
これはカスタム ビュー ライブラリで、内部のカスタム ビューを徐々に充実させていきます。
一、MacAddressEditText
MacAddressEditText
これは Bluetooth Mac アドレス入力コントロールで、クリックすると、値を入力するためのカスタマイズされた 16 進キーボードが表示されます。
1.xmlで使用
まず、次のコードを xml に追加します。詳しくは app モジュールを参照してくださいactivity_mac_address.xml
。
<com.easy.view.MacAddressEditText
android:id="@+id/mac_et"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:boxBackgroundColor="@color/white"
app:boxStrokeColor="@color/black"
app:boxStrokeWidth="2dp"
app:boxWidth="48dp"
app:separator=":"
app:textColor="@color/black"
app:textSize="14sp" />
复制代码
2.属性紹介
ここで使用されるすべてのプロパティはMacAddressEditText
、自分で設定できます。使用方法については、以下の表を参照してください。
属性 | 例証する |
---|---|
app:boxBackgroundColor | 入力ボックスの背景色を設定する |
app:boxStrokeColor | 入力ボックスの枠の色を設定する |
app:boxStrokeWidth | 入力ボックスの枠のサイズを設定する |
app:boxWidth | 设置输入框大小 |
app:separator | Mac地址的分隔符,例如分号: |
app:textColor | 设置输入框文字颜色 |
app:textSize | 设置输入框文字大小 |
3. 代码中使用
MacAddressEditText macEt = findViewById(R.id.mac_et);
String macAddress = macEt.getMacAddress();
复制代码
macAddress可能会是空字符串,使用之前请判断一下,参考app模块中的MacAddressActivity
中的使用方式。
二、CircularProgressBar
CircularProgressBar
是圆环进度条控件。
1. xml中使用
首先是在xml中添加如下代码,具体参考app模块中的activity_progress_bar.xml
。
<com.easy.view.CircularProgressBar
android:id="@+id/cpb_test"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
app:maxProgress="100"
app:progress="10"
app:progressbarBackgroundColor="@color/purple_500"
app:progressbarColor="@color/purple_200"
app:radius="80dp"
app:strokeWidth="16dp"
app:text="10%"
app:textColor="@color/teal_200"
app:textSize="28sp" />
复制代码
2. 属性介绍
这里使用了MacAddressEditText
的所有属性,可以自行进行设置,使用说明参考下表。
属性 | 说明 |
---|---|
app:maxProgress | 最大进度 |
app:progress | 当前进度 |
app:progressbarBackgroundColor | 进度条背景颜色 |
app:progressbarColor | 进度颜色 |
app:radius | 半径,用于设置圆环的大小 |
app:strokeWidth | 进度条大小 |
app:text | 进度条中心文字 |
app:textColor | 进度条中心文字颜色 |
app:textSize | 进度条中心文字大小 |
3. 代码中使用
CircularProgressBar cpbTest = findViewById(R.id.cpb_test);
int progress = 10;
cpbTest.setText(progress + "%");
cpbTest.setProgress(progress);
复制代码
参考app模块中的ProgressBarActivity
中的使用方式。
三、TimingTextView
TimingTextView是计时文字控件。
1. xml中使用
首先是在xml中添加如下代码,具体参考app模块中的activity_timing_text.xml
。
<com.easy.view.TimingTextView
android:id="@+id/tv_timing"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
android:text="计时文字"
android:textColor="@color/black"
android:textSize="32sp"
app:countdown="false"
app:max="60"
app:unit="s" />
复制代码
2. 属性介绍
这里使用了TimingTextView
的自定义属性不多,只有3个,TextView的属性就不列举说明,使用说明参考下表。
属性 | 说明 |
---|---|
app:countdown | 是否倒计时 |
app:max | 最大时间长度 |
app:unit | 时间单位:s(秒)、m(分)、h(时) |
3. 代码中使用
TimingTextView tvTiming = findViewById(R.id.tv_timing);
tvTiming.setMax(6);//最大时间
tvTiming.setCountDown(false);//是否倒计时
tvTiming.setUnit(3);//单位 秒
tvTiming.setListener(new TimingListener() {
@Override
public void onEnd() {
//定时结束
}
});
//开始计时
tvTiming.start();
//停止计时
//tvTiming.end();
复制代码
参考app模块中的TimingActivity
中的使用方式。
四、EasyEditText
EasyEditText
是一个简易输入控件,可用于密码框、验证码输入框进行使用。
1. xml中使用
首先是在xml中添加如下代码,具体参考app模块中的activity_easy_edittext.xml
。
<com.easy.view.EasyEditText
android:id="@+id/et_content"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:boxBackgroundColor="@color/white"
app:boxFocusStrokeColor="@color/green"
app:boxNum="6"
app:boxStrokeColor="@color/black"
app:boxStrokeWidth="2dp"
app:boxWidth="48dp"
app:ciphertext="false"
app:textColor="@color/black"
app:textSize="16sp" />
复制代码
2. 属性介绍
这里使用了EasyEditText
的所有属性,可以自行进行设置,使用说明参考下表。
属性 | 说明 |
---|---|
app:boxBackgroundColor | 设置输入框的背景颜色 |
app:boxFocusStrokeColor | 设置输入框获取焦点时的颜色 |
app:boxNum | 设置输入框的个数,4~6个 |
app:boxStrokeColor | 设置输入框的边框颜色 |
app:boxStrokeWidth | 入力ボックスの枠のサイズを設定する |
app:boxWidth | 入力ボックスのサイズを設定する |
アプリ:暗号文 | パスワードボックスで使用される、暗号化するかどうか |
app:textColor | 入力ボックスの文字色を設定する |
アプリ:テキストサイズ | 入力ボックスの文字サイズを設定する |
3. コードでの使用
binding.cbFlag.setOnCheckedChangeListener((buttonView, isChecked) -> {
binding.etContent.setCiphertext(isChecked);
binding.cbFlag.setText(isChecked ? "密文" : "明文");
});
//输入框
binding.btnGetContent.setOnClickListener(v -> {
String content = binding.etContent.getText();
if (content.isEmpty()) {
showMsg("请输入内容");
return;
}
if (content.length() < binding.etContent.getBoxNum()) {
showMsg("请输入完整内容");
return;
}
showMsg("输入内容为:" + content);
});
复制代码
app モジュール内の使用方法を参照してくださいEasyEditTextActivity
。