自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

自定義Android界面切換效果庫的使用

移動開發(fā) Android
作者希望通過本文可以讓廣大讀者了解、熟悉并且掌握自定義Android界面切換效果庫的使用、開發(fā)與思考,希望大家可以學而能用制作自己的自定義Android界面切換效果庫來使用。

界面或者板塊的切換是Android應用中非常常見的一個功能,同時也談談自己對 “Android模塊化編程”的一些想法與對自定義Android界面切換效果庫的使用。希望大家能通過對界面切換效果庫的研究和思考,總結出一套自己的常用功能類庫的開發(fā)思路。界面切換效果庫 Demo項目的源碼(ShiftEffect.zip)可以點擊“此處下載”。將解壓后的項目源碼(ShiftEffect)導入到Eclipse中就可以看到這個Demo項目的代碼結構了(如下圖)。

首先,在模擬器上運行項目代碼??梢钥吹?,界面切換效果庫的Demo為大家提供了比較豐富的選項,如下圖所示;我們可以隨意選擇切換的內(nèi)容(文字、圖片)、切換的漸變時間、切換的停頓時間以及豐富切換的效果(滾動切換、旋轉漸變、大小漸變等)。


下圖所示的就是圖片切換的效果,大家還可以嘗試各種切換的效果,我們可以看到效果還是很流暢的。

