Android カスタム オープン ソース ライブラリ EasyView

  これはシンプルで便利な Android カスタム View ライブラリです.以前からオープン ソースのライブラリを作成したいと考えていました.このアイデアは実行に移されました.提案する必要があるカスタム View がある場合、それは採用されない可能性があります. , そしてそれは合理的です. 採用, 期間は保証されていません, 私たちはできることをしなければなりません.

1682474222191_095705.gif.gif

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.gradledependencies{}クロージャの下に追加してください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

おすすめ

転載: juejin.im/post/7225407341633175613