画板

本文介绍了一个自定义绘图控件的实现过程,包括如何响应触摸事件进行绘图,改变画笔颜色和宽度,以及如何保存绘制的图片到本地。通过分析源代码,读者可以了解Android中自定义View的基本原理和技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

action_main

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <ImageView
        android:id="@+id/image"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/bg"
        android:layout_alignParentTop="true"/>

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

        <Button
            android:id="@+id/red"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="红色"
            android:onClick="onClick"/>

        <Button
            android:id="@+id/green"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="绿色"
            android:onClick="onClick"/>

        <Button
            android:id="@+id/brush"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="刷子"
            android:onClick="onClick"/>

        <Button
            android:id="@+id/save"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="保存"
            android:onClick="onClick"/>
    </LinearLayout>
</RelativeLayout>

MainActivity

package wanghuiqi.bawie.com.whq_customcontrol;

import android.annotation.SuppressLint;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.widget.ImageView;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    private Canvas mCanvas;
    private Paint mPaint;
    private ImageView mImage;
    //按下
    private int mStartY;
    private int mStartX;
    //移动
    private int mMoveY;
    private int mMoveX;
    //抬起
    private int mEndY;
    private int mEndX;
    private FileOutputStream mFos;
    private Bitmap mBmCopy;

    @SuppressLint("ClickableViewAccessibility")
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mImage = findViewById(R.id.image);
        //加载原图
         Bitmap bmSrc = BitmapFactory.decodeResource(getResources(), R.drawable.bg);
        //创建白纸,设置宽高图片
        mBmCopy = Bitmap.createBitmap(bmSrc.getWidth(), bmSrc.getHeight(), bmSrc.getConfig());
        //创建画板
        mCanvas = new Canvas(mBmCopy);
        //创建画笔
        mPaint = new Paint();
        //在纸上画画,白 板在纸上
        mCanvas.drawBitmap(bmSrc, new Matrix(), mPaint);
        //手势识别器和画笔的结合
        mImage.setOnTouchListener(new View.OnTouchListener() {

            @Override
            public boolean onTouch(View v, MotionEvent event) {
                switch ((event.getAction())) {
                    case MotionEvent.ACTION_DOWN://按下执行
                        //获取用户按下时的坐标
                        mStartX = (int) event.getX();
                        mStartY = (int) event.getY();

                        break;
                    case MotionEvent.ACTION_MOVE://移动执行
                        //获取用户移动的坐标
                        mMoveX = (int) event.getX();
                        mMoveY = (int) event.getY();

                        mCanvas.drawLine(mStartX, mStartY, mMoveX, mMoveY, mPaint);
                        mStartX = mMoveX;
                        mStartY = mMoveY;
                        mImage.setImageBitmap(mBmCopy);
                        break;
                    case MotionEvent.ACTION_UP://抬起执行
                        break;
                }
                return true;
            }

        });

    }

    @Override
    public void onClick(View v) {
        switch (v.getId()){
            case R.id.red:
                mPaint.setColor(Color.RED);
                break;
            case R.id.green:
                mPaint.setColor(Color.GREEN);
                break;
            case R.id.brush:
                mPaint.setStrokeWidth(20);
                break;
            case R.id.save://保存
                //创建文件夹,需要写入内存的权限
                File file = new File("/sdcard/whq");
                //判断文件是否为空
                if (!file.exists()){
                    //为空创建
                    file.mkdir();
                    //创建输出流,将文件的路径和照片的命名
                    try {
                        mFos = new FileOutputStream(file.getPath() + "/1.png");
                        mBmCopy.compress(Bitmap.CompressFormat.PNG,100,mFos);

                    } catch (Exception e) {
                        e.printStackTrace();
                    }finally {
                        //关闭流
                        try {
                            mFos.close();
                        } catch (IOException e) {
                            e.printStackTrace();
                        }
                    }
                }
                break;
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值