Android 成长笔记Android知识Android开发

Android 双缓冲 使用 示例

2017-04-10  本文已影响100人  赵者也

本文参考文献:《疯狂Android讲义(第2版)》

自定义视图:

package com.toby.personal.testlistview;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.MaskFilter;
import android.graphics.Paint;
import android.graphics.Path;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;

/**
 * Created by toby on 2017/4/10.
 */

public class DrawView extends View {

    private final static int VIEW_WIDTH = 720;
    private final static int VIEW_HEIGHT = 1280;

    private float preX;
    private float preY;
    private Path path;
    private Paint paint = null;
    private Paint bmpPaint = null;
    private Bitmap cacheBitmap = null;
    private Canvas cacheCanvas = null;

    public DrawView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);

        cacheBitmap = Bitmap.createBitmap(VIEW_WIDTH, VIEW_HEIGHT, Bitmap.Config.ARGB_8888);
        cacheCanvas = new Canvas();
        path = new Path();
        cacheCanvas.setBitmap(cacheBitmap);

        paint = new Paint(Paint.DITHER_FLAG);
        paint.setColor(Color.RED);
        paint.setStyle(Paint.Style.STROKE);
        paint.setStrokeWidth(1);
        paint.setAntiAlias(true);
        paint.setDither(true);

        bmpPaint = new Paint();
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {

        float x = event.getX();
        float y = event.getY();

        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                path.moveTo(x, y);
                preX = x;
                preY = y;
                break;
            case MotionEvent.ACTION_MOVE:
                path.quadTo(preX, preY, x, y);
                preX = x;
                preY = y;
                break;
            case MotionEvent.ACTION_UP:
                cacheCanvas.drawPath(path, paint);
                path.reset();
                break;
        }
        invalidate();
        return true;
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        canvas.drawBitmap(cacheBitmap, 0, 0, bmpPaint);
        canvas.drawPath(path, paint);
    }

    public void setColor(int color){
        paint.setColor(color);
    }

    public void setStrokeWidth(float width){
        paint.setStrokeWidth(width);
    }

    public void setMaskFilter(MaskFilter maskFilter){
        paint.setMaskFilter(maskFilter);
    }
}

自定义 menu 资源文件:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:title="@string/color">
        <menu>
            <group android:checkableBehavior="single">
                <item
                    android:id="@+id/red"
                    android:title="@string/color_red" />
                <item
                    android:id="@+id/green"
                    android:title="@string/color_green" />
                <item
                    android:id="@+id/blue"
                    android:title="@string/color_blue" />
            </group>
        </menu>
    </item>

    <item android:title="@string/width">
        <menu>
            <group>
                <item
                    android:id="@+id/width_1"
                    android:title="@string/width_1" />
                <item
                    android:id="@+id/width_3"
                    android:title="@string/width_3" />
                <item
                    android:id="@+id/width_5"
                    android:title="@string/width_5" />
            </group>
        </menu>
    </item>

    <item
        android:id="@+id/blur"
        android:title="@string/blur" />

    <item
        android:id="@+id/emboss"
        android:title="@string/emboss" />
</menu>

主布局文件的内容:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/colorGray"
    android:orientation="vertical"
    android:id="@+id/container"
    >

    <com.toby.personal.testlistview.DrawView
        android:id="@+id/drawView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>

主程序文件的内容:

package com.toby.personal.testlistview;

import android.graphics.BlurMaskFilter;
import android.graphics.Color;
import android.graphics.EmbossMaskFilter;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;

public class MainActivity extends AppCompatActivity {

    final private static String TAG = "Toby_Test";

    EmbossMaskFilter emboss;
    BlurMaskFilter blur;

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

        emboss = new EmbossMaskFilter(new float[]{1.5f, 1.5f, 1.5f}, 0.6f, 6, 4.2f);
        blur = new BlurMaskFilter(8, BlurMaskFilter.Blur.NORMAL);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        MenuInflater inflater = new MenuInflater(this);
        inflater.inflate(R.menu.test_menu01, menu);
        return super.onCreateOptionsMenu(menu);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        DrawView drawView = (DrawView) findViewById(R.id.drawView);

        switch (item.getItemId()){
            case R.id.red:
                drawView.setColor(Color.RED);
                item.setChecked(true);
                break;
            case R.id.green:
                drawView.setColor(Color.GREEN);
                item.setChecked(true);
                break;
            case R.id.blue:
                drawView.setColor(Color.BLUE);
                item.setChecked(true);
                break;
            case R.id.width_1:
                drawView.setStrokeWidth(1);
                break;
            case R.id.width_3:
                drawView.setStrokeWidth(3);
                break;
            case R.id.width_5:
                drawView.setStrokeWidth(5);
                break;
            case R.id.blur:
                drawView.setMaskFilter(blur);
                break;
            case R.id.emboss:
                drawView.setMaskFilter(emboss);
                break;
        }

        return true;
    }
}

运行效果:

显示效果
上一篇下一篇

猜你喜欢

热点阅读