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

Android幻燈片效果實(shí)現(xiàn)-Gallery

移動開發(fā) Android
我覺得在開發(fā)中,對一些控件的復(fù)用肯定是很多的,在首頁(非載入頁)一般都會有一個(gè)幻燈片效果,既可以放廣告也可以放推薦,如果圖片設(shè)計(jì)的好看,效果一般都會不錯(cuò)。

最近下載幾款手機(jī)應(yīng)用研究了下,發(fā)了有些自定義控件驚人的相似,所以我覺得在以后的開發(fā)中,對一些控件的復(fù)用肯定是很多的,在首頁(非載入頁)一般都會有一個(gè)幻燈片效果,既可以放廣告也可以放推薦,如果圖片設(shè)計(jì)的好看,效果一般都會不錯(cuò),既然用到了Gallery,也附帶把相框效果的例子寫一寫(淘寶詳情界面的商品圖片滑動展示)

一、效果圖展示

(1)幻燈片效果展示:

(2)商品圖片滑動展示

查看大圖:

二、部分代碼說明

(1)幻燈片效果的實(shí)現(xiàn):

自定義Gallery:DetailGallery.java

可視界面:ImgSwitchActivity.java

適配類:GalleryIndexAdapter.java

1)自定義Gallery主要重寫onFling通過按下和松手的位置不同比較是向右移動還是向左移動,部分代碼如下:

  1. private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2) { 
  2.         return e2.getX() > e1.getX(); 
  3.     } 
  4.     @Override 
  5.     public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, 
  6.             float velocityY) { 
  7.         int kEvent; 
  8.         if (isScrollingLeft(e1, e2)) { 
  9.             kEvent = KeyEvent.KEYCODE_DPAD_LEFT; 
  10.         } else { 
  11.             kEvent = KeyEvent.KEYCODE_DPAD_RIGHT; 
  12.         } 
  13.         onKeyDown(kEvent, null); 
  14.         return true
  15.     } 

2)在適配類 GalleryIndexAdapter主要完成幻燈片的循環(huán)播放,在getCount里面返回值返回Integer.MAX_VALUE,然后在getView里面根據(jù)position與傳進(jìn)來初始圖片個(gè)數(shù)進(jìn)行余數(shù)計(jì)算得到每次循環(huán)到哪張圖片。部分代碼如下:

  1. @Override 
  2.         public int getCount() { 
  3.             // TODO Auto-generated method stub 
  4.             return Integer.MAX_VALUE; 
  5.         } 
  6.         …… 
  7.         @Override 
  8.         public View getView(int position, View convertView, ViewGroup arg2) { 
  9.             // TODO Auto-generated method stub 
  10.             ImageView imageView = new ImageView(context); 
  11. imageView.setBackgroundResource(imagList.get(position%imagList.size())); 
  12.             imageView.setScaleType(ScaleType.FIT_XY); 
  13.             imageView.setLayoutParams(new Gallery.LayoutParams(Gallery.LayoutParams.FILL_PARENT 
  14.                     , Gallery.LayoutParams.WRAP_CONTENT)); 
  15.             return imageView; 
  16.         }   

