欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android自定義邊緣凹凸的卡劵效果

 更新時間:2017年05月24日 09:57:38   作者:吳威龍  
這篇文章主要介紹了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>

源碼:

案例Demo

覺得不錯,歡迎點(diǎn)個Star 哈!!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android整理需要翻譯的strings資源詳情

    Android整理需要翻譯的strings資源詳情

    這篇文章主要介紹了Android整理需要翻譯的strings資源,文章主要列出所有res目錄,根據(jù)是否包含values-ru分成兩組解紹,需要的朋友可以參考一下
    2021-10-10
  • Android 加載大圖、多圖和LruCache緩存詳細(xì)介紹

    Android 加載大圖、多圖和LruCache緩存詳細(xì)介紹

    這篇文章主要介紹了Android 加載大圖、多圖和LruCache緩存詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • Android 中WebView 截圖的實(shí)現(xiàn)方式

    Android 中WebView 截圖的實(shí)現(xiàn)方式

    這篇文章主要介紹了Android 中WebView 截圖的實(shí)現(xiàn)方式,WebView 作為一種特殊的控件,自然不能像其他系統(tǒng) View 或者截屏的方式來獲取截圖。本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2017-12-12
  • Android中選項(xiàng)菜單(OptionMenu)的創(chuàng)建方法

    Android中選項(xiàng)菜單(OptionMenu)的創(chuàng)建方法

    這篇文章主要介紹了Android中選項(xiàng)菜單(OptionMenu)的創(chuàng)建方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-01-01
  • 注解處理器(APT)是什么

    注解處理器(APT)是什么

    APT是JDK提供的工具,用于在編譯階段未生成class之前對源碼中的注解進(jìn)行掃描和處理,獲取到注解后可以使用原始方法與JavaPoet生成Java代碼,這篇文章主要介紹了注解處理器(APT)是什么?需要的朋友可以參考
    2023-02-02
  • Android實(shí)現(xiàn)app應(yīng)用多語言切換功能

    Android實(shí)現(xiàn)app應(yīng)用多語言切換功能

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)app應(yīng)用多語言切換功能的相關(guān)資料,類似于微信的語言切換,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Android 開源項(xiàng)目側(cè)邊欄菜單(SlidingMenu)使用詳解

    Android 開源項(xiàng)目側(cè)邊欄菜單(SlidingMenu)使用詳解

    SlidingMenu的是一種比較新的設(shè)置界面或配置界面效果,在主界面左滑或者右滑出現(xiàn)設(shè)置界面,能方便的進(jìn)行各種操作.目前有大量的應(yīng)用都在使用這一效果。如Evernote、Google+、Foursquare等,國內(nèi)的豌豆夾,人人,360手機(jī)助手等都使用SlidingMenu的界面方案。
    2016-05-05
  • Android實(shí)現(xiàn)電影院選座效果

    Android實(shí)現(xiàn)電影院選座效果

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)電影院選座效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Notification與NotificationManager詳細(xì)介紹

    Notification與NotificationManager詳細(xì)介紹

    在Android系統(tǒng)中,發(fā)一個狀態(tài)欄通知還是很方便的。下面我們就來看一下,怎么發(fā)送狀態(tài)欄通知,狀態(tài)欄通知又有哪些參數(shù)可以設(shè)置
    2012-11-11
  • Android中的腦殘?jiān)O(shè)計(jì)總結(jié)

    Android中的腦殘?jiān)O(shè)計(jì)總結(jié)

    本篇文章是對Android中的腦殘?jiān)O(shè)計(jì)進(jìn)行了分析與介紹,需要的朋友參考下
    2013-05-05

最新評論