[转]android 自定义圆形imageview控件

android布局

首先,定义定义圆形Imageview类:

[java] view plaincopy

  1. import android.content.Context;
  2. import android.graphics.Bitmap;
  3. import android.graphics.Bitmap.Config;
  4. import android.graphics.Canvas;
  5. import android.graphics.Color;
  6. import android.graphics.Paint;
  7. import android.graphics.PorterDuff.Mode;
  8. import android.graphics.PorterDuffXfermode;
  9. import android.graphics.Rect;
  10. import android.graphics.drawable.BitmapDrawable;
  11. import android.graphics.drawable.Drawable;
  12. import android.util.AttributeSet;
  13. import android.widget.ImageView;
  14. public class RoundImageView extends ImageView {
  15. public RoundImageView(Context context) {
  16. super(context);
  17. // TODO Auto-generated constructor stub
  18. }
  19. public RoundImageView(Context context, AttributeSet attrs) {
  20. super(context, attrs);
  21. }
  22. public RoundImageView(Context context, AttributeSet attrs, int defStyle) {
  23. super(context, attrs, defStyle);
  24. }
  25. @Override
  26. protected void onDraw(Canvas canvas) {
  27. Drawable drawable = getDrawable();
  28. if (drawable == null) {
  29. return;
  30. }
  31. if (getWidth() == 0 || getHeight() == 0) {
  32. return;
  33. }
  34. Bitmap b =  ((BitmapDrawable)drawable).getBitmap();
  35. if(null == b)
  36. {
  37. return;
  38. }
  39. Bitmap bitmap = b.copy(Bitmap.Config.ARGB_8888, true);
  40. int w = getWidth(), h = getHeight();
  41. Bitmap roundBitmap =  getCroppedBitmap(bitmap, w);
  42. canvas.drawBitmap(roundBitmap, 0,0, null);
  43. }
  44. public static Bitmap getCroppedBitmap(Bitmap bmp, int radius) {
  45. Bitmap sbmp;
  46. if(bmp.getWidth() != radius || bmp.getHeight() != radius)
  47. sbmp = Bitmap.createScaledBitmap(bmp, radius, radius, false);
  48. else
  49. sbmp = bmp;
  50. Bitmap output = Bitmap.createBitmap(sbmp.getWidth(),
  51. sbmp.getHeight(), Config.ARGB_8888);
  52. Canvas canvas = new Canvas(output);
  53. final int color = 0xffa19774;
  54. final Paint paint = new Paint();
  55. final Rect rect = new Rect(0, 0, sbmp.getWidth(), sbmp.getHeight());
  56. paint.setAntiAlias(true);
  57. paint.setFilterBitmap(true);
  58. paint.setDither(true);
  59. canvas.drawARGB(0, 0, 0, 0);
  60. paint.setColor(Color.parseColor("#BAB399"));
  61. canvas.drawCircle(sbmp.getWidth() / 2+0.7f, sbmp.getHeight() / 2+0.7f,
  62. sbmp.getWidth() / 2+0.1f, paint);
  63. paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
  64. canvas.drawBitmap(sbmp, rect, rect, paint);
  65. return output;
  66. }
  67. }

然后在别的布局文件中使用该控件即可,如:

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:background="@drawable/side_right"
  6. android:gravity="center"
  7. android:orientation="vertical" >
  8. <LinearLayout
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:gravity="center"
  12. android:layout_marginTop="35dip"
  13. android:orientation="vertical" >
  14. <<span style="color:#ff0000;">com.founder.reader.view.RoundImageView</span>
  15. android:id="@+id/right_login_head"
  16. android:layout_width="60dip"
  17. android:layout_height="60dip"
  18. android:scaleType="centerInside"
  19. android:src="@drawable/user" />
时间: 2024-08-27 05:38:39

[转]android 自定义圆形imageview控件的相关文章

android 自定义圆形imageview控件

首先,定义定义圆形Imageview类: import android.content.Context; import android.graphics.Bitmap; import android.graphics.Bitmap.Config; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.PorterDu

(转载)Android自定义标签列表控件LabelsView解析

