ViewFlipper实现文字轮播(仿淘宝头条垂直滚动广告),供大家参考,具体内容如下
广告条目可以单独写成布局文件,然后在布局文件或者代码中添加到总布局中
从源码可以看出,其实ViewFlipper间接的继承了FrameLayout,也可以说ViewFlipper其实就是个FrameLayout,只不过在内部封装了动画实现和Handler实现一个循环而已。
布局文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
<? xml version = "1.0" encoding = "utf-8" ?> < RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android" xmlns:tools = "http://schemas.android.com/tools" android:id = "@+id/activity_main" android:layout_width = "match_parent" android:layout_height = "match_parent" > <!--android:autoStart:设置自动加载下一个View--> <!--android:flipInterval:设置View之间切换的时间间隔--> <!--android:inAnimation:设置切换View的进入动画--> <!--android:outAnimation:设置切换View的退出动画--> < ViewFlipper android:id = "@+id/view_flipper" android:layout_width = "match_parent" android:layout_height = "100dp" android:layout_centerInParent = "true" android:autoStart = "true" android:background = "#808080" android:flipInterval = "2000" android:inAnimation = "@anim/slide_in_down" android:outAnimation = "@anim/slide_out_up" > < TextView android:id = "@+id/first" android:layout_width = "wrap_content" android:layout_height = "wrap_content" android:layout_gravity = "center" android:text = "白日依山尽" android:textColor = "#FF00FF" android:textSize = "50sp" /> < TextView android:id = "@+id/second" android:layout_width = "wrap_content" android:layout_height = "wrap_content" android:layout_gravity = "center" android:text = "黄河入海流" android:textColor = "#FF00FF" android:textSize = "50sp" /> < TextView android:id = "@+id/third" android:layout_width = "wrap_content" android:layout_height = "wrap_content" android:layout_gravity = "center" android:text = "欲穷千里目" android:textColor = "#FF00FF" android:textSize = "50sp" /> < TextView android:id = "@+id/forth" android:layout_width = "wrap_content" android:layout_height = "wrap_content" android:layout_gravity = "center" android:text = "更上一层楼" android:textColor = "#FF00FF" android:textSize = "50sp" /> </ ViewFlipper > </ RelativeLayout > |
这里介绍ViewFlipper用到的属性,这些属性其实都可以使用代码实现,只不过这里为了代码看上去美观,才放在布局里的
- android:autoStart : 设置自动加载下一个View
- android:flipInterval : 设置View之间切换的时间间隔
- android:inAnimation : 设置切换View的进入动画
- android:outAnimation : 设置切换View的退出动画
下面是ViewFlipper常用的方法介绍,除了可以设置上面的属性之外,还提供了其他方法
- isFlipping : 判断View切换是否正在进行
- setFlipInterval : 设置View之间切换的时间间隔
- startFlipping : 开始View的切换,而且默认会循环进行
- stopFlippiing : 停止View的切换
- setOutAnimation : 设置切换View的退出动画
- setInAnimation : 设置切换View的进入动画
- showNext : 显示ViewFlipper里的下一个View
- showPrevious : 显示ViewFlipper里的上一个View
这里还涉及到两个动画其实就是一个平移的动画,它们都保存在anim文件夹中
slide_in_down.xml 进入动画
1
2
3
4
5
6
7
|
<? xml version = "1.0" encoding = "utf-8" ?> < set xmlns:android = "http://schemas.android.com/apk/res/android" > < translate android:duration = "@android:integer/config_mediumAnimTime" android:fromYDelta = "100%" android:toYDelta = "0" /> </ set > |
slide_out_up.xml 退出动画
1
2
3
4
5
6
7
|
<? xml version = "1.0" encoding = "utf-8" ?> < set xmlns:android = "http://schemas.android.com/apk/res/android" > < translate android:duration = "@android:integer/config_mediumAnimTime" android:fromYDelta = "0" android:toYDelta = "-100%" /> </ set > |
MainActivity
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
package com.nrf.mydemo; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.activity_main); } } |
运行之后,效果图
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/luck_nie/article/details/80012092