当前位置: 代码迷 >> Android >> 2013.12.13 ——— android开发实例之焦点图成效
  详细解决方案

2013.12.13 ——— android开发实例之焦点图成效

热度:61   发布时间:2016-04-28 07:09:49.0
2013.12.13 ——— android开发实例之焦点图效果
2013.12.13 ——— android开发实例之焦点图效果

效果图如下:




我的实现分为了两种方法

第一、两个viewpager

放眼一看,不就是两个viewpager么?就先用两个viewpager来实现了,但是做完之后发现了一个问题,viewpager默认是一屏的宽度,无法修改,这下搞不定了,迅速google,找到了一个自定义viewpager的解决方法,[url] https://gist.github.com/devunwired/8cbe094bb7a783e37ad1[/url]

这个可以实现一行显示多张图片的viewpager,效果如下



但是总是感觉不理想,所以又采取了第二种方法

第二、Gallery+Viewpager

代码就不贴了,后面给出源码,说一下我遇到的问题
1、gallery没有选中的图片变成灰色
mGly.setUnselectedAlpha(0.3f);

2、gallery选中的图片加边框
我在item的ImageView外面套了一层LinearLayout,这样改变LinearLayout的背景就可以了
if(position==mGly.getSelectedItemPosition()){                tHolder.mLin.setBackgroundColor(Color.RED);            }else{                tHolder.mLin.setBackgroundColor(Color.TRANSPARENT);            }

3、gallery滑动过快过多的问题

从网上搜了很多 大致有3中方法

首先都需要自定义Gallery,重写onFling方法

3.1、短距离滑动实现滚动
@Override      public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,              float velocityY) {          int kEvent;          if (isScrollingLeft(e1, e2)) {           // Check if scrolling left           kEvent = KeyEvent.KEYCODE_DPAD_LEFT;          } else {           // Otherwise scrolling right           kEvent = KeyEvent.KEYCODE_DPAD_RIGHT;          }          onKeyDown(kEvent, null);          return true;     }          private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2) {          return e2.getX() > e1.getX();      } 


3.2、降低滑动的速率
@Override    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {         return super.onFling(e1, e2, velocityX/3, velocityY);    }


3.3、
@Override    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {        return false;    }


4、滑动viewpager,gallery滑动无动画
刚开始我采用的是
mGly.setSelection(position);

没有动态效果
后来修改如下:
if(mGlyPosition > position){            mGly.onKeyDown(KeyEvent.KEYCODE_DPAD_LEFT, null);        }else if(mGlyPosition < position){            mGly.onKeyDown(KeyEvent.KEYCODE_DPAD_RIGHT, null);        }        mGlyPosition = position;



  相关解决方案