3)在可視界面里面實(shí)現(xiàn)邏輯控制,通過定時(shí)器定時(shí)刷新幻燈片,定時(shí)器通過定時(shí)發(fā)送消息,消息接受處理機(jī)制接收到消息之后,就模擬滑動事件,調(diào) 用Gallery的onFling方法實(shí)現(xiàn)圖片自動切換效果。選擇按鈕的顯示效果(RadioButton)需要在Gallery的 setOnItemSelectedListener進(jìn)行處理。

  1. //定時(shí)器和事件處理5秒刷新一次幻燈片 
  2.     /** 展示圖控制器,實(shí)現(xiàn)展示圖切換 */ 
  3.         final Handler handler_gallery = new Handler() { 
  4.             public void handleMessage(Message msg) { 
  5.                 /* 自定義屏幕按下的動作 */ 
  6.                 MotionEvent e1 = MotionEvent.obtain(SystemClock.uptimeMillis(), 
  7.                         SystemClock.uptimeMillis(), MotionEvent.ACTION_UP, 
  8.                         89.333336f, 265.33334f, 0); 
  9.                 /* 自定義屏幕放開的動作 */ 
  10.                 MotionEvent e2 = MotionEvent.obtain(SystemClock.uptimeMillis(), 
  11.                         SystemClock.uptimeMillis(), MotionEvent.ACTION_DOWN, 
  12.                         300.0f, 238.00003f, 0); 
  13.                 myGallery.onFling(e2, e1, -8000); 
  14.                 /* 給gallery添加按下和放開的動作,實(shí)現(xiàn)自動滑動 */ 
  15.                 super.handleMessage(msg); 
  16.             } 
  17.         }; 
  18.         protected void onResume() { 
  19.             autogallery(); 
  20.             super.onResume(); 
  21.         }; 
  22.         private void autogallery() { 
  23.             /* 設(shè)置定時(shí)器,每5秒自動切換展示圖 */ 
  24.             Timer time = new Timer(); 
  25.             TimerTask task = new TimerTask() { 
  26.                 @Override 
  27.                 public void run() { 
  28.                     Message m = new Message(); 
  29.                     handler_gallery.sendMessage(m); 
  30.                 } 
  31.             }; 
  32.             time.schedule(task, 80005000); 
  33.         } 
  34.     //指示按鈕和gallery初始化過程以及事件監(jiān)聽添加過程 
  35.     //初始化 
  36.         void init(){ 
  37.             myGallery = (DetailGallery)findViewById(R.id.myGallery); 
  38.             gallery_points = (RadioGroup) this.findViewById(R.id.galleryRaidoGroup); 
  39.             ArrayList<Integer> list = new ArrayList<Integer>(); 
  40.             list.add(R.drawable.banner1); 
  41.             list.add(R.drawable.banner2); 
  42.             list.add(R.drawable.banner3); 
  43.             list.add(R.drawable.banner4); 
  44.             GalleryIndexAdapter adapter = new GalleryIndexAdapter(list, context); 
  45.             myGallery.setAdapter(adapter); 
  46.             //設(shè)置小按鈕 
  47.             gallery_point = new RadioButton[list.size()]; 
  48.             for (int i = 0; i < gallery_point.length; i++) { 
  49.                 layout = (LinearLayout) inflater.inflate(R.layout.gallery_icon, null); 
  50.                 gallery_point[i] = (RadioButton) layout.findViewById(R.id.gallery_radiobutton); 
  51.                 gallery_point[i].setId(i);/* 設(shè)置指示圖按鈕ID */ 
  52.                 int wh = Tool.dp2px(context, 10); 
  53.                 RadioGroup.LayoutParams layoutParams = new RadioGroup.LayoutParams(wh, wh); // 設(shè)置指示圖大小 
  54.                 gallery_point[i].setLayoutParams(layoutParams); 
  55.                 layoutParams.setMargins(4040);// 設(shè)置指示圖margin值 
  56.                 gallery_point[i].setClickable(false);/* 設(shè)置指示圖按鈕不能點(diǎn)擊 */ 
  57.                 layout.removeView(gallery_point[i]);//一個(gè)子視圖不能指定了多個(gè)父視圖 
  58.                 gallery_points.addView(gallery_point[i]);/* 把已經(jīng)初始化的指示圖動態(tài)添加到指示圖的RadioGroup中 */ 
  59.             } 
  60.         } 
  61.         //添加事件 
  62.         void addEvn(){ 
  63.             myGallery.setOnItemSelectedListener(new OnItemSelectedListener() { 
  64.                 @Override 
  65.                 public void onItemSelected(AdapterView<?> arg0, View arg1, 
  66.                         int arg2, long arg3) { 
  67.                     // TODO Auto-generated method stub 
  68. gallery_points.check(gallery_point[arg2%gallery_point.length].getId()); 
  69.                 } 
  70.                 @Override 
  71.                 public void onNothingSelected(AdapterView<?> arg0) { 
  72.                     // TODO Auto-generated method stub 
  73.                 } 
  74.             }); 
  75.         } 

(2)商品圖片滑動實(shí)現(xiàn)過程:

圖片滑動效果和上面的幻燈片效果非常的類似,只是在邏輯處理和界面上有一些小小的區(qū)別。

