1.使用BitmapShader实现图片圆角

public class CornerDrawable extends Drawable {
private Paint mPaint;
private Bitmap bmp;
private RectF rectF; public CornerDrawable(Bitmap bmp) {
this.bmp = bmp;
BitmapShader shader = new BitmapShader(bmp, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);
// CLAMP 拉伸
// REPEAT 重复
// MIRROR 镜像
// BitmapShader是从画布的左上角开始绘制的
mPaint = new Paint();
mPaint.setAntiAlias(true);
mPaint.setShader(shader);
} @Override
public void draw(Canvas canvas) {
Rect rect = getBounds();
// Log.e(getClass().getSimpleName(), rect.left + ":" + rect.width() + ":" + rect.height());
// Log.e(getClass().getSimpleName(), rectF.left + ":" + rectF.width() + ":" + rectF.height());
canvas.drawRoundRect(rectF, 20, 20, mPaint);
} @Override
public void setAlpha(int alpha) {
mPaint.setAlpha(alpha);
} @Override
public void setColorFilter(ColorFilter cf) {
mPaint.setColorFilter(cf);
} @Override
public int getOpacity() {
return PixelFormat.TRANSLUCENT;
} // getIntrinsicWidth、getIntrinsicHeight主要是为了在View使用wrap_content的时候,提供一下尺寸
@Override
public int getIntrinsicHeight() {
return bmp.getHeight();
} @Override
public int getIntrinsicWidth() {
return bmp.getWidth();
} @Override
public void setBounds(int left, int top, int right, int bottom) {
super.setBounds(left, top, right, bottom);
rectF = new RectF(left, top, right, bottom);
}
}

2.除了圆角外,还可以指定画图片的某圆弧对应的内容

重写上面的draw方法如下

RectF rf = new RectF(-100, -130, 160, 130);
canvas.drawArc(rf, 0, 120, true, paint);

3.使用PorterDuffXfermode

    @Override
public void draw(Canvas canvas) {
PorterDuffXfermode pdf = new PorterDuffXfermode(PorterDuff.Mode.SRC_IN);
     paint.drawBitmap(dst, 0, 0, paint);
paint.setXfermode(pdf);
paint.setColor(0xffff4400);
canvas.drawBitmap(src, 0, 0, paint);
paint.setXfermode(null);
}

http://www.jianshu.com/p/d11892bbe055

》》XferMode

  1. AvoidXfermode  指定了一个颜色和容差,强制Paint避免在它上面绘图(或者只在它上面绘图)。
  2. PixelXorXfermode  当覆盖已有的颜色时,应用一个简单的像素异或操作。
  3. PorterDuffXfermode  这是一个非常强大的转换模式,使用它,可以使用图像合成的16条Porter-Duff规则的任意一条来控制Paint如何与已有的Canvas图像进行交互。

》》PorterDuff.Mode为枚举类,一共有16个枚举值:

  • PorterDuff.Mode.CLEAR    所绘制不会提交到画布上。
  • PorterDuff.Mode.SRC   显示上层绘制图片
  • PorterDuff.Mode.DST  显示下层绘制图片
  • PorterDuff.Mode.SRC_OVER  正常绘制显示,上下层绘制叠盖。
  • PorterDuff.Mode.DST_OVER  上下层都显示。下层居上显示。
  • PorterDuff.Mode.SRC_IN   取两层绘制交集。显示上层。
  • PorterDuff.Mode.DST_IN  取两层绘制交集。显示下层。
  • PorterDuff.Mode.SRC_OUT 取上层绘制非交集部分。
  • PorterDuff.Mode.DST_OUT 取下层绘制非交集部分。
  • PorterDuff.Mode.SRC_ATOP 取下层非交集部分与上层交集部分
  • PorterDuff.Mode.DST_ATOP 取上层非交集部分与下层交集部分
  • PorterDuff.Mode.XOR  异或:去除两图层交集部分
  • PorterDuff.Mode.DARKEN  取两图层全部区域,交集部分颜色加深
  • PorterDuff.Mode.LIGHTEN  取两图层全部,点亮交集部分颜色
  • PorterDuff.Mode.MULTIPLY  取两图层交集部分叠加后颜色
  • PorterDuff.Mode.SCREEN  取两图层全部区域,交集部分变为透明色

参考:ApiDemos/Graphics/XferModes

4.对图片进行颜色转换

    public static Drawable getPrimaryDrawable(int resId) {
Drawable icon = context.getResources().getDrawable(resId);
int baseColor = context.getResources().getColor(R.color._secondary_color);
icon.setColorFilter(baseColor, PorterDuff.Mode.SRC_IN);
return icon;
}

5.通过xml定义drawable

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape>
<solid android:color="#ff80cbc4" />
</shape>
</item>
<item android:top="48dp">
<bitmap
android:gravity="center"
android:src="@drawable/app_background_png"
android:tileMode="disabled" />
</item>
</layer-list>

6.自定义按钮状态

    <declare-styleable name="CustomStateDrawableButton">
<attr name="state_readed" format="boolean" />
</declare-styleable>

定义一个状态

