- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Android ViewPager无限循环实现底部小圆点动态滑动由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
页面拖动到最后一页 再向下滑动回复到 第一页,第一页向前滑动回到 最后一页 。
同时,底部红色小圆点随着页面的滑动距离比例随时改变位置 。
布局:
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
|
<?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:layout_width=
"match_parent"
android:layout_height=
"match_parent"
android:paddingbottom=
"@dimen/activity_vertical_margin"
android:paddingleft=
"@dimen/activity_horizontal_margin"
android:paddingright=
"@dimen/activity_horizontal_margin"
android:paddingtop=
"@dimen/activity_vertical_margin"
tools:context=
"com.lian.viewpagertest.mainactivity"
>
<android.support.v4.view.viewpager
android:id=
"@+id/viewpager"
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
>
</android.support.v4.view.viewpager>
<textview
android:id=
"@+id/tv"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:text=
"内容"
android:textsize=
"25sp"
android:layout_alignparentbottom=
"true"
android:layout_centerhorizontal=
"true"
/>
<relativelayout
android:id=
"@+id/rl_bottom"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_alignparentbottom=
"true"
android:layout_centerhorizontal=
"true"
android:layout_marginbottom=
"45dip"
>
<linearlayout
android:id=
"@+id/ll_points"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:orientation=
"horizontal"
>
</linearlayout>
<view
android:id=
"@+id/v_redpoint"
android:layout_width=
"10dip"
android:layout_height=
"10dip"
android:background=
"@drawable/red_circle"
/>
</relativelayout>
</relativelayout>
|
其中red_circle是用shape绘制的红色小圆点 。
最后的linearlayout实际上是灰色小圆点的容器,在代码中根据数据的长度动态确定数目 。
代码:
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
|
package
com.lian.viewpagertest;
import
android.os.bundle;
import
android.support.v4.view.pageradapter;
import
android.support.v4.view.viewpager;
import
android.support.v7.app.appcompatactivity;
import
android.util.log;
import
android.view.view;
import
android.view.viewgroup;
import
android.view.viewtreeobserver;
import
android.widget.imageview;
import
android.widget.linearlayout;
import
android.widget.relativelayout;
import
android.widget.textview;
import
java.util.arraylist;
import
java.util.list;
public
class
mainactivity
extends
appcompatactivity {
private
viewpager mviewpager;
private
textview mtextview;
private
linearlayout mlinearlayout;
private
view mview;
private
list<imageview> mdatalist;
private
int
diatance;
@override
protected
void
oncreate(bundle savedinstancestate) {
super
.oncreate(savedinstancestate);
initview();
initdata();
initevent();
}
/**
* 初始化数据
*/
private
void
initdata() {
int
[] sorce =
new
int
[]{r.drawable.a,r.drawable.b,r.drawable.c,r.drawable.d,r.drawable.e};
mdatalist =
new
arraylist<imageview>();
for
(
int
i =
0
;i < sorce.length;i ++){
imageview img =
new
imageview(getapplicationcontext());
img.setimageresource(sorce[i]);
mdatalist.add(img);
//添加底部灰点
view v =
new
view(getapplicationcontext());
v.setbackgroundresource(r.drawable.gray_circle);
//指定其大小
linearlayout.layoutparams params =
new
linearlayout.layoutparams(
20
,
20
);
if
(i !=
0
)
params.leftmargin =
20
;
v.setlayoutparams(params);
mlinearlayout.addview(v);
}
mviewpager.setadapter(
new
myadapter());
//设置每次加载时第一页在max_value / 2 - extra 页,造成用户无限轮播的错觉
int
startpage = integer.max_value /
2
;
int
extra = startpage % mdatalist.size();
startpage = startpage - extra;
mviewpager.setcurrentitem(startpage);
}
/**
* viewpager的容器
*/
public
class
myadapter
extends
pageradapter{
@override
public
int
getcount() {
//告诉容器我们的数据长度为integer.max_value,这样就可以一直滚动
return
integer.max_value;
}
@override
public
boolean
isviewfromobject(view view, object object) {
return
view == object;
}
@override
public
object instantiateitem(viewgroup container,
int
position) {
//若position超过mdatalist.size(),会发生越界异常,所以这里每次超过size又从0开始计算位置
position = position % mdatalist.size();
imageview img = mdatalist.get(position);
container.addview(img);
return
img;
}
@override
public
void
destroyitem(viewgroup container,
int
position, object object) {
position = position % mdatalist.size();
container.removeview((view)object);
// super.destroyitem(container, position, object);
}
}
private
void
initevent() {
/**
* 当底部红色小圆点加载完成时测出两个小灰点的距离,便于计算后面小红点动态移动的距离
*/
mview.getviewtreeobserver().addongloballayoutlistener(
new
viewtreeobserver.ongloballayoutlistener() {
@override
public
void
ongloballayout() {
diatance = mlinearlayout.getchildat(
1
).getleft() - mlinearlayout.getchildat(
0
).getleft();
log.d(
"两点间距"
,diatance +
"测出来了"
);
}
});
mviewpager.setonpagechangelistener(
new
viewpager.onpagechangelistener() {
@override
public
void
onpagescrolled(
int
position,
float
positionoffset,
int
positionoffsetpixels) {
//测出页面滚动时小红点移动的距离,并通过setlayoutparams(params)不断更新其位置
position = position % mdatalist.size();
float
leftmargin = diatance * (position + positionoffset);
relativelayout.layoutparams params = (relativelayout.layoutparams) mview.getlayoutparams();
params.leftmargin = math.round(leftmargin);
mview.setlayoutparams(params);
log.d(
"红点在这"
,leftmargin +
""
);
}
@override
public
void
onpageselected(
int
position) {
}
@override
public
void
onpagescrollstatechanged(
int
state) {
}
});
}
private
void
initview() {
setcontentview(r.layout.activity_main);
mviewpager = (viewpager) findviewbyid(r.id.viewpager);
mtextview = (textview) findviewbyid(r.id.tv);
mlinearlayout = (linearlayout) findviewbyid(r.id.ll_points);
mview = findviewbyid(r.id.v_redpoint);
}
}
|
以上就是本文的全部内容,希望对大家的学习有所帮助.
最后此篇关于Android ViewPager无限循环实现底部小圆点动态滑动的文章就讲到这里了,如果你想了解更多关于Android ViewPager无限循环实现底部小圆点动态滑动的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这是在我的 MainActivity 中用作 BroadcastReceiver 的代码 mRegistrationBroadcastReceiver = new BroadcastRecei
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我想在大部分时间隐藏 UISearchBar,只在用户需要时调用它来显示。 我在 Interface Builder 中放置了一个 UISearchBar 并将其隐藏在 View 后面,当用户单击按钮
我有一个包含 CCMenuItemImage 的菜单(“myMenu”)。我希望此菜单能够检测手指滑动并相应地滑动。 我的问题是 CCMenuItemImage 似乎吸收了触摸事件。当用户触摸 CCM
我正在寻找一个简单的 jQuery 或 Javascript 解决方案,以使导航侧边栏在用户向下滚动页面时顺利跟随用户。像这里一样:http://ucon-acrobatics.com/shop/ 任
我有一个 ListView 控件来显示项目,我想提供一个滑动/滑动手势来选择一个项目。我用 GestureRecognizer类来识别交叉滑动手势,但我还想通过水平移动选择的项目来为这个手势设置动画。
我想将 String 行标记化为标记(存储到 String 表中),并且我只能使用 java.io.*它是为了实现一个计算器。 例如:第一行:1+2+3第二行:1+ 2*3(标记之间有空格) 进入表{
我有一个 ListView 控件来显示项目,我想提供一个滑动/滑动手势来选择一个项目。我用 GestureRecognizer类来识别交叉滑动手势,但我还想通过水平移动选择的项目来为这个手势设置动画。
我有一个导航栏,当单击菜单图标时,它将滑入“#secondary-nav”并隐藏“#primary-nav”。然而 jquery 似乎没有显示“#secondary-menu”。下面提供的是 HTMl
这个问题已经有答案了: how to make a sliding up panel like the Google Maps app? (2 个回答) 已关闭 7 年前。 我正在寻找类似的实现,如下
我有 ViewPager(Slide) 和 3 张图片。共有三个图像是通过 Internet 下载的。如果我将图片换到服务器上的另一台服务器上,链接保持不变,但应用程序中的图片没有改变,仍然是缓存中的
我在 gridview 中创建了两个按钮。 我想达到以下目的,但不知道应该用什么方法? 首先我触摸第一个按钮,将显示 toast 1 msg。通过将我的手指滑到第二个按钮而不抬起我的手指,将显示 to
所以我设置了一个小的 jquery 动画,用户将鼠标悬停在容器上一段时间,这会导致容器 split ,然后显示内部信息。 我不希望鼠标一进入容器就开始动画,所以我在动画上放了一个delay()。现在动
这个问题在这里已经有了答案: Simulate swipe with mouse in javascript (5 个答案) 关闭 7 年前。
我希望我的 Sprite 像在冰上一样滑动。因此,如果他在地面上,那么他可以正常行走,但当他接触冰时,他会滑动,直到有东西阻止他。有谁知道如何才能做到这一点?谢谢 最佳答案 像“Sprite Move
我的代码有几个问题:HTML: Bellevue
我正在尝试实现从 fragment1 过渡到 fragment2 的滑动动画。我正在使用 setCustomAnimations 方法。而且我知道我需要使用框架方法来替换 fragment 。 我的代
我不知道你们是否听说过 app chomp,但应用程序中有一个布局,如下图所示。我想知道他们是如何设置的,我将如何使用它来为我自己的应用程序制作类似的东西。有趣的是,当你滑动时,没有像水平 Scrol
我想检测用户何时在一个单元格占据整个屏幕宽度的 collectionView 中向左或向右滑动。是否可以不添加手势识别器。我试过添加手势识别器,但只有当我们将 collectionView 的 scr
我正在尝试开发一个应用程序来复制类似 tinder 的基于滑动的提要。该应用程序的想法与火种非常相似,也具有向右滑动和向左滑动匹配功能。 到目前为止我做了什么-我在 MongoDB 中创建了一个刷卡集
我是一名优秀的程序员,十分优秀!