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

Android線程實(shí)現(xiàn)圖片輪播

 更新時(shí)間:2016年12月28日 15:05:19   作者:niaonao  
這篇文章主要介紹了Android線程實(shí)現(xiàn)圖片輪播,初始化3秒更換一次圖片背景,輪換播放,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

一、實(shí)現(xiàn)效果

本篇文章實(shí)現(xiàn)了簡(jiǎn)單的圖片輪播,初始化3張資源圖片,初始化3秒更換一次圖片背景,輪換播放。

二、知識(shí)點(diǎn)

Thread線程start() 、sleep();handler機(jī)制;Android 控件imageView、setBackgroundResource(id);

還算是較為簡(jiǎn)單的,涉及的基本都是基礎(chǔ)知識(shí)。

三、基本思路

  1.初始化資源文件

  2.創(chuàng)建一個(gè)實(shí)例化線程對(duì)象 new Thread()

  3.handler 機(jī)制,sendMessage(msg); 來處理線程信息,以改變當(dāng)前顯示資源圖片為下一張

  4.線程設(shè)置睡眠時(shí)間,來設(shè)置圖片輪播的時(shí)間間隔,

  5.每隔一段時(shí)間通過 handler 機(jī)制發(fā)送一次信息來實(shí)現(xiàn)圖片資源變換來實(shí)現(xiàn)輪播

-->>代碼實(shí)現(xiàn):

  (1) layout 布局:就一個(gè)ImageView 控件

k1.jpg ,k2.jpg, k3,jpg 是三張圖片

(2)  java 代碼實(shí)現(xiàn)對(duì)背景圖片的輪播變換操作:

package com.example.ususaltest; 
 
import android.app.Activity; 
import android.os.Bundle; 
import android.os.Handler; 
import android.os.Message; 
import android.widget.ImageView; 
 
public class MainActivity extends Activity { 
 
  int i = 1;//變量 
  private ImageView imageView; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
 
    initView();//加載控件 
    initEvent();//控件操作 
     
  } 
   
  private void initView() { 
    imageView = (ImageView) findViewById(R.id.id_image); 
  } 
   
  private void initEvent(){ 
     
     
    final Handler handler = new Handler(){ 
      @Override 
      public void handleMessage(Message msg) {//接收消息,并處理 
        super.handleMessage(msg); 
        if (msg.what == 1)  
          imageView.setBackgroundResource(R.drawable.k1);//設(shè)置變換后的圖片資源 
        else if (msg.what == 2)  
          imageView.setBackgroundResource(R.drawable.k2); 
        else if (msg.what == 3)  
          imageView.setBackgroundResource(R.drawable.k3); 
        else  
          imageView.setBackgroundResource(R.drawable.k1); 
      } 
    }; 
     
    new Thread(new Runnable() { 
      @Override 
      public void run() { 
        while (true) { 
          try { 
          Thread.sleep(3000);//暫停 3 秒 
        } catch (InterruptedException e) {e.printStackTrace();} 
        Message message = new Message(); 
        message.what = i; 
        handler.sendMessage(message);//發(fā)送消息 
         
        if(i == 3)//3張圖片播放完,重置 
          i = 0; 
         
        i++; 
        } 
      } 
    }).start(); 
  } 
 
} 

(3) 到此已實(shí)現(xiàn)圖片輪播效果,但可觀賞度不高,可以適當(dāng)?shù)募右恍﹦?dòng)畫什么的,使圖片轉(zhuǎn)換時(shí)更加有動(dòng)感,動(dòng)態(tài)的變換,看得到變換的過程,而不是單純的靜態(tài)的變換。

四、拓展延伸 -- 動(dòng)畫

加上縮放動(dòng)畫,使圖片輪換時(shí)能看到更換過程,動(dòng)態(tài)化輪播功能

new Thread(new Runnable() { 
      @Override 
      public void run() { 
        while (true) { 
          try { 
          Thread.sleep(3000); 
        } catch (InterruptedException e) {e.printStackTrace();} 
        Message message = new Message(); 
        message.what = i; 
        handler.sendMessage(message);//發(fā)送消息 
        //加上縮放動(dòng)畫 
        <span style="background-color: rgb(51, 255, 255);">AnimationSet set = new AnimationSet(true); 
        ScaleAnimation scale = new ScaleAnimation(1.5f, 1.0f, 1.5f, 1.0f ,Animation.RELATIVE_TO_SELF, 0.5f ,Animation.RELATIVE_TO_SELF, 0.5f); 
        scale.setDuration(500); 
        set.addAnimation(scale); 
        imageView.setAnimation(set);</span> 
         
        if(i == 3)//3張圖片播放完,重置 
          i = 0; 
         
        i++; 
        } 
      } 
    }).start(); 

這樣效果上會(huì)好一點(diǎn),也可以加位移動(dòng)畫,使換圖片時(shí),讓圖片從右邊進(jìn)來,或左邊進(jìn)來右邊出去之類的動(dòng)畫。

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

相關(guān)文章

最新評(píng)論