- 浏览: 176498 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
dupeng41255:
问一下,。com的接口 是不是需要注册啊?我调用的时候返回说需 ...
java实现whois域名查询 -
feiyu86:
比喻的非常贴切。。
synchronized方法和代码块的使用 -
罡风笑:
贴结果:CBH 蜀汉 绝顶 刀客
开心一下 你古代的身份。超级好玩~
来自:http://blog.csdn.net/lenghun00/article/details/7635374
@Gallery配合dot使用时,如果放在RelativeLayout中,则手动滑动有反弹现象,其他layout没问题,现在还没弄清原因。
首先继承Gallery重写OnFling函数,去除gallery的滚动惯性
- public class MyGallery extends Gallery {
- public MyGallery(Context context, AttributeSet attrs) {
- super(context, attrs);
- // TODO Auto-generated constructor stub
- }
- private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2) {
- return e2.getX() > e1.getX();
- }
- @Override
- public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
- float velocityY) {
- int keyCode;
- if (isScrollingLeft(e1, e2)) {
- keyCode = KeyEvent.KEYCODE_DPAD_LEFT;
- } else {
- keyCode = KeyEvent.KEYCODE_DPAD_RIGHT;
- }
- onKeyDown(keyCode, null);
- return true;
- }
- }
public class MyGallery extends Gallery { public MyGallery(Context context, AttributeSet attrs) { super(context, attrs); // TODO Auto-generated constructor stub } private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2) { return e2.getX() > e1.getX(); } @Override public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { int keyCode; if (isScrollingLeft(e1, e2)) { keyCode = KeyEvent.KEYCODE_DPAD_LEFT; } else { keyCode = KeyEvent.KEYCODE_DPAD_RIGHT; } onKeyDown(keyCode, null); return true; } }
@注OnFling直接返回false也能实现类似效果,但那样需要滑动很大距离,图片才会切换,用户体验不好
第二步,构造adapter
要想平滑的实现循环滚动,可以让getCount返回一个很大的值,这样gallery就认为是有多个item,item之间的切换动画是平滑的
- public class GalleryAdapter extends BaseAdapter {
- private LayoutInflater mInflater;
- private Context mContext;
- private int width;
- private int count;
- private int[] mImageIds;
- public GalleryAdapter(Context context, int[] ids) {
- mContext = context;
- mImageIds = ids;
- mInflater = LayoutInflater.from(mContext);
- DisplayMetrics dm = mContext.getApplicationContext().getResources()
- .getDisplayMetrics();
- width = dm.widthPixels;
- count = mImageIds.length;
- }
- @Override
- public int getCount() {
- return Integer.MAX_VALUE;//用于循环滚动
- }
- @Override
- public Object getItem(int position) {
- return position;
- }
- @Override
- public long getItemId(int position) {
- return position;
- }
- @Override
- public View getView(int position, View convertView, ViewGroup parent) {
- position = position % count;
- if (convertView == null) {
- convertView = mInflater.inflate(R.layout.gallery_item, null);
- }
- ImageView v = (ImageView) convertView.findViewById(R.id.img);
- v.setLayoutParams(new Gallery.LayoutParams(width, 200));
- v.setScaleType(ImageView.ScaleType.FIT_XY);
- v.setBackgroundResource(mImageIds[position]);
- return v;
- }
- }
public class GalleryAdapter extends BaseAdapter { private LayoutInflater mInflater; private Context mContext; private int width; private int count; private int[] mImageIds; public GalleryAdapter(Context context, int[] ids) { mContext = context; mImageIds = ids; mInflater = LayoutInflater.from(mContext); DisplayMetrics dm = mContext.getApplicationContext().getResources() .getDisplayMetrics(); width = dm.widthPixels; count = mImageIds.length; } @Override public int getCount() { return Integer.MAX_VALUE;//用于循环滚动 } @Override public Object getItem(int position) { return position; } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { position = position % count; if (convertView == null) { convertView = mInflater.inflate(R.layout.gallery_item, null); } ImageView v = (ImageView) convertView.findViewById(R.id.img); v.setLayoutParams(new Gallery.LayoutParams(width, 200)); v.setScaleType(ImageView.ScaleType.FIT_XY); v.setBackgroundResource(mImageIds[position]); return v; } }
第三,实现自动滚动
由于我们还要手动滚动,所以自动滚动用单独一个进程来实现
- private void startAutoScroll() {
- new Thread() {
- @Override
- public void run() {
- int count = 0;
- while (mAutoScroll) {
- count = 0;
- while (count < 30) {
- count++;
- try {
- Thread.sleep(100);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- if (mOnTouch) {// 用戶手动滑动时,停止自动滚动
- count = 0;
- }
- }
- mPosition++;
- Message msg = mHandler.obtainMessage(SCROLL, mPosition, 0);
- mHandler.sendMessage(msg);
- }
- }
- }.start();
- }
- private Handler mHandler = new Handler() {
- @Override
- public void handleMessage(Message msg) {
- switch (msg.what) {
- case SCROLL:
- mGallery.setSelection(msg.arg1);
- break;
- }
- }
- };
private void startAutoScroll() { new Thread() { @Override public void run() { int count = 0; while (mAutoScroll) { count = 0; while (count < 30) { count++; try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } if (mOnTouch) {// 用戶手动滑动时,停止自动滚动 count = 0; } } mPosition++; Message msg = mHandler.obtainMessage(SCROLL, mPosition, 0); mHandler.sendMessage(msg); } } }.start(); } private Handler mHandler = new Handler() { @Override public void handleMessage(Message msg) { switch (msg.what) { case SCROLL: mGallery.setSelection(msg.arg1); break; } } };
第四实现手动滚动
手动滚动时,要停止自动滚动,监听gallery的onTouch事件,DOWN时mOnTouch置为true,UP时mOnTouch置为false即可
- mGallery.setOnTouchListener(new OnTouchListener() {
- @Override
- public boolean onTouch(View v, MotionEvent event) {
- int action = event.getAction();
- if (action == MotionEvent.ACTION_DOWN) {
- mOnTouch = true;
- } else if (action == MotionEvent.ACTION_UP) {
- mOnTouch = false;
- }
- return false;
- }
- });
mGallery.setOnTouchListener(new OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { int action = event.getAction(); if (action == MotionEvent.ACTION_DOWN) { mOnTouch = true; } else if (action == MotionEvent.ACTION_UP) { mOnTouch = false; } return false; } });
到现在我们已经可以自动滚动,手动滚动时自动滚动也会停止。
我们也许还需要加上dot提示图片滚动的位置
- LinearLayout layout = (LinearLayout) findViewById(R.id.dot);
- if (mDots == null) {
- mDots = new ImageView[ids.length];
- for (int i = 0; i < ids.length; i++) {
- if (mDots[i] == null)
- mDots[i] = new ImageView(this);
- mDots[i].setBackgroundResource(R.drawable.banner_tab_unselected);
- layout.addView(mDots[i], new LinearLayout.LayoutParams(mWidth
- / ids.length + 1, LayoutParams.WRAP_CONTENT));
- }
- mDots[0].setBackgroundResource(R.drawable.banner_tab_selected);
- }
LinearLayout layout = (LinearLayout) findViewById(R.id.dot); if (mDots == null) { mDots = new ImageView[ids.length]; for (int i = 0; i < ids.length; i++) { if (mDots[i] == null) mDots[i] = new ImageView(this); mDots[i].setBackgroundResource(R.drawable.banner_tab_unselected); layout.addView(mDots[i], new LinearLayout.LayoutParams(mWidth / ids.length + 1, LayoutParams.WRAP_CONTENT)); } mDots[0].setBackgroundResource(R.drawable.banner_tab_selected); }
- mGallery.setOnItemSelectedListener(new OnItemSelectedListener() {
- @Override
- public void onItemSelected(AdapterView<?> arg0, View view,
- int position, long arg3) {
- mDotPosition = position % ids.length;
- mDots[mDotPosition]
- .setBackgroundResource(R.drawable.banner_tab_selected);
- if (mDotPosition != mPreDotPosition)
- mDots[mPreDotPosition]
- .setBackgroundResource(R.drawable.banner_tab_unselected);
- mPreDotPosition = mDotPosition;
- }
- @Override
- public void onNothingSelected(AdapterView<?> arg0) {
- }
- });
发表评论
-
Android 属性动画(Property Animation) 完全解析 (下)
2016-02-22 14:49 1067版权声明:本文为博主原创文章,未经博主允许不得转载。 ... -
Android 属性动画(Property Animation) 完全解析 (上)
2016-02-22 14:47 730版权声明:本文为博主原创文章,未经博主允许不得转载。 ... -
Windows系统中Maven的安装与配置以及m2eclipse插件的安装
2014-04-30 16:06 1192近期公司的一个项目需要用maven搭建,所以把maven的环 ... -
Gallery自动循环滚动,手动滚动的平滑切换及存在问题
2012-11-06 10:34 7来自:http://blog.csdn.net/lenghun ... -
VLC for Android on Linux
2012-07-12 14:28 1944来自:http://wiki.videolan.org/And ... -
Android模拟器对应电脑键盘快捷键
2012-01-10 00:01 1427Home键(小房子键) 在键盘上映射的是home键。 ... -
Android的gallery实现无限循环和降低选择频率
2011-07-20 17:55 1485gallery是一个很好用的控 ... -
Android编译问题:Only 64-bit build environments are supported beyond froyo/2.2
2011-03-07 19:01 1136在使用: $ repo init -u git://An ... -
任务管理器正在运行的程序(2)
2010-12-23 14:36 1737RunningTaskInfo AndroidManifes ... -
任务管理器正在运行的程序(1)
2010-12-23 14:26 1538RunningTaskInfo 范例说明 ... -
android 监听文件和目录的创建删除移动等事件
2010-11-11 15:14 1770android.os下的FileObserver类是一个 ... -
animation知识学习
2010-10-22 14:07 2038LinearInterpolator 变化率是个常数,即 f ... -
Android 页面切换动画效果
2010-10-18 12:54 4181在Android 2.0之后有了ove ... -
android自适应屏幕方向和大小
2010-09-27 16:51 1752一:不同的layoutAndroid手机屏幕大小不一,有 ... -
Android图片处理的的一些方法
2010-08-02 18:54 63311.图片加载方法,方便用户加载图片 /**** 加载本地图片 ... -
OMA-SyncML-DataSyncProtocol-V1_1_2-20030612-A
2010-07-02 12:12 676手机联系人等信息同步中使用 -
Android取得屏幕分辨率
2010-05-31 10:32 958WindowManager windowManager = g ... -
Content Providers
2010-03-04 23:21 1201来源:http://developer.andro ... -
Android基础 : Android Content Provider[转]
2010-03-02 23:09 1110Android应用程序可以使用文件或SqlLite数据库来存储 ... -
Android 联系人开发- 保存联系人
2010-03-02 22:46 4757最近在开发android平台的联系人部分,有点总结和大家分享一 ...
相关推荐
2. **触摸反馈**:用户可以通过轻触屏幕并滑动来手动滚动,同时`Gallery`会提供适当的滚动反馈。 3. **自动滚动**:通过定时器或者动画实现自动在项目间切换,即图片轮播效果。 4. **焦点管理**:`Gallery`会管理...
在Android开发中,展示图像的方式多种多样,其中`Gallery`和`ImageSwitcher`是两种常用的组件,尤其适用于实现图片的循环显示切换效果。这里,我们将深入探讨这两个组件的使用方法及其背后的原理。 首先,`Gallery`...
在Android开发中,`Gallery`是一个非常有用的控件,它允许用户...无论是手动还是自动循环,都需要关注焦点的切换时机以及相应的事件处理。在实际项目中,还可以根据需求进一步优化,例如添加过渡动画、设置滚动速度等。
8. **用户体验**:设置适当的自动滚动间隔,确保用户能跟上图片切换的速度,同时添加手势控制,让用户可以根据需要手动滑动。 总结起来,实现"android滚动插件"涉及到的主要知识点包括:使用ViewPager或Gallery组件...
"不间断无接缝图片滚动"是一种常见的网页设计技术,它为用户提供了一种流畅且连续的视觉体验,使得图片在页面上以无缝的方式自动或手动滚动。这种效果在展示产品图库、摄影集或者画廊等场景中非常常见,能够吸引用户...
同时,通过设置PagerAdapter的`setOffscreenPageLimit()`方法,可以控制缓存的页面数量,确保图片的平滑切换。 2. **Adapter**:为了将图片数据绑定到ViewPager,我们需要创建一个适配器(Adapter),比如`...
ViewFlow是一个开源的Android库,它提供了类似Gallery的无限循环滚动功能,同时具有更好的性能和自定义性。ViewFlow允许开发者轻松地创建水平滚动视图,适用于展示一系列图片或按钮,实现平滑的用户体验。在这个项目...
图片轮播通常基于定时器(如`setInterval`)实现,每隔一定时间自动切换显示的图片。jQuery提供了一组方便的动画方法,如`fadeIn`和`fadeOut`,可以用于平滑地淡入淡出图片,实现无缝过渡效果。 **二、jQuery选择器...
13.jquery黑色循环滚动菜单特效插件下载 14.jquery灰色简洁风格横向三级网站导航菜单 15.jquery简洁动感支持三级的黑色导航菜单 16.jquery类似TAB一样的动感菜单下载 17.jquery绿色动感滑动下拉多级导航...
1. **自定义View**:开发者可以创建一个继承自HorizontalScrollView或者ViewPager的自定义View,然后在此基础上实现图片的循环滚动。这通常涉及以下步骤: - 实现滑动手势的监听,处理用户的滑动事件。 - 编写布局...
本文将深入探讨如何使用RecyclerView实现一个循环滚动的Banner效果,类似于Gallery组件的功能。 首先,我们需要理解RecyclerView的基本架构。RecyclerView由Adapter、ViewHolder和LayoutManager三个主要部分组成。...
这个项目利用JavaScript(可能是jQuery库)来创建一个平滑的图片切换效果,其中图片会淡入淡出,为用户带来流畅的视觉体验。 首先,jQuery是一个轻量级的JavaScript库,它简化了HTML文档遍历、事件处理、动画以及...
通过这些API,我们可以根据需求实现更复杂的功能,如自动播放、无限循环等。 最后,为了确保在不同屏幕尺寸上的良好表现,我们需要根据屏幕宽度应用适当的CSS媒体查询,调整图片的大小和布局。这可以通过使用CSS预...
2. 图片滑动效果:平滑的图片滑动过渡,可以使用ViewPager或RecyclerView实现,配合PageTransformer实现酷炫的切换动画。 3. 图片缩放:支持手势缩放,可以利用Android的ScaleGestureDetector实现。 4. 图片预加载:...