本文实例讲述了Android编程实现带渐变效果的圆角矩形。分享给大家供大家参考,具体如下:
/* * *带渐变色效果的圆角矩形 * * @description: * @author ldm * @date 2016-4-26下午3:47:12 */公开课RoundRectsActivity延伸活动{ @Override 保护无效onCreate(包savedInstanceState) { super.onCreate (savedInstanceState); setContentView(新RoundRectView ()); } 私有静态类RoundRectView扩展视图{//矩形类主要用于表示坐标系中的一块矩形区域 私人矩形mRect;//GradientDrawable支持使用渐变色来绘制图形,通常可以用作按钮或是背景图形 私人GradientDrawable mDrawable; 公共RoundRectView(上下文语境){ 超级(上下文); setFocusable(真正的); initView (); }/* * *初始化数据 * * @description: * @author ldm * @date 2016-4-26下午3:56:06 */私人空间initView () { mRect=new矩形(0,0,240,240);//定位指定了渐变的方向,int[]颜色指定渐变的颜色由颜色数组指定,数组中的每个值为一个颜色。 mDrawable=new GradientDrawable ( GradientDrawable.Orientation。TL_BR,新的int [] {0 xffff0000, 0 xff00ff00 0 xff0000ff});//设置可拉的的形状为矩形 mDrawable.setShape (GradientDrawable.RECTANGLE);//设置渐变的半径 mDrawable.setGradientRadius((浮动)(Math.sqrt (2) * 120)); }/* * *置图片四个角圆形半径 * * @description: * @author ldm * @date 2016-4-26下午4:08:17 */静态孔隙setCornersRadii (GradientDrawable可拉的、浮点数r0、 浮动r1, r2浮动,浮动r3) {//设置图片四个角圆形半径:1、2两个参数表示左上角,3、4表示右上角,5、6表示右下角,7、8表示左下角 可拉的。setCornerRadii(新浮动[]{r0、r0 r1, r1、r2 r2, r3, r3}); } @Override 保护无效onDraw(帆布画布){ mDrawable.setBounds (mRect); 浮动r=16; canvas.save (); 画布。翻译(10,10);//画面平移//设置渐变模式:线性渐变 mDrawable.setGradientType (GradientDrawable.LINEAR_GRADIENT); setCornersRadii (mDrawable, r, r, 0, 0); mDrawable.draw(画布); canvas.restore (); canvas.save (); 画布。翻译(10 + mRect.width () + 10, 10);//设置渐变模式:径抽渐变 mDrawable.setGradientType (GradientDrawable.RADIAL_GRADIENT); setCornersRadii (mDrawable, 0, 0, r, r); mDrawable.draw(画布); canvas.restore (); 画布。翻译(0,mRect.height () + 10); canvas.save (); 画布。翻译(10,10);//设置渐变模式:颜色渐变方向非环形,而是以某点为圆心呈扇形扫过。 mDrawable.setGradientType (GradientDrawable.SWEEP_GRADIENT); setCornersRadii (mDrawable 0 r, r, 0); mDrawable.draw(画布); canvas.restore (); canvas.save (); 画布。翻译(10 + mRect.width () + 10, 10); mDrawable.setGradientType (GradientDrawable.LINEAR_GRADIENT); setCornersRadii (mDrawable, r, 0, 0, r); mDrawable.draw(画布); canvas.restore (); 画布。翻译(0,mRect.height () + 10); canvas.save (); 画布。翻译(10,10); mDrawable.setGradientType (GradientDrawable.RADIAL_GRADIENT); setCornersRadii (mDrawable, r, 0, r, 0); mDrawable.draw(画布); canvas.restore (); canvas.save (); 画布。翻译(10 + mRect.width () + 10, 10); mDrawable.setGradientType (GradientDrawable.SWEEP_GRADIENT); setCornersRadii (mDrawable 0 r, 0, r); mDrawable.draw(画布); canvas.restore (); } } } >之前开源代码:https://github.com/ldm520/ANDROID_API_DEMOS
或者点击此处。
更多关于Android相关内容感兴趣的读者可查看本站专题:《Android布局布局技巧总结》,《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android基本组件用法总结》,《Android视图视图技巧总结》及《安卓控件用法总结》
希望本文所述对大家Android程序设计有所帮助。
Android编程实现带渐变效果的圆角矩形示例