android canvas, paint ,Bitmap,BitmapFactory类介绍

Paint类

setAlpha(int a) 透明度

setColor(int color)设置颜色值

setAntiAlias(boolean aa) 抗锯齿

setStrokeWidth(float width);  当画笔样式为STROKE或FILL_OR_STROKE时,设置笔刷的粗细度

setShader(Shader shader);  设置图像效果,使用Shader可以绘制出各种渐变效果

setSrokeJoin(Paint.Join join); 设置绘制时各图形的结合方式,如平滑效果等

setStrokeCap(Paint.Cap cap);  当画笔样式为STROKE或FILL_OR_STROKE时,设置笔刷的图形样式,如圆形样式    Cap.ROUND,或方形样式Cap.SQUARE

setStyle(Paint.Style style):填充样式

Paint.Style.FILL  填充内部

Paint.Style.FILL_AND_STROKE 填充内部和描边

Paint.Style.STROKE  仅描边

setShadowLayer (float radius, float dx, float dy, int color)  添加阴影 radius:阴影的倾斜度,dx:水平位移,dy:垂直位移

setDither(boolean dither);是否使用图像抖动处理,会使绘制出来的图片颜色更加平滑和饱满,图像更加清晰

setMaskFilter(MaskFilter maskfilter);可以用不同的MaskFilter实现滤镜的效果,如滤化,立体等

setPathEffect(PathEffect effect): PathEffect是用来控制绘制轮廓(线条)的方式

CornerPathEffect  //将线段与线段之间的夹角转换成圆角,参数表示半径

DashPathEffect  //用于绘制虚线路径,第一个参数表示虚线的长度和虚线间隔的距离,改参数是float数组,数组长度必须大于2,也就是指定一个虚线的长度,必须指定虚线的间隔,第二个参数是偏移量,不断改变呈现虚线前后移动效果

ComposePathEffect //将两种特效组合一起,第一个参数必须是形状特效既DashPathEffect或PathDashPathEffect,第二个参数是外观特效既CornerPathEffect对象

setXfermode(Xfermode xfermode); 设置图形重叠时的处理方式,如合并,取交集或并集,经常用来制作橡皮的擦除效果

//文本绘制 部分

setFakeBoldText(boolean fakeBoldText);  模拟实现粗体文字,设置在小字体上效果会非常差

setSubpixelText(boolean subpixelText);    设置该项为true,将有助于文本在LCD屏幕上的显示效果

setTextAlign(Paint.Align align);  设置绘制文字的对齐方向

setTextScaleX(float scaleX);  设置绘制文字x轴的缩放比例,可以实现文字的拉伸的效果

setTextSize(float textSize);  设置绘制文字的字号大小

setTextSkewX(float skewX);  设置斜体文字,skewX为倾斜弧度

setTypeface(Typeface typeface);  设置Typeface对象,即字体风格,包括粗体,斜体以及衬线体,非衬线体等

setUnderlineText(boolean underlineText);  设置带有下划线的文字效果

setStrikeThruText(boolean strikeThruText);    设置带有删除线的效果

measureText(String text) 测量文字 返回文字宽度

Bitmap类(对位图进行一系列的拉伸缩放,压缩等操作)

createBitmap(Bitmap src) 以src为原图生成不可变得新图像

createBitmap(int width, int height, Bitmap.Config config) 创建指定格式、大小的位图

createBitmap(int[] colors, int width, int height, Bitmap.Config config) 得到整个图片的颜色集合,绘制指定宽高的图

createBitmap(Bitmap source, int x, int y, int width, int height) 以source为原图,创建新的图片,指定起始坐标以及新图像的高宽。

createScaledBitmap(Bitmap src, int dstWidth, int dstHeight, boolean filter) 以src为原图,创建新的图像,指定新图像的高宽以及是否可变。

getWidth() 获取位图的宽度

getHeight() 获取位图的高度

recycle() 回收位图占用的内存空间,把位图标记为Dead

isRecycled()  判断位图内存是否已释放

isMutable() 图片是否可修改

getScaledWidth(Canvas canvas) 获取指定密度转换后的图像的宽度

getScaledHeight(Canvas canvas) 获取指定密度转换后的图像的高度

getPixels(int[] pixels, int offset, int stride, int x, int y, int width, int height) 复制所有像素值到pixels数组,offset数组中第一个下标,

compress(CompressFormat format, int quality, OutputStream stream)压缩,按指定的图片格式以及画质,将图片转换为输出流。

format:Bitmap.CompressFormat.PNG或Bitmap.CompressFormat.JPEG

quality:画质,0-100.0表示最低画质压缩,100以最高画质压缩。对于PNG等无损格式的图片,会忽略此项设置。

BitmapFactory类 (创建位图对象从不同的来源,包括文件、流和字节数组)

