Android編程實現(xiàn)帶漸變效果的圓角矩形示例
本文實例講述了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支持使用漸變色來繪制圖形,通常可以用作Button或是背景圖形
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 });
// 設(shè)置Drawable的形狀為矩形
mDrawable.setShape(GradientDrawable.RECTANGLE);
// 設(shè)置漸變的半徑
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) {
// 設(shè)置圖片四個角圓形半徑: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);//畫面平移
// 設(shè)置漸變模式:線性漸變
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);
// 設(shè)置漸變模式:徑抽漸變
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);
// 設(shè)置漸變模式:顏色漸變方向非環(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
或者點擊此處本站下載。
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android布局layout技巧總結(jié)》、《Android開發(fā)入門與進階教程》、《Android調(diào)試技巧與常見問題解決方法匯總》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計有所幫助。
- Android實現(xiàn)圓角矩形和圓形ImageView的方式
- android實現(xiàn)圓角矩形背景的方法
- Android自定義ViewGroup實現(xiàn)帶箭頭的圓角矩形菜單
- Android編程之canvas繪制各種圖形(點,直線,弧,圓,橢圓,文字,矩形,多邊形,曲線,圓角矩形)
- Android實現(xiàn)空心圓角矩形按鈕的實例代碼
- Android開發(fā)使用自定義View將圓角矩形繪制在Canvas上的方法
- Android開發(fā)基于Drawable實現(xiàn)圓角矩形的方法
- Android開發(fā)之圓角矩形創(chuàng)建工具RoundRect類定義與用法分析
- Android實現(xiàn)自定義ImageView的圓角矩形圖片效果
相關(guān)文章
Android自定義View實現(xiàn)價格區(qū)間選擇控件
這篇文章主要為大家詳細介紹了Android如何利用自定義View實現(xiàn)價格區(qū)間選擇控件,文中的示例代碼講解詳細,感興趣的小伙伴可以嘗試一下2022-11-11
Android使用DocumentFile讀寫外置存儲的問題
大家好,本篇文章主要講的是Android使用DocumentFile讀寫外置存儲的問題,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2021-12-12
Android多線程+單線程+斷點續(xù)傳+進度條顯示下載功能
這篇文章主要介紹了Android多線程+單線程+斷點續(xù)傳+進度條顯示下載功能,需要的朋友可以參考下2017-06-06
Android開發(fā)實現(xiàn)自定義水平滾動的容器示例
這篇文章主要介紹了Android開發(fā)實現(xiàn)自定義水平滾動的容器,涉及Android滾動容器的事件響應(yīng)、屬性運算與修改相關(guān)操作技巧,需要的朋友可以參考下2017-10-10