界面切換效果庫位于ShiftEffect項目的libs目錄下,即plugs-effect.jar。該效果庫的使用范例都在 com.example.scrolleffect包目錄下的MainActivity.java文件中,使用方法在代碼注釋中都已經(jīng)寫的非常清楚了,如 下參考。

  1. public class MainActivity extends Activity implements OnItemSelectedListener {   
  2.    
  3.     // 展示漸變動效的容器,用于容納漸變效果庫的View控件   
  4.     private LinearLayout container;   
  5.        
  6.     // 漸變效果庫的View控件類   
  7.     private EffectView mView;   
  8.        
  9.     // 文字資源(用于展示漸變切換)   
  10.     private String[] mTexts = { "今日新聞1""今日新聞2""今日新聞3" };   
  11.        
  12.     // 圖片資源(用于展示漸變切換)   
  13.     private int[] mImages = { R.drawable.image_1, R.drawable.image_2, R.drawable.image_3 };   
  14.    
  15.     // 切換內(nèi)容選項   
  16.     private Spinner sp1;   
  17.     private ArrayAdapter<String> aa1;   
  18.     private String[] menu1 = { "內(nèi)容:文字""內(nèi)容:圖片" };   
  19.    
  20.     // 切換漸變時間選項   
  21.     private Spinner sp2;   
  22.     private ArrayAdapter<String> aa2;   
  23.     private String[] menu2 = { "動時:300ms""動時:1000ms""動時:3000ms" };   
  24.    
  25.     // 切換漸變停頓選項   
  26.     private Spinner sp3;   
  27.     private ArrayAdapter<String> aa3;   
  28.     private String[] menu3 = { "停時:3000ms""停時:5000ms""停時:10000ms" };   
  29.    
  30.     // 切換漸變效果選項   
  31.     private Spinner sp4;   
  32.     private ArrayAdapter<String> aa4;   
  33.     private String[] menu4 = { "動效:向上""動效:向下""動效:向左""動效:向右""動效:旋轉",   
  34.             "動效:大小""動效:漸變" };   
  35.    
  36.     @Override   
  37.     public void onCreate(Bundle savedInstanceState) {   
  38.         super.onCreate(savedInstanceState);   
  39.         setContentView(R.layout.activity_main);   
  40.    
  41.         // 初始化展示動效的容器   
  42.         container = (LinearLayout) this.findViewById(R.id.container);   
  43.    
  44.         // 初始化各個選項的內(nèi)容   
  45.         sp1 = (Spinner) findViewById(R.id.spinner1);   
  46.         aa1 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu1);   
  47.         aa1.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);   
  48.         sp1.setAdapter(aa1);   
  49.         sp1.setOnItemSelectedListener(this);   
  50.    
  51.         sp2 = (Spinner) findViewById(R.id.spinner2);   
  52.         aa2 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu2);   
  53.         aa2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);   
  54.         sp2.setAdapter(aa2);   
  55.         sp2.setOnItemSelectedListener(this);   
  56.    
  57.         sp3 = (Spinner) findViewById(R.id.spinner3);   
  58.         aa3 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu3);   
  59.         aa3.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);   
  60.         sp3.setAdapter(aa3);   
  61.         sp3.setOnItemSelectedListener(this);   
  62.    
  63.         sp4 = (Spinner) findViewById(R.id.spinner4);   
  64.         aa4 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu4);   
  65.         aa4.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);   
  66.         sp4.setAdapter(aa4);   
  67.         sp4.setOnItemSelectedListener(this);   
  68.     }   
  69.    
  70.     @Override   
  71.     public boolean onCreateOptionsMenu(Menu menu) {   
  72.         getMenuInflater().inflate(R.menu.activity_main, menu);   
  73.         return true;   
  74.     }   
  75.    
  76.     @Override   
  77.     public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {   
  78.         // 選擇切換內(nèi)容選項(可選擇滾動文字或者圖片)   
  79.         if (parent.getAdapter() == aa1) {   
  80.             container.removeAllViews();   
  81.             switch (position) {   
  82.                 case 0:   
  83.                     // 初始化文字切換View對象   
  84.                     mView = EffectUtil.fillTexts(this, EffectView.ANI_UP, 30, mTexts);   
  85.                     container.addView(mView);   
  86.                     mView.start();   
  87.                     break;   
  88.                 default:   
  89.                     mView = EffectUtil.fillImages(this, EffectView.ANI_UP, mImages);   
  90.                     container.addView(mView);   
  91.                     mView.start();   
  92.                     break;   
  93.             }   
  94.         }   
  95.         // 選擇切換漸變時間選項   
  96.         if (parent.getAdapter() == aa2) {   
  97.             switch (position) {   
  98.                 case 0:   
  99.                     mView.setDuration(300);   
  100.                     break;   
  101.                 case 1:   
  102.                     mView.setDuration(1000);   
  103.                     break;   
  104.                 default:   
  105.                     mView.setDuration(3000);   
  106.                     break;   
  107.             }   
  108.         }   
  109.         // 選擇切換漸變間隔選項   
  110.         if (parent.getAdapter() == aa3) {   
  111.             switch (position) {   
  112.                 case 0:   
  113.                     mView.setInterval(3000);   
  114.                     break;   
  115.                 case 1:   
  116.                     mView.setInterval(5000);   
  117.                     break;   
  118.                 default:   
  119.                     mView.setInterval(10000);   
  120.                     break;   
  121.             }   
  122.         }   
  123.         // 選擇切換漸變效果選項   
  124.         if (parent.getAdapter() == aa4) {   
  125.             switch (position) {   
  126.                 case 0:   
  127.                     mView.setAnimation(EffectView.ANI_UP); // 往上滾動   
  128.                     break;   
  129.                 case 1:   
  130.                     mView.setAnimation(EffectView.ANI_DOWN); // 往下滾動   
  131.                     break;   
  132.                 case 2:   
  133.                     mView.setAnimation(EffectView.ANI_LEFT); // 往左滾動   
  134.                     break;   
  135.                 case 3:   
  136.                     mView.setAnimation(EffectView.ANI_RIGHT); // 往右滾動   
  137.                     break;   
  138.                 case 4:   
  139.                     mView.setAnimation(EffectView.ANI_ROTATE); // 旋轉漸變   
  140.                     break;   
  141.                 case 5:   
  142.                     mView.setAnimation(EffectView.ANI_SCALE); // 大小漸變   
  143.                     break;   
  144.                 default:   
  145.                     mView.setAnimation(EffectView.ANI_FADE); // 消失漸變   
  146.                     break;   
  147.             }   
  148.         }   
  149.     }   
  150.     @Overridek   
  151.     public void onNothingSelected(AdapterView<?> parent) {   
  152.         // TODO Auto-generated method stub   
  153.     }   