1)適配器類GalleryAdapter.java上面進(jìn)行了圖片縮放處理,節(jié)省了內(nèi)存開銷,又可把圖片按照自己的要求縮放。

  1. //由于是測試case,所以圖片都是寫死的為了區(qū)別,在position = 1的時(shí)候換了一張圖片 
  2.     public View getView(int position, View convertView, ViewGroup parent) { 
  3.                 // TODO Auto-generated method stub 
  4.                 ImageView imageView = (ImageView) LayoutInflater.from(context).inflate(R.layout.img, 
  5.                         null); 
  6.                 Bitmap bitmap = null
  7.                 try { 
  8.                     if(position == 1 ){ 
  9.                         bitmap = BitmapFactory.decodeStream(assetManager.open("xpic11247_s.jpg")); 
  10.                         imageView.setTag("xpic11247_s.jpg"); 
  11.                     } 
  12.                     else
  13.                         bitmap = BitmapFactory.decodeStream(assetManager.open("item0_pic.jpg")); 
  14.                         imageView.setTag("item0_pic.jpg"); 
  15.                     } 
  16.                 } catch (IOException e) { 
  17.                     // TODO Auto-generated catch block 
  18.                     e.printStackTrace(); 
  19.                 } 
  20.                 // 加載圖片之前進(jìn)行縮放 
  21.                 int width = bitmap.getWidth(); 
  22.                 int height = bitmap.getHeight(); 
  23.                 float newHeight = 200
  24.                 float newWidth = width*newHeight/height; 
  25.                 float scaleWidth = ((float) newWidth) / width; 
  26.                 float scaleHeight = ((float) newHeight) / height; 
  27.                 // 取得想要縮放的matrix參數(shù) 
  28.                 Matrix matrix = new Matrix(); 
  29.                 matrix.postScale(scaleWidth, scaleHeight); 
  30.                 // 得到新的圖片 
  31.                 Bitmap newbm = Bitmap.createBitmap(bitmap, 00, width, height, matrix, true); 
  32.                 System.out.println(newbm.getHeight()+"-----------"+newbm.getWidth()); 
  33.                 imageView.setImageBitmap(newbm); 
  34.                 // } 
  35.                 return imageView; 
  36.             } 

2)添加了一個(gè)相框效果,如果圖片加載失敗,就會出現(xiàn)一個(gè)圖片壓縮之后大小相等的相框圖片。

  1. <?xml version="1.0" encoding="utf-8"?> 
  2.     <ImageView xmlns:android="http://schemas.android.com/apk/res/android" 
  3.         android:id="@+id/waterfall_image" 
  4.         android:layout_width="fill_parent" 
  5.         android:layout_height="fill_parent" 
  6.         android:background="@drawable/image_border" 
  7.         > 
  8.     </ImageView> 

三、開發(fā)中遇到一些問題

(1)layout.removeView(gallery_point[i]);//一個(gè)子視圖不能指定了多個(gè)父視圖

如果需要把當(dāng)前子childview添加到另外一個(gè)view里面去,則必須在當(dāng)前的父View里面移除掉當(dāng)前的childView,如果不進(jìn)行這樣處理則 會拋出Caused by: java.lang.IllegalStateException異常,提示The specified child already has a parent. You must call removeView() on the child's parent first.

(2)在進(jìn)行圖片縮放的時(shí)候,記得處理好dp和px直接的轉(zhuǎn)換。

責(zé)任編輯:閆佳明 來源: oschina
相關(guān)推薦

2009-02-09 17:45:12

Impressive播放幻燈片 SourceForg

2011-07-13 17:09:34

WPS幻燈片

2013-04-03 11:12:57

Java幻燈片切換

2020-10-15 06:00:22

LinuxLinux終端幻燈片

2013-05-31 09:36:13

Jquery3D效果

2011-01-21 10:50:59

Windows 8

2014-10-29 11:46:00

2012-05-25 14:41:19

JavaScript

2013-07-05 10:26:40

Android

2011-08-09 15:25:00

Windows7

2017-01-22 17:25:55

Android放大鏡效果源碼分析

2012-02-01 09:11:00

jQuery插件

2015-09-06 09:21:25

HTML5幻燈片系統(tǒng)H5Slides

2009-01-07 11:07:27

AJAXASP.NET.NET

2018-09-26 10:00:51

UbuntuLinux幻燈片

2010-08-03 11:29:09

Flex全屏

2024-03-11 08:35:25

Python工程幻燈片

2009-07-29 13:57:53

創(chuàng)建SlideShowASP.NET

2009-12-25 14:25:39

WPF圖標(biāo)

2013-12-02 10:01:04

云平臺
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號