绘图 画笔特效处理

paint 常用的属性:带边框,填充的style,颜色,宽度,抗锯齿(ANTI_ALIAS_FLAG)
详细的链接如下 http://blog.sina.com.cn/s/blog_783ede0301012ilk.html

高级特性:PorterDuffXfermode 有些类似于数学的交集和并集。用的最多的是,使用一张图片作为另一张图片的遮罩层,DST_IN,SRC_IN 模式来实现将一个矩形图片变成圆角图片或者圆形图片的效果。
要使用PorterDuffXfermodel很简单,只需要让这个画面拥有这样的属性即可 。 常用方法,先用一个普通画笔画一个遮罩层,再用带PorterDuffXfermodel的画笔将图片画在遮罩层上。这样就达到了混合两个图片的目的。

简单例子: 实现圆角图片
package xiaoxu.picture;

import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.RectF;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity {

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

    init();//初始化
    mImage.setImageBitmap( changePic());
}

private Bitmap changePic() {

Bitmap bm = BitmapFactory.decodeResource(getResources(),R.drawable.rr2);
Bitmap bitmap = Bitmap.createBitmap(bm.getWidth(),bm.getHeight(), Bitmap.Config.ARGB_8888);

   Canvas canvas = new Canvas(bitmap);
   Paint mPaint = new Paint();
   canvas.drawRoundRect(new RectF(0,0,bm.getWidth(),bm.getHeight()),100,60,mPaint);

    mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));//画笔特效处理

    canvas.drawBitmap(bm,0,0,mPaint);

    return  bitmap;

}

void init(){
   mImage = (ImageView)findViewById(R.id.mImage);

}

}

实例二 实现刮刮卡的效果 自定义View如下
package xiaoxu.picture;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;

/**
* Created by Administrator on 2016/4/2.
*/
//实现刮刮卡效果
public class ScratchView extends View {

private Bitmap bm;
private Bitmap bitmap;
private Paint paint;
private Canvas canvas1;

Path path = new Path();

public ScratchView(Context context, AttributeSet attrs) {
    super(context, attrs);

    bm = BitmapFactory.decodeResource(context.getResources(), R.drawable.rr2);//从资源中获取要处理的图片
    bitmap = Bitmap.createBitmap(bm.getWidth(), bm.getHeight(), Bitmap.Config.ARGB_8888);//创建一个位图它获得图片大小的尺寸。

    paint = new Paint();
    paint.setAlpha(0);  //**要将透明度设置为0能显示出擦除的效果,因为在使用透明通道混合的时候,
    // 并不是进行简单的图层计算,同时也会去计算透明通道的值。
    paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_IN));
    paint.setStrokeCap(Paint.Cap.ROUND);  //设置一些属性,让笔触和连接处圆滑
    paint.setStrokeJoin(Paint.Join.ROUND);
    paint.setStrokeWidth(50);

    canvas1 = new Canvas(bitmap);//创建画布,并将接下来在画布上进行操作的信息存储在bitmap中。
    canvas1.drawColor(Color.GRAY);

}
  @Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()) {
        case MotionEvent.ACTION_DOWN:

            path.reset();
            path.moveTo(event.getX(), event.getY());

            break;
        case MotionEvent.ACTION_MOVE:

            path.lineTo(event.getX(), event.getY());
            //通过监听获得到移动的位置的坐标,并设置到path中
            break;

    }

canvas1.drawPath(path, paint);//画出路径,使用带有特殊效果的笔

    invalidate();//重新调用onDrow()

    return true;
}

@Override
protected void onDraw(Canvas canvas) {

    canvas.drawBitmap(bm, 0, 0, null);
    canvas.drawBitmap(bitmap, 0, 0, null);
 }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值