Android开发基于Drawable实现圆角矩形的方法

本文实例讲述了Android开发基于Drawable实现圆角矩形的方法。分享给大家供大家参考,具体如下:

第一步:写个类继承drawable,重写里面的方法,实现的核心代码在draw里

关键技术:BitmapShader

public BitmapShader(Bitmap bitmap,Shader.TileMode tileX,Shader.TileMode tileY)

调用这个方法来产生一个画有一个位图的渲染器(Shader)。

bitmap 在渲染器内使用的位图
tileX The tiling mode for x to draw the bitmap in. 在位图上X方向渲染器平铺模式
tileY The tiling mode for y to draw the bitmap in. 在位图上Y方向渲染器平铺模式

TileMode:
CLAMP :如果渲染器超出原始边界范围,会复制范围内边缘染色。
REPEAT :横向和纵向的重复渲染器图片,平铺。
MIRROR :横向和纵向的重复渲染器图片,这个和REPEAT重复方式不一样,他是以镜像方式平铺。

/**
* 四种屏幕尺寸分类:: small, normal, large, and xlarge
* 四种密度分类: ldpi (low), mdpi (medium), hdpi (high), and xhdpi (extra high)
* 四种屏幕的DPI:ldpi是120dpi,mdpi是160dpi,hdpi是240dpi,xhdpi是320dpi
* 四种屏幕对应density:0.75,1,1.5,2
* 四种图片资源文件夹:drawable-ldpi,drawable-mdpi,drawable-hdpi,drawable-xhdpi
*/
/**
 * 圆角
 *
 * @Project App_View
 * @Package com.android.view.drawable
 * @author chenlin
 * @version 1.0
 * @Note TODO
 */
public class RoundImageDrawable extends Drawable {
 private Paint mPaint;
 private Bitmap mBitmap;
 private RectF mRectF;
 private int mRound;
 public RoundImageDrawable(Bitmap bitmap) {
  this.mBitmap = bitmap;
  mPaint = new Paint();
  mPaint.setAntiAlias(true);
  BitmapShader shader = new BitmapShader(mBitmap, TileMode.CLAMP, TileMode.CLAMP);
  mPaint.setShader(shader);
 }
 /**
  * 初始化区域
  */
 @Override
 public void setBounds(int left, int top, int right, int bottom) {
  mRectF = new RectF(left, top, right, bottom);
  super.setBounds(left, top, right, bottom);
 }
 /**
  * 核心代码: 绘制圆角
  */
 @Override
 public void draw(Canvas canvas) {
  canvas.drawRoundRect(mRectF, mRound, mRound, mPaint);
 }
 /**
  * 暴露给外面设置圆角的大小
  *
  * @param round
  */
 public void setRound(int round) {
  this.mRound = round;
 }
 /**
  * getIntrinsicWidth、getIntrinsicHeight主要是为了在View使用wrap_content的时候,
  * 提供一下尺寸,默认为-1可不是我们希望的
  */
 @Override
 public int getIntrinsicHeight() {
  return mBitmap.getHeight();
 }
 @Override
 public int getIntrinsicWidth() {
  return mBitmap.getWidth();
 }
 /**
  * 根据画笔设定drawable的透明度
  */
 @Override
 public void setAlpha(int alpha) {
  mPaint.setAlpha(alpha);
 }
 /**
  * 根据画笔设定drawable的颜色过滤器
  */
 @Override
 public void setColorFilter(ColorFilter cf) {
  mPaint.setColorFilter(cf);
 }
 @Override
 public int getOpacity() {
  return PixelFormat.TRANSLUCENT;
 }
}

第二步:实现类

public class RoundActivity extends Activity {
 private ImageView mImageView;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_round_drawable);
  setContentView(R.layout.activity_round_drawable);
  mImageView = (ImageView) findViewById(R.id.iv_round);
  Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.aa);
  RoundImageDrawable drawable = new RoundImageDrawable(bitmap);
  drawable.setRound(30);
  mImageView.setImageDrawable(drawable); }
}

