滚动播放文字或者图片信息效果

简介: 源码地址    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;imp


源码地址   

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>














目录
相关文章
|
2月前
|
数据安全/隐私保护
图片添加文字水印
【10月更文挑战第21天】图片添加文字水印是一种重要的保护和宣传手段。通过合理选择文字内容、设计和添加方法,可以有效地为图片添加水印,保护图片的权益和价值。同时,随着技术的发展,我们也需要不断探索和创新,以适应不断变化的需求。你还可以根据具体的行业需求和实际情况,进一步深入研究和优化文字水印的添加策略,确保图片得到更好的保护和利用。
61 0
|
5月前
|
JavaScript
文本,视频网站轮播框如何只播放前五条数据
文本,视频网站轮播框如何只播放前五条数据
|
7月前
如何实现图片多种颜色的文字混排并且带的背景颜色范围比文字图片范围大
如何实现图片多种颜色的文字混排并且带的背景颜色范围比文字图片范围大
46 1
|
7月前
|
C# 开发工具 数据安全/隐私保护
C# 给图片添加文字水印
C# 给图片添加文字水印
|
Web App开发 移动开发 前端开发
移动端图片操作(二)——预览、旋转、合成
在上一节中已经提到了预览,预览可以通过data: URL格式或URL对象。
移动端图片操作(二)——预览、旋转、合成
滚动截取页面图片
滚动截取页面图片
74 0
|
数据安全/隐私保护
生活中常用的图片去水印方法有哪些呢
有时候我们想换头像/微信背景墙了 是不是第一时间想到的是去某书逛逛,有时候看到有些博主分享的壁纸或者表情包等,忍不住的想保存下来,很多人应该还不知道如何下载吧,今天分享我的三个操作方法
|
人工智能 小程序 数据安全/隐私保护
微信8.0状态视频无水印素材+个人设置技巧
微信8.0状态视频无水印素材+个人设置技巧
322 0
微信8.0状态视频无水印素材+个人设置技巧
|
前端开发 JavaScript 搜索推荐
文字水印的几种实现方式
文字水印是一种强提示,一般会用在前端展示敏感、权利声明等场景下。我们简单介绍几种方法。
487 0
文字水印的几种实现方式
|
架构师 开发者
图片和文字控件|学习笔记
快速学习图片和文字控件。
101 0