我們可以看到,該界面切換效果庫的使用方法是非常方便和靈活的。使用EffectUtil的fillTexts(或fillImages)方法添加需要進 行切換的文字(或圖片)之后,再調(diào)用其EffectView對象的start方法就可以打開切換效果了。此外,我們還可以使用setDuration方法 設置切換過程的漸變時間、使用setInterval設置切換過程的漸變間隔、使用setAnimation方法設置切換過程的漸變效果;這些方法的使用 在使用范例中都能查到。
接下來,讓我們來思考一個問題:如果拋開以上的Android界面切換效果庫,使用原生API來實現(xiàn)一個類似的效果,我們該如何來做?你 是否會感覺非常繁瑣?確實如此。其實,這也就是為何我們提倡“模塊化編程”的原因!實際上業(yè)內(nèi)已經(jīng)有很多的開發(fā)團隊早已意識到了這一點,也就是所謂的 “Android模塊化編程”。那么,何謂“Android模塊化編程”呢?簡單來說,就是把常見的、可復用的功能提取出來,單獨制作成好用的類庫,使之 在開發(fā)產(chǎn)品的時候可被復用。
實際上,任何一門技術發(fā)展到一定階段,必然會出現(xiàn)模塊化的方法和思想,對于Android編程來說也是如此。 模塊化編程可以幫助知識積累、技術沉淀,幫助我們制作出更加豐富和復雜的應用。因此,我建議大家在學習Android變成的過程中,多使用模塊化的思想來 實現(xiàn),比如上述的“自定義Android界面切換效果庫”,就是個很好的例子。我們可以來看看以上界面切換效果庫源碼結構,如下圖。

從源碼的結構中,我們可以看出,效果庫的代碼層次十分清晰。EffectUtil是總接口類,里面包含了fillTexts和fillImages兩個方 法,用于初始化界面切換的內(nèi)容(文字or圖片);相關的視圖類都在com.app.plugs.effect.view包下,這些視圖都是用于容納切換內(nèi) 容的容器;而動畫效果類則位于com.app.plugs.effect.anim包下,這里包含了所有動畫效果的邏輯。具體源碼大家可以直接反編譯 Demo項目的源碼plugs-effect.jar來看,此包是未加密過的。
當然,在模塊化編程實現(xiàn)的過程中,必定會遇到很多需要解決 的問題。比如下面就是個最常見的問題,模塊相關的資源文件如何打包?實際上在模塊化編程的過程中,我們不提倡對資源進行打包。大家更應該使用 Android原生的控件API來實現(xiàn)模塊的UI,而不是XML模板(使用XML模板有可能降低Android應用的運行效率,請參考《Android和PHP開發(fā)***實踐》第10章.客戶端優(yōu)化)來學習自定義Android界面切換效果庫的使用;而圖片資源這些則可以通過模塊的API進行設置;總之,原則是模塊化的類庫中應該只包含代碼。當然,大家在實施過程中遇到任何問題,都歡迎到這里來留言和討論。

責任編輯:閆佳明 來源: csdn
相關推薦

2010-02-07 14:02:16

Android 界面

2013-01-06 10:43:54

Android開發(fā)View特效

2016-11-16 21:55:55

源碼分析自定義view androi

2016-12-26 15:25:59

Android自定義View

2017-10-25 14:07:54

APPiOSxcode

2010-10-25 16:05:07

oracle自定義函數(shù)

2024-05-30 08:23:37

ViewPager滑動效果接口

2017-04-21 14:27:21

Android控件QQ未讀消息

2013-04-01 14:35:10

Android開發(fā)Android自定義x

2014-12-10 10:37:45

Android自定義布局

2021-09-14 15:13:18

鴻蒙HarmonyOS應用

2019-12-25 11:47:27

LinuxFVWM

2022-01-14 09:17:13

PythonAPISIX插件

2009-06-23 11:35:44

JSF的Naviati

2017-05-18 12:36:16

android萬能適配器列表視圖

2016-04-12 10:07:55

AndroidViewList

2017-05-19 10:03:31

AndroidBaseAdapter實踐

2011-08-25 11:44:21

LUA腳本魔獸世界

2015-06-10 10:54:24

自定義路PHP

2021-12-24 15:46:23

鴻蒙HarmonyOS應用
點贊
收藏

51CTO技術棧公眾號