public class CustomStateDrawableButton extends ImageButton {
public static final int[] MessageReaded = {R.attr.state_readed};
private boolean isReaded = false; public CustomStateDrawableButton(Context context) {
super(context);
} public CustomStateDrawableButton(Context context, AttributeSet attrs) {
super(context, attrs);
} public CustomStateDrawableButton(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
} public void setReaded(boolean isReaded) {
if (this.isReaded != isReaded) {
this.isReaded = isReaded;
//
refreshDrawableState();
}
} @Override
public int[] onCreateDrawableState(int extraSpace) {
if (!isReaded) {
int[] ds = super.onCreateDrawableState(extraSpace + 1);
mergeDrawableStates(ds, MessageReaded);
return ds;
}
return super.onCreateDrawableState(extraSpace);
}
}
// http://www.devdiv.com/Android-Android%E4%B8%ADDrawable%E5%88%86%E7%B1%BB%E6%B1%87%E6%80%BB%EF%BC%88%E4%B8%8A%EF%BC%89-thread-126853-1-1.html
// ColorDrawable、GradientDrawable、BitmapDrawable、 NinePatchDrawable、InsetDrawable、ClipDrawable、ScaleDrawable、RotateDrawable、AnimationDrawable、LayerDrawable、LevelListDrawable、StateListDrawable、TransitionDrawable

Android 自定义Drawable的更多相关文章

  1. Android自定义drawable(Shape)详解

    在Android开发过程中,经常需要改变控件的默认样式, 那么通常会使用多个图片来解决.不过这种方式可能需要多个图片,比如一个按钮,需要点击时的式样图片,默认的式样图片. 这样就容易使apk变大. 那 ...

  2. Android APK开发 Drawable文件夹下的自定义Drawable文件

    版本:2018/2/11 Drawable的分类 自定义Drawable SVG矢量图 个人总结的知识点外,部分知识点选自<Android开发艺术探索>-第六章 Drawable 1.Dr ...

  3. Android 使用自定义Drawable 设置圆角矩形或者圆形图片

    转自  Android Drawable 那些不为人知的高效用法 本文出自:[张鸿洋的博客] http://blog.csdn.net/lmj623565791/article/details/437 ...

  4. Android—自定义开关按钮实现

    我们在应用中经常看到一些选择开关状态的配置文件,做项目的时候用的是android的Switch控件,但是感觉好丑的样子………… 个人认为还是自定义的比较好,先上个效果图:

  5. android 自定义通知栏

    package com.example.mvp; import cn.ljuns.temperature.view.TemperatureView;import presenter.ILoginPre ...

  6. 最简单的android自定义进度条样式

    一.自定义圆形进度条样式 1.在安卓项目drawable目录下新建一个xml文件如下:<?xml version="1.0" encoding="utf-8&quo ...

  7. Android自定义spinner下拉框实现的实现

    一:前言 本人参考博客:http://blog.csdn.net/jdsjlzx/article/details/41316417 最近在弄一个下拉框,发现Android自带的很难实现我的功能,于是去 ...

  8. Android自定义对话框

    在android中有自带的对话框,为了美观,很多开发者会使用自定义对话框,如下图: 点击“弹出自定义对话框按钮后”显示如图效果. 首先要自己定义一个xml文件定义自己对话框的样式: <?xml ...

  9. android 自定义Style初探---ProgressBar

    系统自带的ProgressBar太丑了,所以我决定自定义一个Style. 原来的Style <?xml version="1.0" encoding="utf-8& ...

随机推荐

  1. 每日代码 - 6/26 lambda表达式

    public class CartViewRender { public static CartView renderMyCartView(Cart cart){ ErrorCodeEnum erro ...

  2. [ThingWorx] Install PostgreSQL Issue

    ThingWorx application need PostgreSQL, I try configurate it in macbook. The first step is install Po ...

  3. 常用js方法整理common.js

    项目中常用js方法整理成了common.js var h = {}; h.get = function (url, data, ok, error) { $.ajax({ url: url, data ...

  4. MATLAB实现将图像转换为素描(简笔画)风格

    代码: colorgrad.m function [VG, A, PPG] = colorgrad(f, T) ) || (size(f,)~=) error('Input image must be ...

  5. Atitit.词法分析的原理 理论

    Atitit.词法分析的原理 理论 1. 分词 .词法分析lexical analysis 1 1.1. 分词主要流程 1 1.2. 分词的属性如下表token 1 1.3. 词法分析器主要包括:构造 ...

  6. paip.mysql fulltext 全文搜索.最佳实践.

    paip.mysql fulltext 全文搜索.最佳实践.  作者Attilax  艾龙,  EMAIL:1466519819@qq.com  来源:attilax的专栏 地址:http://blo ...

  7. paip。java 高级特性 类默认方法,匿名方法+多方法连续调用, 常量类型

    paip.java 高级特性 类默认方法,匿名方法+多方法连续调用, 常量类型 作者Attilax 艾龙,  EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http ...

  8. java 初学者需注意问题

    1.Java为什么能跨平台运行? Java语言编写的程序既是编译型的,又是解释型的.程序代码经过编译之后转换为一种Java字节码的中间语言,Java虚拟机即JVM将对字节码进行解释和运行.编译只进行一 ...

  9. chrome浏览器扩展的事件处理

    关于chrome扩展开发的栗子已经有很多了,问问度娘基本能满足你的欲望, 我想说的是扩展和页面间的数据传递问题. 我们知道写扩展有个必须的文件就是“manifest.json”, 这个里面定义了一个和 ...

  10. python爬虫代码

    原创python爬虫代码 主要用到urllib2.BeautifulSoup模块 #encoding=utf-8 import re import requests import urllib2 im ...