activity_round_drawable.xml

<?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:orientation="vertical" >
 <ImageView
  android:id="@+id/iv_round"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:scaleType="fitXY" />
</LinearLayout>

绘制圆形图片

核心代码:

mWidth = Math.min(bitmap.getWidth(), bitmap.getHeight());
canvas.drawCircle(mWidth / 2, mWidth / 2, mRadius, mPaint);
/**
 * 圆形
 * @Project  App_View
 * @Package  com.android.view.drawable
 * @author   chenlin
 * @version  1.0
 * @Note    TODO
 */
public class CircleImageDrawable extends Drawable {
  private Bitmap mBitmap;
  private Paint mPaint;
  private int mWidth;
  private int mRadius;
  public CircleImageDrawable(Bitmap bitmap){
    this.mBitmap = bitmap;
    mPaint.setAntiAlias(true);
    BitmapShader shader = new BitmapShader(mBitmap, TileMode.CLAMP, TileMode.CLAMP);
    mPaint.setShader(shader);
    mWidth = Math.min(bitmap.getWidth(), bitmap.getHeight());
    mRadius = mWidth / 2;
  }
  /**
   * 核心代码
   */
  @Override
  public void draw(Canvas canvas) {
    canvas.drawCircle(mWidth / 2, mWidth / 2, mRadius, mPaint);
  }
  /**
   * getIntrinsicWidth、getIntrinsicHeight主要是为了在View使用wrap_content的时候,
   * 提供一下尺寸,默认为-1可不是我们希望的
   */
  @Override
  public int getIntrinsicHeight() {
    return mWidth;
  }
  @Override
  public int getIntrinsicWidth() {
    return mWidth;
  }
  @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;
  }
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android图形与图像处理技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • Android自定义Drawable实现圆角效果

    Drawable是一种可绘制资源的载体,如图形.图像等.在实际开发中可以作为view的背景.主要有静态和动态两种方式,静态通过xml描述使用,动态即自定义Drawable.本文实现一个圆形和圆角的背景图片效果. 效果图: 实现方式: 1.初始化一个BitmapShader着色器对象: 2.将着色器对象set给画笔: 3.在画布上绘制圆或圆角即可: 4.使用,view.setBackgroundDrawable 或者 ImageView.setImageDrawable package com.m

  • 关于Android中drawable必知的一些规则

    前言 一入 Android 深似海,相信很多 Android 开发者深有体会,Android 系统版本的碎片化,Android 硬件设备的多样性,第三方 Rom 的不确定因素.现在想开发一个合格的商业化 App 真的不容易,先不说别的,应用的兼容性就是一项技术和耐心的双重考验,想完美适配各种情况可以说是不可能的,往往都是在人力和适配率之间寻找平衡,今天要说的 drawable 就是需要适配的一个重要角色. 配置限定符 对于不同的屏幕密度.不同的设备方向,不同的语言和区域,都会涉及到备选 draw

  • Android App开发中将View或Drawable转为Bitmap的方法

    View转换为Bitmap Android中经常会遇到把View转换为Bitmap的情形,比如,对整个屏幕视图进行截屏并生成图片:Coverflow中需要把一页一页的view转换为Bitmap.以便实现复杂的图形效果(阴影.倒影效果等):再比如一些动态的实时View为便于观察和记录数据.需要临时生成静态的Bitmap. 实现方法: 1)下面是笔者经常用的一个转换方法 public static Bitmap convertViewToBitmap(View view, int bitmapWid

  • android中图形图像处理之drawable用法分析

    本文实例讲述了android中图形图像处理之drawable用法.分享给大家供大家参考.具体如下: 一.如何获取 res 中的资源 数据包package:android.content.res 主要类:Resources 其主要接口按照功能,划分为以下三部分: getXXXX() 例如: int getColor(int id) Drawable getDrawable(int id) String getString(int id)  直接获取res中存放的资源 InputStream ope

  • Android LayerDrawable使用实例

    1.在Android项目开发的时候,经常看到很漂亮的UI界面,比如,当你点击一张图片被选中的时候,覆上一张透明的图片.表示被选中,区别与那些没有被选中的.这种是如何实现的呢?答案是LayerDrawable的使用出现的效果.下面是LayerDrawable的总结,若有不正确的地方,请大家指正. 2.简单的来说,LayerDrawable继承与Drawable,Drawable就是一个可画的对象,可能是一张位图BitmapDrawable,也可能是一个图形ShapeDrawable,还有可能是一个

  • Android Bitmap和Drawable相互转换的简单代码

    很多开发者表示,不知道Android的Drawable和Bitmap之间如何相关转换.下面Android123给大家两种比较简单高效的方法. 一.Bitmap转Drawable 复制代码 代码如下: Bitmap bm=xxx; //xxx根据你的情况获取 BitmapDrawable bd=BitmapDrawable(bm); Android开发网提示因为BtimapDrawable是Drawable的子类,最终直接使用bd对象即可. 二. Drawable转Bitmap 转成Bitmap对

  • Android 让自定义TextView的drawableLeft与文本一起居中

    前言 TextView的drawableLeft.drawableRight和drawableTop是一个常用.好用的属性,可以在文本的上下左右放置一个图片,而不使用更加复杂布局就能达到,我也常常喜欢用RadioButton的这几个属性实现很多效果,但是苦于不支持让drawbleLeft与文本一起居中,设置gravity为center也无济于事,终于有空研究了一下,这里与大家一起分享. 正文 一.效果图  二.实现代码 自定义控件 /** * drawableLeft与文本一起居中显示 * *

  • Android开发使用Drawable绘制圆角与圆形图案功能示例

    本文实例讲述了Android开发使用Drawable绘制圆角与圆形图案功能.分享给大家供大家参考,具体如下: 1. 创建类RoundCircleDrawable继承Drawable /** * 圆角矩形 * @Project App_View * @Package com.android.view.drawable * @author chenlin * @version 1.0 * @Date 2016年4月21日 * @Note TODO */ public class RoundCircl

  • Android编程中TextView宽度过大导致Drawable无法居中问题解决方法

    本文实例讲述了Android编程中TextView宽度过大导致Drawable无法居中问题解决方法.分享给大家供大家参考,具体如下: 在做项目的时候,很多时候我们都要用到文字和图片一起显示,一般设置TextView的DrawableLeft.DrawableRight.DrawableTop.DrawableBottom就行了.但是有一种情况是当TextView的熟悉是fill_parent或者使用权重的时候并且设置了起Gravity的ceter的时候,Drawable图片是无法一起居中的,为了

  • android 放大镜ShapeDrawable妙用分享

    首先,ShapeDrawable构造的时候可以指定描画的形状, 其次,可以通过shape.getPaint().setShader();指定Shader,shader可以接受一个图片和matrix 所以问题就顺利的解决了:) 具体实现如下:[java] 复制代码 代码如下: float scale = 1.2f; int cx = 224; int cy = 357; int r = 200; // 指定形状创建一个ShapeDrawable  ShapeDrawable shape=new S

  • 基于android中的各种颜色在drawable.xml中的值详解

    < drawable name="white">#FFFFFF< /drawable>< !--白色 --> < drawable name="black">#000000< /drawable>< !--黑色 --> < drawable name="ivory">#FFFFF0< /drawable>< !--象牙色 --> <

  • Android自定义Drawable实现圆形和圆角

    本文实例为大家分享了自定义Drawable实现圆形和圆角的具体代码,供大家参考,具体内容如下 圆形 package com.customview.widget; import android.graphics.Bitmap; import android.graphics.BitmapShader; import android.graphics.Canvas; import android.graphics.ColorFilter; import android.graphics.Paint;

随机推荐