效果图:

參看下面代码:

public class MainActivity extends Activity {
private ImageView imageView1;
private ImageView imageView2;
Bitmap mBitmap;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.image);
initView(); } private void initView(){
imageView1=(ImageView)findViewById(R.id.imageView1);
imageView2=(ImageView)findViewById(R.id.imageView2);
//读取资源图片
mBitmap=readBitMap();
//对资源图片进行缩放
Bitmap bitmap=zoomBitmap(mBitmap, mBitmap.getWidth()/2, mBitmap.getHeight()/2);
//设置圆角图片
imageView2.setImageBitmap(setRoundedCorner(bitmap,20f));
} /**
* 读取资源图片
* @return
*/
private Bitmap readBitMap(){
BitmapFactory.Options opt=new BitmapFactory.Options();
/*
* 设置让解码器以最佳方式解码
*/
opt.inPreferredConfig=Bitmap.Config.RGB_565;
//以下两个字段须要组合使用
opt.inPurgeable=true;
opt.inInputShareable=true;
/*
* 获取资源图片
*/
InputStream is=this.getResources().openRawResource(R.drawable.mei);
return BitmapFactory.decodeStream(is, null, opt);
} /**
* 缩放图片
* @param bitmap
* @param w
* @param h
* @return
*/
public Bitmap zoomBitmap(Bitmap bitmap, int w, int h) {
int width = bitmap.getWidth();
int height = bitmap.getHeight();
Matrix matrix = new Matrix();
float scaleWidht = ((float) w / width);
float scaleHeight = ((float) h / height);
/*
* 通过Matrix类的postScale方法进行缩放
*/
matrix.postScale(scaleWidht, scaleHeight);
Bitmap newbmp = Bitmap.createBitmap(bitmap, 0, 0, width, height, matrix, true);
return newbmp;
} /**
* 设置图片为圆角
* @param bitmap
* @param roundPx 圆角角度
* @return
*/
public Bitmap setRoundedCorner(Bitmap bitmap, float roundPx) {
Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888);
Canvas canvas = new Canvas(output); final Paint paint = new Paint();
final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
/*
* 椭圆形
*/
final RectF rectF = new RectF(rect);
/*
* 去锯齿
*/
paint.setAntiAlias(true);
canvas.drawARGB(0, 0, 0, 0); /*
* 绘制圆角矩形
*/
canvas.drawRoundRect(rectF, roundPx, roundPx, paint);
/*
* 设置两个图形相交
*/
paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(bitmap, rect, rect, paint); return output;
} }

转载请注明出处:http://blog.csdn.net/hai_qing_xu_kong/article/details/44314043情绪控制_

版权声明:本文博主原创文章,博客,未经同意不得转载。

最新文章

  1. iOS项目开发中的知识点与问题收集整理①(Part 一)
  2. Windws Server 2008 R2 WEB环境配置之MYSQL 5.6.22安装配置
  3. 贪吃蛇的java代码分析(三)
  4. 前端开发流程之(线上)绝对地址(图片+css+js)
  5. Python collections 模块用法举例
  6. js中的排序
  7. [转]Extundelete--数据恢复软件
  8. TCP中 recv和sendf函数
  9. JS验证框架(exValidation)
  10. CSS Sprite 雪碧图制作
  11. MOOC即Massive Open Online Course的缩写
  12. 【关于php】Appserv的安装注意事项
  13. 3C Tic-tac-toe
  14. 亚马逊记AWS(Amazon Web Services)自由EC2应用
  15. idea svn 更新覆盖了本地代码
  16. shell中exec解析
  17. Dreamweaver CS5 CS6 代码格式化、美化插件(可同一时候格式化HTML、JavaScript、CSS )眼下最好用的代码格式化扩展
  18. monkey-----停止正在测试的monkey
  19. java-16习题
  20. [2019BUAA软工助教]答黄杉同学

热门文章

  1. setStyleSheet来设定窗口部件的样式
  2. QT操作Excel(通过QAxObject使用了OLE,前提是本地安装了Excel)
  3. HTML5文件上传还有进度条
  4. codeforces584B Kolya and Tanya
  5. ACM-计算几何之Quoit Design——hdu1007 zoj2107
  6. Android周报
  7. KFC - About KFC - Quality Assurance
  8. The tempfile module
  9. Activity与Service通信的方式有三种:
  10. c++里的类型转化