成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

從未如此驚艷!你好,SuperTextView

移動開發(fā) Android
歡迎使用SuperTextView,這篇文檔將會向你展示如何使用這個控件來提高你構建項目的效率。

[[189231]]

【引自CoorChice的博客】簡介

歡迎使用SuperTextView,這篇文檔將會向你展示如何使用這個控件來提高你構建項目的效率。 

 

SuperTextView繼承自TextView,它能夠大量的減少布局的復雜程度,并且使得一些常見的效果變得十分容易實現(xiàn)且高效。同時,它內置了動畫驅動,你只需要合理編寫Adjuster,然后startAnim()就可以看到預期的動畫效果。它僅僅是一個控件,所以你可以不費吹灰之力的在你的項目中集成使用。

特點

  1. 你從此不必再為背景圖編寫和管理大量<shape>文件了。
  2. 重新優(yōu)化的狀態(tài)圖功能使得你能夠精確的控制狀態(tài)圖的大小,以及在SuperTextView中的位置。
  3. 支持設置圓角,并且能夠精確的控制圓角位置。
  4. 能夠輕松的實現(xiàn)控件邊框效果。
  5. 支持文字描邊,這使得空心文字效果成為了可能。
  6. 內置動畫驅動,你只需配合Adjuster合理的使用即可。
  7. Adjuster的出現(xiàn),使得你對控件的繪制過程具有了掌控權,良好的設計使得它能夠***的實現(xiàn)絕大部分你腦海中的效果。

使用指南

支持的屬性

SuperTextView十分方便的支持在xml中直接設置屬性,并且你能夠立即看到效果。就像你平時使用TextView一樣方便。

  1. <SuperTextView 
  2.     android:layout_width="50dp" 
  3.     android:layout_height="50dp" 
  4.  
  5.     //設置圓角。會同時作用于填充和邊框(如果邊框存在的話)。 
  6.     //如果要設置為圓形,只需要把該值設置為寬或長的1/2即可。  
  7.     app:corner="25dp"   
  8.     //設置左上角圓角 
  9.     app:left_top_corner="true" 
  10.     //設置右上角圓角 
  11.     app:right_top_corner="true" 
  12.     //設置左下角圓角 
  13.     app:left_bottom_corner="true" 
  14.     //設置右下角圓角 
  15.     app:right_bottom_corner="true" 
  16.     //設置填充顏色 
  17.     app:solid="@color/red"   
  18.     //設置邊框顏色 
  19.     app:stroke_color="@color/black"   
  20.     //設置邊框的寬度。 
  21.     app:stroke_width="2dp"  
  22.     //放置一個drawable在背景層上。默認居中顯示。 
  23.     //并且默認大小為SuperTextView的一半。 
  24.     app:state_drawable="@drawable/emoji"   
  25.     //設置drawable的顯示模式。可選值如下: 
  26.     // lefttopright、bottom、center(默認值)、 
  27.     //leftTop、rightTop、leftBottom、rightBottom、 
  28.     //fill(充滿整個SuperTextView,此時會使設置drawable的大小失效) 
  29.     app:state_drawable_mode="center"  
  30.     //設置drawable的height 
  31.     app:state_drawable_height="30dp" 
  32.     //設置drawable的width 
  33.     app:state_drawable_width="30dp" 
  34.     //設置drawble相對于基礎位置左邊的距離 
  35.     app:state_drawable_padding_left="10dp" 
  36.     //設置drawble相對于基礎位置上邊的距離 
  37.     app:state_drawable_padding_top="10dp" 
  38.     // boolean類型。是否顯示drawable。 
  39.     //如果你想要設置的drawable顯示出來,必須設置為true。 
  40.     //當不想讓它顯示時,再設置為false即可。 
  41.     app:isShowState="true"  
  42.     //是否開啟文字描邊功能。 
  43.     //注意,啟用這個模式之后通過setTextColor()設置的顏色將會被覆蓋。 
  44.     //你需要通過text_fill_color來設置文字的顏色。 
  45.     app:text_stroke="true"  
  46.     // 文字的描邊顏色。默認為Color.BLACK。 
  47.     app:text_stroke_color="@color/black" 
  48.     // 文字描邊的寬度。 
  49.     app:text_stroke_width="1dp" 
  50.     // 文字填充的顏色。默認為Color.BLACK。 
  51.     app:text_fill_color="@color/blue"  
  52.     // boolean類型。是否啟用Adjuster功能。 
  53.     //具體干什么,需要在Java中為SuperTextView實現(xiàn)一個Adjuster。 
  54.     //當你啟用這個功能而沒有實現(xiàn)自己的Adjuster時, 
  55.     //SuperTextView會啟用默認的Adjuster。它會按照一定的規(guī)則調整文字大小。 
  56.     app:autoAdjust="true"  
  57.     />  