decodeByteArray(byte[] data, int offset, int length, BitmapFactory.Options opts) 从字节数组中解码生成不可变的位图

decodeFile(String pathName, BitmapFactory.Options opts)读取一个文件得到一个位图

decodeResource(Resources res, int id) 读取一个资源文件得到一个位图

decodeResource(Resources res, int id, BitmapFactory.Options opts)

decodeStream(InputStream is) 从输入流中解码位图

Option 参数类:

inJustDecodeBounds——如果设置为true,不获取图片,不分配内存,但会返回图片的高度宽度信息。

inSampleSize——图片缩放的倍数。如果设为4,则宽和高都为原来的1/4,则图是原来的1/16。

outWidth——获取图片的宽度值

outHeight——获取图片的高度值

inDensity——用于位图的像素压缩比

inTargetDensity——用于目标位图的像素压缩比(要生成的位图)

inScaled——设置为true时进行图片压缩,从inDensity到inTargetDensity

Drawable类

draw(Canvas canvas) 绘制到画布上

setBounds(int left, int top, int right, int bottom) 设置绘制位图的左上角坐标,宽度和高度

Canvas类

//画点

drawPoint(float x, float y, Paint paint);绘制一个点, x坐标,y坐标,Paint对象

drawPoints(float[] pts, Paint paint) ;绘制多个点,pts坐标点集合,每两个值组成一个xy坐标点

drawPoints(float[] pts, int offset, int count, Paint paint);绘制多个点, pts坐标集合,每两个值为一个xy坐标点,offset 和count 表示从offset下标开始绘制count个坐标

//画线

drawLine(float startX, float startY, float stopX, float stopY, Paint paint);绘制一条线

drawLines(float[] pts, Paint paint);绘制多条线,pts中每四个值为一组标示一条线

drawLines(float[] pts, int offset, int count, Paint paint) ;绘制多条线,offset和count代表pts中下标为offset开始绘制count个值

//画圆

drawCircle(float cx, float cy, float radius, Paint paint);绘制圆形,xy圆心距离x的坐标,cy圆心距离cy的坐标,radius半径

//画矩形

drawRect(float left, float top, float right, float bottom, Paint paint);绘制矩形,左上角的xy坐标,右下角的xy坐标

drawRect(RectF rect, Paint paint) 绘制矩形,rect为矩形对象

drawRoundRect(RectF rect, float rx, float ry, Paint paint) 绘制圆角矩形

//画弧

drawArc(RectF oval, float startAngle, float sweepAngle, boolean useCenter, Paint paint);绘制弧形,顺时针方向,oval矩形区域,startAngle起始角度,sweepAngle偏移量角度,usecenter true弧形两端与中心点相连,false不连接,

//椭圆

drawOval(RectF oval, Paint paint) 绘制椭圆

//路径

drawPath(Path path, Paint paint) 绘制路径

//绘制图片

drawPicture(Picture picture) 绘制图片

drawPicture(Picture picture, RectF dst) 指定区域绘制图片

//绘制文本

drawText(String text, int start, int end, float x, float y, Paint paint) 绘制文本 xy为基线坐标

drawTextOnPath(String text, Path path, float hOffset, float vOffset, Paint paint) 绘制路径文本 hOffset水平偏移 vOffset垂直偏移

drawTextOnPath(char[] text, int index, int count, Path path, float hOffset, float vOffset, Paint paint)

//位图

drawBitmap(Bitmap bitmap, Matrix matrix, Paint paint)

drawBitmap(Bitmap bitmap, Rect src, Rect dst, Paint paint) 从一个指定区域绘制图到另一个指定区域

drawBitmap(Bitmap bitmap, float left, float top, Paint paint)

//扭曲图像

drawBitmapMesh(Bitmap bitmap, int meshWidth, int meshHeight, float[] verts, int vertOffset, int[] colors, int colorOffset, Paint paint):

bitmap:要扭曲的原始图像

meshWidth:扭曲的原始头像的宽度

meshHeight:扭曲的原始头像的高度

verts:扭曲区域的像素坐标

vertOffset:verts数组的偏移量,一般可设0

colors:扭曲区域像素的颜色,可设为null

colorOffset: colors数组的偏移量

translate(float dx, float dy) 平移 xy为移动距离

scale (float sx, float sy),分别是x,y轴的缩放比例

scale (float sx, float sy, float px, float py),x.y轴的缩放比例,px,py表示缩放中心位置

rotate (float degrees),旋转角度(顺时针)

rotate (float degrees, float px, float py),旋转角度和控制点

skew (float sx, float sy) 画布倾斜 sx:将画布在x方向上倾斜相应的角度,sx倾斜角度的tan值, sy:将画布在y轴方向上倾斜相应的角度,sy为倾斜角度的tan值.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容