Android自定义标签列表控件LabelsView解析 作者 donkingliang 关注 2017.03.15 20:59* 字数 759 阅读 406评论 0喜欢 3 无论是在移动端的App,还是在前端的网页,我们经常会看到下面这种标签的列表效果: 标签列表 标签从左到右摆放,一行显示不下时自动换行.这样的效果用Android源生的控件很不好实现,所以往往需要我们自己去自定义控件.我在开发中就遇到过几次要实现这样的标签列表效果,所以就自己写了个控件,放到我的GitHub,方便以后使用.有

Android——自定义镂空遮盖控件

刚学完ViewDragHelper和PorterDuffXferMode的我,突然想做一个这样效果的自定义控件:点击ListView的列表项,通过ViewDragHelper用动画方式上下各弹出一个控件遮盖住ListView,这两个控件在遮盖listView的过程中有一部分是镂空的.先上效果图: 首先是进行页面的布局,让自定义控件PlayLayout继承自Franlayout,在最底层放的就是listView所在的子FramLayout(Id:midContent),然后依次在上面加上下两个看起

android自定义刷新类控件

android虽然定义了种类非常丰富的控件,但是有的时候这些自定义的控件还是不能满足我的要求,为了能够适配更多的需求,我们需要在原有的基础上进行自定义控件. 今天我向大家介绍的就是android中最常见的刷新类控件.因为我们最近正在参加一个项目,在项目组长的带领下,我学到了很多的东西,这对我的android技术的提升非常大,定义一个自定义控件可能不是很难,但是如何让这个自定义控件更加有效.更加快速地运行. 首先我们需要建立一个自定义控件类: package com.example.ui.widg

如何打造Android自定义的下拉列表框控件

一.概述 Android中的有个原生的下拉列表控件Spinner,但是这个控件有时候不符合我们自己的要求, 比如有时候我们需要类似windows 或者web网页中常见的那种下拉列表控件,类似下图这样的: 这个时候只有自己动手写一个了.其实实现起来不算很难, 本文实现的方案是采用TextView +ImageView+PopupWindow的组合方案. 先来看看我们的自己写的控件效果图吧:(源码在文章下面最后给出哈!) 二.自定义下拉列表框控件的实现 1. 自定义控件用到的布局文件和资源: 结果框

Android自定义标签列表控件LabelsView解析

版权声明:本文为博主原创文章,未经博主允许不得转载. 无论是在移动端的App,还是在前端的网页,我们经常会看到下面这种标签的列表效果:   标签从左到右摆放,一行显示不下时自动换行.这样的效果用Android源生的控件很不好实现,所以往往需要我们自己去自定义控件.我在开发中就遇到过几次要实现这样的标签列表效果,所以就自己写了个控件,放到我的GitHub,方便以后使用.有兴趣的同学也欢迎访问我的GitHub.查看源码实现和使用该控件.下面我将为大家介绍该控件的具体实现和使用. 要实现这样一个标签列

安卓自定义圆形图片控件的使用(hdodenhof/CircleImageView)

控件的来源:https://github.com/hdodenhof/CircleImageView 感兴趣的可以去看看,我只说一下怎么使用: 效果图: 在自己的项目中使用的话,需要写一个类class CircleImageView extends ImageView : 具体如下,只是使用的话,复制过来就好,注意改一下包名: 1 package de.hdodenhof.circleimageview; 2 3 import android.content.Context; 4 import

Android自定义星星评分控件,高效

下面为控件的实现历程: 此控件高效,直接使用ondraw绘制,先亮照: 由于Android自身的星星评分控件样式可以改,但是他的大小不好调整的缺点,只能用small normal这样的style调整,自定义不强,因此击发了我自定义星星控件的欲望. 星星评分控件的设计,大体规划为: 需要两张图片,一颗亮星星,一颗空星星:(当然图片不一定是星星,其他图片也可以,现在实验就用星星就好了)星星数量,间距可以自定义,星星的最小步进为0.1,在用户使用的时候与Android自带的方法一样. 星星控件大体分为

Android 自定义SwitchButton开关控件

SwitchButton开关控件早已经非常流行.有各种各样的样式,SwitchButton开关控件一般用于app软件设置那里,控制缓存.声音.提示.下载等等.是具有很好的UI体验以及用户的习惯性.那么再下面介绍一个SwitchButton开关控件.并附上源码. 源码下载:点击 一.看实现的效果图 二.自定义SwitchButton 这是一个继承CheckBox的SwitchButton类.来实现做这些动画效果的,首先准备好这些图片,然后canvas绘制控件 的边框.背景.以及按钮.绘制时候加上相