以上這些屬性,均可以在Java中進行動態(tài)的設置。同時也能夠獲得它們的值。例如:

  1. mSuperTextView.setCorner(10); 
  2.  
  3. mSuperTextView.getCorner();  

圓形和邊框

 

 

為了實現(xiàn)上圖效果,通常你需要編寫和管理大量的<shape>文件。現(xiàn)在你只需要在xml或代碼中對SuperTextView直接進行設置即可。

不簡單的圓角

 

不同于簡單的圓角,SuperTextView支持精確的控制圓角的位置。一個、兩個、三個都沒問題。一切由你掌控。

神奇的文字描邊

 

文字描邊從未如此簡單!

高效的狀態(tài)圖

 

 

不同于原生的Drawable,SuperTextView對于Drawable提供了更多精細化的控制操作。你能夠輕松的指定Drawable大小以及位置,只需一個屬性就能搞定。

相信你一定深有感觸,想要實現(xiàn)上圖中的效果,往往需要嵌套多層布局(一般3層吧?)。而SuperTextView只需一個控件,并且十分簡單高效的就能實現(xiàn)。它能夠大量的減少你的App中的布局復雜程度,減少視圖樹的繪制時間。

炸裂的Adjuster

Adjuster被設計用來在SuperTextView的繪制過程中插入一些操作。這具有非常重要的意義。比如,默認實現(xiàn)的DefaultAdjuster能夠動態(tài)的調整文字的大小。當然,你可以用它來實現(xiàn)各種各樣的效果。

想要Adjuster生效,你必須調用SuperTextView.setAutoAdjust(true)來啟用Adjuster功能。當然,你可以所以方便的停止,通過調用SuperTextView.setAutoAdjust(false)。并且,你需要注意調用順序,因為一旦調用了SuperTextView.setAutoAdjust(true),而Adjuster沒有被設置的話,將會啟用默認的DefaultAdjuster(它能夠動態(tài)的調整文字大小),直到你設置了你自己的Adjuster

干預控件的繪制

