Android 开发 - 一些画板第三方库(DrawBoard、FingerPaintView、PaletteLib)

一、DrawBoard

1、Dependencies
  • 模块级 build.gradle
groovy 复制代码
implementation 'com.github.jenly1314:drawboard:1.1.0'
2、Test
(1)Activity Layout
  • activity_draw_board.xml
xml 复制代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".DrawBoardActivity">

    <com.king.drawboard.view.DrawBoardView
        android:id="@+id/dbv_container"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <Button
            android:id="@+id/btn_undo"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="撤销" />

        <Button
            android:id="@+id/btn_redo"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginStart="5dp"
            android:layout_weight="1"
            android:text="恢复" />

        <Button
            android:id="@+id/btn_clear"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginStart="5dp"
            android:layout_weight="1"
            android:text="清空" />

        <Button
            android:id="@+id/btn_eraser"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginStart="5dp"
            android:layout_weight="1"
            android:text="橡皮擦" />
    </LinearLayout>
</LinearLayout>
(2)Activity Code
  • DrawBoardActivity.java
java 复制代码
public class DrawBoardActivity extends AppCompatActivity {

    private boolean eraserFlag = false;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        EdgeToEdge.enable(this);
        setContentView(R.layout.activity_draw_board);
        ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main), (v, insets) -> {
            Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars());
            v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom);
            return insets;
        });

        DrawBoardView dbvContainer = findViewById(R.id.dbv_container);
        Button btnUndo = findViewById(R.id.btn_undo);
        Button btnRedo = findViewById(R.id.btn_redo);
        Button btnClear = findViewById(R.id.btn_clear);
        Button btnEraser = findViewById(R.id.btn_eraser);

        // 设置画笔颜色和粗细
        dbvContainer.setPaintColor(Color.RED);
        dbvContainer.setLineStrokeWidth(5f);

        // 撤销
        btnUndo.setOnClickListener(v -> dbvContainer.undo());

        // 重做
        btnRedo.setOnClickListener(v -> dbvContainer.redo());

        // 清除
        btnClear.setOnClickListener(v -> dbvContainer.clear());

        // 橡皮擦 / 画笔
        btnEraser.setOnClickListener(v -> {
            eraserFlag = !eraserFlag;
            if (eraserFlag) {
                btnEraser.setText("画笔");
                dbvContainer.setDrawMode(DrawBoardView.DrawMode.ERASER);
            } else {
                btnEraser.setText("橡皮擦");
                dbvContainer.setDrawMode(DrawBoardView.DrawMode.DRAW_PATH);
            }
        });
    }
}

二、FingerPaintView

1、Dependencies
  • 模块级 build.gradle
groovy 复制代码
implementation 'com.github.PicnicSupermarket:FingerPaintView:1.2'
  • settings.gradle,添加 JitPack 仓库
groovy 复制代码
dependencyResolutionManagement {
    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
    repositories {
        ...

        maven { url 'https://jitpack.io' }
    }
}
2、Test
(1)Activity Layout
  • activity_finger_paint_view.xml
xml 复制代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".FingerPaintViewActivity">

    <tech.picnic.fingerpaintview.FingerPaintImageView
        android:id="@+id/fpiv_container"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:src="@drawable/ic_launcher_background"
        app:inEditMode="true" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <Button
            android:id="@+id/btn_undo"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="撤销" />

        <Button
            android:id="@+id/btn_clear"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginStart="5dp"
            android:layout_weight="1"
            android:text="清空" />
    </LinearLayout>
</LinearLayout>
(2)Activity Code
  • FingerPaintViewActivity.java
java 复制代码
public class FingerPaintViewActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        EdgeToEdge.enable(this);
        setContentView(R.layout.activity_finger_paint_view);
        ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main), (v, insets) -> {
            Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars());
            v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom);
            return insets;
        });

        FingerPaintImageView fpivContainer = findViewById(R.id.fpiv_container);
        Button btnUndo = findViewById(R.id.btn_undo);
        Button btnClear = findViewById(R.id.btn_clear);

        // 设置画笔颜色和粗细
        fpivContainer.setStrokeColor(Color.RED);
        fpivContainer.setStrokeWidth(10f);

        // 撤销
        btnUndo.setOnClickListener(v -> fpivContainer.undo());

        // 清除
        btnClear.setOnClickListener(v -> fpivContainer.clear());
    }
}

三、PaletteLib

1、Dependencies
  • 模块级 build.gradle
groovy 复制代码
implementation 'com.gitee.osard:palettelib:1.3.0'
  • settings.gradle,添加 JitPack 仓库
groovy 复制代码
dependencyResolutionManagement {
    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
    repositories {
        ...

        maven { url 'https://jitpack.io' }
    }
}
2、Test
(1)Activity Layout
  • activity_palette_lib.xml
xml 复制代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".PaletteLibActivity">

    <com.mjsoftking.palettelib.PaletteImageView
        android:id="@+id/piv_container"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <Button
            android:id="@+id/btn_undo"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="撤销" />

        <Button
            android:id="@+id/btn_clear"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginStart="5dp"
            android:layout_weight="1"
            android:text="清空" />
    </LinearLayout>
</LinearLayout>
(2)Activity Code
  • PaletteLibActivity.java
java 复制代码
public class PaletteLibActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        EdgeToEdge.enable(this);
        setContentView(R.layout.activity_palette_lib);
        ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main), (v, insets) -> {
            Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars());
            v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom);
            return insets;
        });

        PaletteImageView pivContainer = findViewById(R.id.piv_container);
        Button btnUndo = findViewById(R.id.btn_undo);
        Button btnClear = findViewById(R.id.btn_clear);

        // 设置画笔颜色和粗细
        pivContainer.palette.setPaintColor(R.color.black);
        pivContainer.palette.setStrokeWidth(10f);

        // 撤销
        btnUndo.setOnClickListener(v -> pivContainer.palette.revocation());

        // 清除
        btnClear.setOnClickListener(v -> pivContainer.palette.clear());
    }
}
相关推荐
兔子撩架构10 小时前
Dubbo 的同步服务调用
java·后端·spring cloud
O***P57110 小时前
【MySQL】MySQL内置函数--日期函数字符串函数数学函数其他相关函数
android·mysql·adb
z***438410 小时前
MySQL-mysql zip安装包配置教程
android·mysql·adb
x***133910 小时前
MySQL 篇 - Java 连接 MySQL 数据库并实现数据交互
java·数据库·mysql
xuanzdhc10 小时前
Gitgit
java·linux·运维·服务器·c++·git
无心水11 小时前
【Python实战进阶】7、Python条件与循环实战详解:从基础语法到高级技巧
android·java·python·python列表推导式·python条件语句·python循环语句·python实战案例
一点★11 小时前
“equals”与“==”、“hashCode”的区别和使用场景
java·开发语言
N***H48611 小时前
SpringCloud实战十三:Gateway之 Spring Cloud Gateway 动态路由
java·spring cloud·gateway
s***w11211 小时前
SpringMVC新版本踩坑[已解决]
java
老李头喽11 小时前
走进单元测试
java·单元测试