本文實例講述了Android編程實現(xiàn)帶漸變效果的圓角矩形。分享給大家供大家參考,具體如下:
/** * 帶漸變色效果的圓角矩形 * * @description: * @author ldm * @date 2016-4-26 下午3:47:12 */public class RoundRectsActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(new RoundRectView(this)); } private static class RoundRectView extends View { // Rect類主要用于表示坐標系中的一塊矩形區(qū)域 private Rect mRect; // GradientDrawable支持使用漸變色來繪制圖形,通??梢杂米鰾utton或是背景圖形 private GradientDrawable mDrawable; public RoundRectView(Context context) { super(context); setFocusable(true); initView(); } /** * 初始化數(shù)據(jù) * * @description: * @author ldm * @date 2016-4-26 下午3:56:06 */ private void initView() { mRect = new Rect(0, 0, 240, 240); // orientation指定了漸變的方向,int[]colors指定漸變的顏色由colors數(shù)組指定,數(shù)組中的每個值為一個顏色。 mDrawable = new GradientDrawable( GradientDrawable.Orientation.TL_BR, new int[] { 0xFFFF0000, 0xFF00FF00, 0xFF0000FF }); // 設置Drawable的形狀為矩形 mDrawable.setShape(GradientDrawable.RECTANGLE); // 設置漸變的半徑 mDrawable.setGradientRadius((float) (Math.sqrt(2) * 120)); } /** * 置圖片四個角圓形半徑 * * @description: * @author ldm * @date 2016-4-26 下午4:08:17 */ static void setCornersRadii(GradientDrawable drawable, float r0, float r1, float r2, float r3) { // 設置圖片四個角圓形半徑:1、2兩個參數(shù)表示左上角,3、4表示右上角,5、6表示右下角,7、8表示左下角 drawable.setCornerRadii(new float[] { r0, r0, r1, r1, r2, r2, r3, r3 }); } @Override protected void onDraw(Canvas canvas) { mDrawable.setBounds(mRect); float r = 16; canvas.save(); canvas.translate(10, 10);//畫面平移 // 設置漸變模式:線性漸變 mDrawable.setGradientType(GradientDrawable.LINEAR_GRADIENT); setCornersRadii(mDrawable, r, r, 0, 0); mDrawable.draw(canvas); canvas.restore(); canvas.save(); canvas.translate(10 + mRect.width() + 10, 10); // 設置漸變模式:徑抽漸變 mDrawable.setGradientType(GradientDrawable.RADIAL_GRADIENT); setCornersRadii(mDrawable, 0, 0, r, r); mDrawable.draw(canvas); canvas.restore(); canvas.translate(0, mRect.height() + 10); canvas.save(); canvas.translate(10, 10); // 設置漸變模式:顏色漸變方向非環(huán)形,而是以某點為圓心呈扇形掃過。 mDrawable.setGradientType(GradientDrawable.SWEEP_GRADIENT); setCornersRadii(mDrawable, 0, r, r, 0); mDrawable.draw(canvas); canvas.restore(); canvas.save(); canvas.translate(10 + mRect.width() + 10, 10); mDrawable.setGradientType(GradientDrawable.LINEAR_GRADIENT); setCornersRadii(mDrawable, r, 0, 0, r); mDrawable.draw(canvas); canvas.restore(); canvas.translate(0, mRect.height() + 10); canvas.save(); canvas.translate(10, 10); mDrawable.setGradientType(GradientDrawable.RADIAL_GRADIENT); setCornersRadii(mDrawable, r, 0, r, 0); mDrawable.draw(canvas); canvas.restore(); canvas.save(); canvas.translate(10 + mRect.width() + 10, 10); mDrawable.setGradientType(GradientDrawable.SWEEP_GRADIENT); setCornersRadii(mDrawable, 0, r, 0, r); mDrawable.draw(canvas); canvas.restore(); } }}開源代碼:https://github.com/ldm520/ANDROID_API_DEMOS
或者點擊此處本站下載。
希望本文所述對大家Android程序設計有所幫助。
新聞熱點
疑難解答
圖片精選