Android自定義邊緣凹凸的卡劵效果
所謂前人栽樹,后人乘涼,在此感謝博主的貢獻(xiàn)。
原文:邊緣凹凸的卡劵效果
先上效果圖:
我實(shí)現(xiàn)的效果和原博主實(shí)現(xiàn)的效果是不一樣的,我是左右邊緣凹凸,而博主是上下邊緣凹凸。其實(shí)理解了原理,哪個邊緣實(shí)現(xiàn)這個效果都是可以的。
實(shí)現(xiàn)原理:
直接在view邊緣上畫一個個白色的小圓來實(shí)現(xiàn)這種效果,這個view:CouponView
可以讓它繼承LinearLayout,通過重寫onDraw()方法實(shí)現(xiàn)重新繪制的效果。最后在布局文件中使用該自定義CouponView即可。
畫圓的個數(shù)如何確定:
(這是原博主的經(jīng)驗(yàn),總結(jié)的的確很好)
假如我們上下線的半圓以及半圓與半圓之間的間距是固定的,那么不同尺寸的屏幕肯定會畫出不同數(shù)量的半圓,那么我們只需要根據(jù)控件的寬度來獲取能畫的半圓數(shù)。
大家觀察圖片,很容易發(fā)現(xiàn),圓的數(shù)量總是圓間距數(shù)量-1,也就是,假設(shè)圓的數(shù)量是circleNum,那么圓間距就是circleNum+1。
所以我們可以根據(jù)這個計(jì)算出
circleNum. circleNum = (int) ((w-gap)/(2*radius+gap));
這里gap就是圓間距,radius是圓半徑,w是view的寬。
自定義LinearLayout:CouponView
/** * Created by Veyron on 2017/2/20. * Function:自定義實(shí)現(xiàn)邊緣凹凸卡卷效果 */ public class CouponView extends LinearLayout { private Paint mPaint; //畫筆 private float gap = 8; //圓間距 private float radius = 10; //半徑 private int circleNum; //圓數(shù)量 private float remain; private float width; //視圖寬 public CouponView(Context context) { super(context); } public CouponView(Context context, AttributeSet attrs) { super(context, attrs); mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);//設(shè)置是否使用抗鋸齒功能,會消耗較大資源,繪制圖形速度會變慢。 mPaint.setDither(true);//設(shè)定是否使用圖像抖動處理,會使繪制出來的圖片顏色更加平滑和飽滿,圖像更加清晰 mPaint.setColor(Color.WHITE); mPaint.setStyle(Paint.Style.FILL); } @Override protected void onSizeChanged(int w, int h, int oldw, int oldh) { super.onSizeChanged(w, h, oldw, oldh); width = w; if (remain==0){ //計(jì)算不整除的剩余部分 remain = (int)(h-gap)%(2*radius+gap); } circleNum = (int) ((h-gap)/(2*radius+gap)); //計(jì)算圓的數(shù)量 } public CouponView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } /** * 上面定義了圓的半徑和圓間距,同時初始化了這些值并且獲取了需要畫的圓數(shù)量。 接下來只需要一個一個將圓畫出來就可以了。 * @param canvas */ @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); //循環(huán)在左右兩個邊上畫出凹凸效果 for (int i=0;i<circleNum;i++){ float y = gap+radius+remain/2+((gap+radius*2)*i);//計(jì)算出y軸坐標(biāo) canvas.drawCircle(0,y,radius,mPaint);//在左邊邊畫圓 canvas.drawCircle(width,y,radius,mPaint);//在右邊畫圓 } } }
簡單的根據(jù)circleNum的數(shù)量進(jìn)行了圓的繪制。
這里remain/2是因?yàn)?,可能一些情況,計(jì)算出來的可以畫的數(shù)量不是剛好整除的。這樣就會出現(xiàn)右邊最后一個間距會比其它的間距都要寬。
所以我們在繪制第一個的時候加上了余下的間距的一半,即使是不整除的情況。至少也能保證第一個和最后一個間距寬度一致。
布局文件使用該自定義LinearLayout:CouponView
里面的具體布局就看業(yè)務(wù)需求了
<?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:paddingLeft="16dp" android:paddingRight="16dp" android:paddingTop="20dp" android:paddingBottom="20dp"> <com.veyron.www.couponview.view.CouponView android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#FF5216" android:padding="20dp"> <ImageView android:layout_width="120dp" android:layout_height="120dp" android:src="@drawable/hanber" android:scaleType="centerCrop"/> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:paddingLeft="16dp"> <TextView android:id="@+id/name" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="26dp" android:textColor="#000000" android:text="優(yōu)惠漢堡劵" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="18dp" android:padding="5dp" android:text="編號:007" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="20dp" android:padding="5dp" android:text="優(yōu)惠價:¥18" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="12dp" android:paddingLeft="5dp" android:paddingTop="5dp" android:text="截止日期:2017-06-09" /> </LinearLayout> </com.veyron.www.couponview.view.CouponView> </FrameLayout>
源碼:
覺得不錯,歡迎點(diǎn)個Star 哈!!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android 加載大圖、多圖和LruCache緩存詳細(xì)介紹
這篇文章主要介紹了Android 加載大圖、多圖和LruCache緩存詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-10-10Android 中WebView 截圖的實(shí)現(xiàn)方式
這篇文章主要介紹了Android 中WebView 截圖的實(shí)現(xiàn)方式,WebView 作為一種特殊的控件,自然不能像其他系統(tǒng) View 或者截屏的方式來獲取截圖。本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2017-12-12Android中選項(xiàng)菜單(OptionMenu)的創(chuàng)建方法
這篇文章主要介紹了Android中選項(xiàng)菜單(OptionMenu)的創(chuàng)建方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-01-01Android實(shí)現(xiàn)app應(yīng)用多語言切換功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)app應(yīng)用多語言切換功能的相關(guān)資料,類似于微信的語言切換,感興趣的小伙伴們可以參考一下2016-08-08Android 開源項(xiàng)目側(cè)邊欄菜單(SlidingMenu)使用詳解
SlidingMenu的是一種比較新的設(shè)置界面或配置界面效果,在主界面左滑或者右滑出現(xiàn)設(shè)置界面,能方便的進(jìn)行各種操作.目前有大量的應(yīng)用都在使用這一效果。如Evernote、Google+、Foursquare等,國內(nèi)的豌豆夾,人人,360手機(jī)助手等都使用SlidingMenu的界面方案。2016-05-05Notification與NotificationManager詳細(xì)介紹
在Android系統(tǒng)中,發(fā)一個狀態(tài)欄通知還是很方便的。下面我們就來看一下,怎么發(fā)送狀態(tài)欄通知,狀態(tài)欄通知又有哪些參數(shù)可以設(shè)置2012-11-11Android中的腦殘?jiān)O(shè)計(jì)總結(jié)
本篇文章是對Android中的腦殘?jiān)O(shè)計(jì)進(jìn)行了分析與介紹,需要的朋友參考下2013-05-05