服务器之家

服务器之家 > 正文

Android编程绘制圆形图片的方法

时间:2021-05-31 16:18     来源/作者:xurong

本文实例讲述了android编程绘制圆形图片的方法。分享给大家供大家参考,具体如下:

效果图如下:

Android编程绘制圆形图片的方法

第一步:新建roundview自定义控件继承view

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package com.rong.activity;
import com.rong.test.r;
import android.content.context;
import android.graphics.bitmap;
import android.graphics.bitmap.config;
import android.graphics.bitmapfactory;
import android.graphics.canvas;
import android.graphics.color;
import android.graphics.paint;
import android.graphics.porterduff;
import android.graphics.porterduffxfermode;
import android.util.attributeset;
import android.widget.imageview;
/**
 * 利用xfermode制作一个圆形图片
 *
 * @author 徐荣
 *
 */
public class roundview extends imageview {
  /**
   * 画笔
   */
  private paint mpaint;
  /**
   * 原型图
   */
  private bitmap src;
  /**
   * 遮罩层
   */
  private bitmap mask;
  public roundview(context context, attributeset attrs) {
    super(context, attrs);
    // 初始化画笔
    mpaint = new paint();
    mpaint.setantialias(true);
    // 拿到原型图
    src = bitmapfactory.decoderesource(getresources(), r.drawable.ml);
  }
  @override
  protected void onsizechanged(int w, int h, int oldw, int oldh) {
    super.onsizechanged(w, h, oldw, oldh);
    // 图片的遮罩,为什么要在这里面初始化遮罩层呢?因为在这个方法里width()和height()才被初始化了
    mask = bitmap.createbitmap(getmeasuredwidth(), getmeasuredheight(), config.argb_4444);
  }
  @override
  protected void ondraw(canvas canvas) {
    super.ondraw(canvas);
    // 设置画布的颜色为透明
    canvas.drawcolor(color.transparent);
    // 划出你要显示的圆
    canvas cc = new canvas(mask);
    cc.drawcircle(getmeasuredwidth() / 2, getmeasuredheight() / 2, getmeasuredheight() / 2, mpaint);
    // 这个方法相当于ps新建图层,下面你要做的事就在这个图层上操作
    canvas.savelayer(0, 0, getmeasuredwidth(), getmeasuredheight(), null, canvas.all_save_flag);
    // 先绘制遮罩层
    canvas.drawbitmap(mask, 0, 0, mpaint);
    // 设置混合模式
    mpaint.setxfermode(new porterduffxfermode(porterduff.mode.src_in));
    // 再绘制src源图
    canvas.drawbitmap(src, 0, 0, mpaint);
    // 还原混合模式
    mpaint.setxfermode(null);
    // 还原画布,相当于ps的合并图层
    canvas.restore();
  }
}

第二步 新建布局文件activity_main.xml

?
1
2
3
4
5
6
7
8
9
10
11
<?xml version="1.0" encoding="utf-8"?>
<relativelayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:background="#ffffff"
  android:orientation="vertical" >
  <com.rong.activity.roundview
    android:layout_width="160dp"
    android:layout_height="160dp"
    android:layout_centerinparent="true" />
</relativelayout>

运行!

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

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部