源码地址
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>