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

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

效果图如下:


[img]http://dl2.iteye.com/upload/attachment/0092/1235/dc35abad-4259-3c42-8d60-e901b2a587ce.png[/img]

我的实现分为了两种方法

第一、两个viewpager

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

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

[img]http://dl2.iteye.com/upload/attachment/0092/1251/5b352598-95db-3be2-88a8-8a462b91724e.png[/img]

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

第二、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;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值