實現(xiàn)一個Adjuster需要繼承SuperTextView.Adjuster,并且實現(xiàn)adjust(SuperTextView v, Canvas canvas)方法。Adjuster.adjust()會在每次繪制過程中被調用,這意味著你能夠不可思議的從外部干預控件的繪制過程。

  1. public class YourAdjuster extends SuperTextView.Adjuster { 
  2.  
  3.   @Override 
  4.   protected void adjust(SuperTextView v, Canvas canvas) { 
  5.     //do your business。 
  6.   } 
  7.  
  8.  

注意,如果開啟動畫,你必須十分謹慎的編寫adjuster()中的代碼。因為動畫會以60幀/每秒的速度進行繪制。這意味著,這個方法每秒會被調用60次!所以,千萬不要在這個方法中重復的創(chuàng)建對象,會卡爆的!原因是短時間的大量將會引起【內存抖動】,導致GC頻繁發(fā)生。相關知識你可以看看我的這兩篇文章:

響應觸摸事件

如果你重載Adjuster的onTouch(SuperTextView v, MotionEvent event)方法,你將能夠獲得SuperTextView的觸摸事件。這是重要的一點,如果你想持續(xù)的對SuperTextView的觸摸事件進行處理,你必須使onTouch()返回true。否則你只能接收到一個ACTION_DOWN事件,而不是一個事件流。

  1. public class YourAdjuster extends SuperTextView.Adjuster { 
  2.  
  3.   @Override 
  4.   protected void adjust(SuperTextView v, Canvas canvas) { 
  5.     //do your business。 
  6.   } 
  7.  
  8.   @Override 
  9.   public boolean onTouch(SuperTextView v, MotionEvent event) { 
  10.     //you can get the touch event. 
  11.     //If want to get a series of touch event, you must return true here. 
  12.   } 
  13.  
  14.  

如此驚艷的效果

得益于SuperTextView內置的動畫驅動,你能夠結合Adjuster來實現(xiàn)難以置信的動畫效果。一切只需要在你合理的編寫好Adjuster后,調用startAnim()和stopAnim()來啟動/停止動畫。 

 

如你所見,上面的效果就是通過Adjuster來實現(xiàn)的。并且這種拔插式的設計,使得你能夠隨時在同一個SuperTextView上使用新的Adjuster,你所有需要做的事情就是創(chuàng)建一個新的Adjuster,然后調用setAdjuster()。

之前@Alex_Cin希望看到Ripple漣漪效果,所以在RippleAdjuster.java中,我演示了如何使用Adjuster和動畫驅動配合實現(xiàn)上圖的Rippler漣漪效果。【RippleAdjuster.java鏈接:https://github.com/chenBingX/SuperTextView/blob/master/app/src/main/java/com/coorchice/supertextview/SuperTextView/Adjuster/RippleAdjuster.java】

看,你可以使用Adjuster實現(xiàn)自己的Ripple效果。

指定Adjuster的層級

Adjuster貼心的設計了控制作用層級的功能。你可以通過Adjuster.setOpportunity(Opportunity opportunity)來指定Adjuster的繪制層級。

在SuperTextView中,繪制層級被從下到上分為:背景層、Drawable層、文字層3個層級。通過Opportunity來指定你的Adjuster想要插入到那個層級間。

  1. public enum Opportunity { 
  2.       BEFORE_DRAWABLE, //背景層和Drawable層之間 
  3.       BEFORE_TEXT,     //Drawable層和文字層之間 
  4.       AT_LAST          //最上層 
  5.  

三種類型的Opportunity示意圖。

 

默認值是Opportunity.BEFORE_TEXT。即第二張圖的示例。

事實上,只要你愿意,SuperTextView就相當于一張畫布,你可以在上面任意的揮灑你的創(chuàng)意。它能夠讓你專注于創(chuàng)作,而不用去在意編寫那些無用麻煩的代碼。

如何開始使用

  • 如果你喜歡SuperTextView,希望能順手在Github點個star哦!
  • 抽出空余時間寫文章分享需要動力,還請各位看官動動小手點個贊,給我點鼓勵😄
  • 我一直在不定期的創(chuàng)作新的干貨,想要上車只需進到我的【個人主頁】點個關注就好了哦。發(fā)車嘍~

方法一

在你的build.gradle中加入:

  1. allprojects { 
  2.     repositories { 
  3.         ... 
  4.         maven { url 'https://jitpack.io' } 
  5.     } 
  6.  
  7. dependencies { 
  8.     compile 'com.github.chenBingX:SuperTextView:v1.0' 
  9.  

方法二

你可以Clone我的【Github倉庫https://github.com/chenBingX/SuperTextView】,然后在Library包下找到SuperTextView和attrs.xml,復制到你的項目中。

現(xiàn)在,你可以開始使用SuperTextView了。

點擊這里跳轉SuperTextView項目地址。https://github.com/chenBingX/SuperTextView

責任編輯:龐桂玉 來源: CoorChice的博客
相關推薦

2013-06-14 10:36:00

2022-08-12 12:19:13

Cluster檢索集群

2019-05-23 10:55:22

Istio灰度發(fā)布ServiceMesh

2013-10-25 13:35:02

云計算

2009-08-26 20:12:41

BMCBSMITIL

2013-11-28 13:47:37

Android4.4ART模式

2020-06-17 10:42:54

shellshell腳本Linux

2024-02-27 18:06:35

2025-04-03 00:10:11

DockerAI模型

2021-10-18 13:31:28

Web應用交互式

2021-11-09 13:59:47

物聯(lián)網(wǎng)安全設備

2020-03-17 07:41:50

ApacheKafka系統(tǒng)

2020-03-03 15:40:51

開發(fā)技能代碼

2021-02-06 17:49:49

人工智能智能醫(yī)療智慧安防

2022-06-13 06:33:04

瀏覽器瀏覽器插件

2021-09-13 22:26:16

編程語言CPython

2025-01-24 00:44:15

2013-12-13 13:23:29

馬云阿里巴巴

2022-10-21 15:02:36

DeepFake技術

2025-04-18 03:02:00

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 韩日精品在线观看 | 中文字幕精品一区二区三区精品 | 欧美精品一区二区三区四区五区 | 欧美日韩看片 | 亚洲国产91 | 国产精品自产拍 | 五月婷婷激情网 | 欧美三区在线观看 | 99re超碰| 亚洲444eee在线观看 | 免费视频久久久久 | 久久噜噜噜精品国产亚洲综合 | 蜜桃一区| 一级黄色片在线看 | 56pao在线| 亚洲精品久久久一区二区三区 | 日韩精品在线观看一区二区三区 | 美女一区二区在线观看 | 国产不卡视频在线 | 久草免费在线视频 | 91欧美精品成人综合在线观看 | 精品久久久久久18免费网站 | 噜噜噜噜狠狠狠7777视频 | 精品国产一区二区三区久久久蜜月 | 中国黄色在线视频 | 欧洲精品久久久久毛片完整版 | 福利一区二区 | 亚洲综合色自拍一区 | 亚洲资源站 | 国产午夜精品久久久久 | 一区二区三区中文字幕 | 性高湖久久久久久久久3小时 | 91精品国产91久久久久久 | 国产999在线观看 | 日韩在线一区二区三区 | 免费观看黄 | 精品毛片 | а天堂中文最新一区二区三区 | 亚洲成人网在线播放 | 在线91| 天天草视频 |