滾動播放文字或者圖片信息效果


源碼地址   java

package com.example.shifteffect;

import com.app.plugs.effect.EffectUtil;
import com.app.plugs.effect.view.EffectView;
import com.example.scrolleffect.R;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.LinearLayout;
import android.widget.Spinner;
import android.widget.AdapterView.OnItemSelectedListener;

public class MainActivity extends Activity implements OnItemSelectedListener {

	// 展現漸變更效的容器,用於容納漸變效果庫的View控件
	private LinearLayout container;
	
	// 漸變效果庫的View控件類
	private EffectView mView;
	
	// 文字資源(用於展現漸變切換)
	private String[] mTexts = { "今日新聞1", "今日新聞2", "今日新聞3" };
	
	// 圖片資源(用於展現漸變切換)
	private int[] mImages = { R.drawable.image_1, R.drawable.image_2, R.drawable.image_3 };

	// 內容選項
	private Spinner sp1;
	private ArrayAdapter<String> aa1;
	private String[] menu1 = { "內容:文字", "內容:圖片" };

	// 漸變時間選項
	private Spinner sp2;
	private ArrayAdapter<String> aa2;
	private String[] menu2 = { "動時:300ms", "動時:1000ms", "動時:3000ms" };

	// 漸變間隔選項
	private Spinner sp3;
	private ArrayAdapter<String> aa3;
	private String[] menu3 = { "停時:3000ms", "停時:5000ms", "停時:10000ms" };

	// 漸變效果選項
	private Spinner sp4;
	private ArrayAdapter<String> aa4;
	private String[] menu4 = { "動效:向上", "動效:向下", "動效:向左", "動效:向右", "動效:旋轉",
			"動效:大小", "動效:漸變" };

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		// 初始化展現動效的容器
		container = (LinearLayout) this.findViewById(R.id.container);

		// 初始化各個選項的內容
		sp1 = (Spinner) findViewById(R.id.spinner1);
		aa1 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu1);
		aa1.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
		sp1.setAdapter(aa1);
		sp1.setOnItemSelectedListener(this);

		sp2 = (Spinner) findViewById(R.id.spinner2);
		aa2 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu2);
		aa2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
		sp2.setAdapter(aa2);
		sp2.setOnItemSelectedListener(this);

		sp3 = (Spinner) findViewById(R.id.spinner3);
		aa3 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu3);
		aa3.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
		sp3.setAdapter(aa3);
		sp3.setOnItemSelectedListener(this);

		sp4 = (Spinner) findViewById(R.id.spinner4);
		aa4 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, menu4);
		aa4.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
		sp4.setAdapter(aa4);
		sp4.setOnItemSelectedListener(this);
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		getMenuInflater().inflate(R.menu.activity_main, menu);
		return true;
	}

	@Override
	public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
		// 內容選項邏輯(可選擇滾動文字或者圖片)
		if (parent.getAdapter() == aa1) {
			container.removeAllViews();
			switch (position) {
				case 0:
					// 初始化文字切換View對象
					mView = EffectUtil.fillTexts(this, EffectView.ANI_UP, 30, mTexts);
					container.addView(mView);
					mView.start();
					break;
				default:
					mView = EffectUtil.fillImages(this, EffectView.ANI_UP, mImages);
					container.addView(mView);
					mView.start();
					break;
			}
		}
		// 漸變時間選項邏輯
		if (parent.getAdapter() == aa2) {
			switch (position) {
				case 0:
					mView.setDuration(300);
					break;
				case 1:
					mView.setDuration(1000);
					break;
				default:
					mView.setDuration(3000);
					break;
			}
		}
		// 漸變間隔選項邏輯
		if (parent.getAdapter() == aa3) {
			switch (position) {
				case 0:
					mView.setInterval(3000);
					break;
				case 1:
					mView.setInterval(5000);
					break;
				default:
					mView.setInterval(10000);
					break;
			}
		}
		// 漸變效果選項
		if (parent.getAdapter() == aa4) {
			switch (position) {
				case 0:
					mView.setAnimation(EffectView.ANI_UP); // 往上滾動
					break;
				case 1:
					mView.setAnimation(EffectView.ANI_DOWN); // 往下滾動
					break;
				case 2:
					mView.setAnimation(EffectView.ANI_LEFT); // 往左滾動
					break;
				case 3:
					mView.setAnimation(EffectView.ANI_RIGHT); // 往右滾動
					break;
				case 4:
					mView.setAnimation(EffectView.ANI_ROTATE); // 旋轉漸變
					break;
				case 5:
					mView.setAnimation(EffectView.ANI_SCALE); // 大小漸變
					break;
				default:
					mView.setAnimation(EffectView.ANI_FADE); // 消失漸變
					break;
			}
		}
	}

	@Override
	public void onNothingSelected(AdapterView<?> parent) {
		// TODO Auto-generated method stub

	}
}

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:orientation="vertical" android:padding="10dip"
	android:layout_width="fill_parent" 
	android:layout_height="fill_parent">

	<Spinner android:id="@+id/spinner1" 
		android:layout_width="fill_parent"
		android:layout_height="wrap_content" />
	
	<Spinner android:id="@+id/spinner2" 
		android:layout_width="fill_parent"
		android:layout_height="wrap_content" />
	
	<Spinner android:id="@+id/spinner3" 
		android:layout_width="fill_parent"
		android:layout_height="wrap_content" />
	
	<Spinner android:id="@+id/spinner4" 
		android:layout_width="fill_parent"
		android:layout_height="wrap_content" />

	<LinearLayout android:id="@+id/container"
		android:layout_width="fill_parent" 
		android:layout_height="fill_parent"
		android:layout_weight="1" 
		android:gravity="center" />

</LinearLayout>
相關文章
相關標籤/搜索