Androidの解决ViewFlipper与ScrollView滑动响应事件拦截的问题

        Androidの解决ViewFlipper与ScrollView滑动响应事件拦截的问题

1.  使用ViewFlipper作为水平滑动容器;需要使用ScrollView作为垂直滑动容器。
   Android ViewFlipper添加ScrollView后不能滑动了原因是因为activity没有处理滑动效果。  网上都说是 重写
 public boolean dispatchTouchEvent(MotionEvent ev) {
                // TODO Auto-generated method stub
                super.dispatchTouchEvent(ev);
                return gestureDetector.onTouchEvent(ev);
     }
 其实该方法要在 scrollview中实现,具体看下面。。不是写在Activity中
 
  这里是主newslist_contentactivity_viewflipper.xml内容了
<pre name="code" class="html"><?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#EDE4D6"
    android:orientation="vertical" >
   <ViewFlipper
        android:id="@+id/viewflipper"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:clickable="true"
        android:layout_below="@id/linearLayout1">
   </ViewFlipper>
</RelativeLayout>
 但是我又添加了另一个xml 
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#EDE4D6"
    android:orientation="vertical" >

   <com.blueberry.xinli.widget.FriendlyScrollView
        android:id="@+id/yilincontent_scroll"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:scrollbars="none" > 
            <RelativeLayout
                android:id="@+id/layout_title_textview"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:layout_marginLeft="13dip"
                android:layout_marginTop="20dip"
                android:orientation="vertical" >

                <TextView
                    android:id="@+id/ntitle_textview"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="5dip"
                    android:text="@string/yilin_top_left_text"
                    android:textColor="#ffdc6a86"
                    android:textSize="25sp" />
                <!-- android:layout_centerHorizontal="true" -->

                <TextView
                    android:id="@+id/nfrom_textview"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_below="@id/ntitle_textview"
                    android:layout_marginTop="8dip"
                    android:text="@string/yilin_top_left_text"
                    android:textColor="@color/main_news_item_title"
                    android:textSize="18sp" />
            </RelativeLayout>
     </com.blueberry.xinli.widget.FriendlyScrollView> 
</RelativeLayout>
这里我自定义的一个 scrollview 了。。。

需要实现一个自定义的scrollview类了
public class FriendlyScrollView extends ScrollView {  
    GestureDetector gestureDetector;  
    public FriendlyScrollView(Context context) {  
        super(context);  
        gestureDetector = gestureDetector; 
    }  
   
    public FriendlyScrollView(Context context, AttributeSet attrs) {  
        super(context, attrs);  
    }  
   
    public FriendlyScrollView(Context context, AttributeSet attrs, int defStyle) {  
        super(context, attrs, defStyle);  
    }  
   
    public void setGestureDetector(GestureDetector gestureDetector) {  
        this.gestureDetector = gestureDetector;  
    }  
   
    @Override  
    public boolean onTouchEvent(MotionEvent event) {  
        super.onTouchEvent(event);  
        return gestureDetector.onTouchEvent(event);  
    }  
   
    @Override  
    public boolean dispatchTouchEvent(MotionEvent ev){  
        gestureDetector.onTouchEvent(ev);  
        super.dispatchTouchEvent(ev);  
        return true;  
    }   
}  

由于ViewFlipper在外,ScrollView在内,因此一般的做法是定义一个手势响应类来处理响应事件,并将响应事件的处理交给内层的ScrollView。
yilincontent_scroll = (FriendlyScrollView)v.findViewById(R.id.yilincontent_scroll);
yilincontent_scroll.setOnTouchListener(new listener());
yilincontent_scroll.setGestureDetector(gestureDetector);

记得在这里添加yilincontent_scroll.setGestureDetector(gestureDetector); 否则会有空指针异常的。。
一下就是如何在Activity中实现手势左右滑动了,要去实现了,这里不做具体内容了。

解决问题关键地点:
自定义一个scrollview,, 重写那个dispatchTouchEvent 方法即可。。


2 .源码下载
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ViewFlipper是Android中的一个ViewGroup,可以用于实现视图的轮播、广告轮播等效果。以下是一个简单的示例,实现ViewFlipper的左右滑动切换图片效果: 1. 在XML布局文件中加入ViewFlipper组件,并添加ImageView子组件作为要轮播的图片。 ```xml <ViewFlipper android:id="@+id/viewFlipper" android:layout_width="match_parent" android:layout_height="match_parent"> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/image1"/> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/image2"/> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/image3"/> </ViewFlipper> ``` 2. 在Java代码中获取ViewFlipper组件,并设置动画效果。 ```java ViewFlipper viewFlipper = findViewById(R.id.viewFlipper); // 设置切换动画 viewFlipper.setInAnimation(this, android.R.anim.slide_in_left); viewFlipper.setOutAnimation(this, android.R.anim.slide_out_right); // 设置轮播时间间隔 viewFlipper.setFlipInterval(3000); // 启动自动轮播 viewFlipper.setAutoStart(true); ``` 在上述代码中,我们使用了Android自带的两种动画效果:slide_in_left和slide_out_right,这两种动画效果可以实现ViewFlipper的左右滑动切换图片效果。同时,我们还设置了轮播时间间隔为3秒,并启动了自动轮播。 最后,我们需要注意的是,如果我们想要在ViewFlipper中添加更多的图片,只需要在XML布局文件中添加更多的ImageView子组件即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值