【Android】HorizontalScrollView内子控件横向拖拽

简介:

前言

网上ListView上下拖动的例子有,效果也很好,但是项目要横着拖的,只要硬着头皮自己写(主要是没找到合适的),参考文章1修改而来,分享一下。


声明

欢迎转载,但请保留文章原始出处:) 
博客园:http://www.cnblogs.com

农民伯伯: http://over140.cnblogs.com


正文

截图

   

 

代码

java

复制代码
public  class HoDragActivity  extends Activity {

     private LinearLayout main;

     private GestureDetector mGestureDetector;

    @Override
     public  void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
        setContentView(R.layout.main_cc);

        main = (LinearLayout) findViewById(R.id.main);

        bindDrapListener(R.id.myimage1);
        bindDrapListener(R.id.myimage2);
        bindDrapListener(R.id.myimage3);
        bindDrapListener(R.id.myimage4);
        bindDrapListener(R.id.myimage5);
        bindDrapListener(R.id.myimage6);
        bindDrapListener(R.id.myimage7);
        bindDrapListener(R.id.myimage8);
        bindDrapListener(R.id.myimage9);
        bindDrapListener(R.id.myimage10);
        bindDrapListener(R.id.myimage11);
        bindDrapListener(R.id.myimage12);

        mGestureDetector =  new GestureDetector( thisnew DrapGestureListener());
    }

     private View mDrapView;

     private  void bindDrapListener( int id) {
        View v = findViewById(id);
        v.setOnTouchListener(mOnTouchListener);
        v.setOnDragListener(mOnDragListener);
    }

     private OnTouchListener mOnTouchListener =  new OnTouchListener() {

        @Override
         public  boolean onTouch(View v, MotionEvent event) {
            mDrapView = v;

             if (mGestureDetector.onTouchEvent(event))
                 return  true;

             switch (event.getAction() & MotionEvent.ACTION_MASK) {
             case MotionEvent.ACTION_UP:

                 break;
            }

             return  false;
        }
    };

     private OnDragListener mOnDragListener =  new OnDragListener() {

        @Override
         public  boolean onDrag(View v, DragEvent event) {
             switch (event.getAction()) {
             case DragEvent.ACTION_DRAG_STARTED:
                 //  Do nothing
                 break;
             case DragEvent.ACTION_DRAG_ENTERED:
                v.setAlpha(0.5F);
                 break;
             case DragEvent.ACTION_DRAG_EXITED:
                v.setAlpha(1F);
                 break;
             case DragEvent.ACTION_DROP:
                View view = (View) event.getLocalState();
                 for ( int i = 0, j = main.getChildCount(); i < j; i++) {
                     if (main.getChildAt(i) == v) {
                         //  当前位置
                        main.removeView(view);
                        main.addView(view, i);
                         break;
                    }
                }
                 break;
             case DragEvent.ACTION_DRAG_ENDED:
                v.setAlpha(1F);
             default:
                 break;
            }
             return  true;
        }
    };

     private  class DrapGestureListener  extends SimpleOnGestureListener {
        @Override
         public  boolean onSingleTapConfirmed(MotionEvent e) {
             return  super.onSingleTapConfirmed(e);
        }

        @Override
         public  void onLongPress(MotionEvent e) {
             super.onLongPress(e);
            ClipData data = ClipData.newPlainText("", "");
            MyDragShadowBuilder shadowBuilder =  new MyDragShadowBuilder(
                    mDrapView);
            mDrapView.startDrag(data, shadowBuilder, mDrapView, 0);
        }

        @Override
         public  boolean onDown(MotionEvent e) {
             return  true;
        }
    }

     private  class MyDragShadowBuilder  extends View.DragShadowBuilder {

         private  final WeakReference<View> mView;

         public MyDragShadowBuilder(View view) {
             super(view);
            mView =  new WeakReference<View>(view);
        }

        @Override
         public  void onDrawShadow(Canvas canvas) {
            canvas.scale(1.5F, 1.5F);
             super.onDrawShadow(canvas);
        }

        @Override
         public  void onProvideShadowMetrics(Point shadowSize,
                Point shadowTouchPoint) {
             //  super.onProvideShadowMetrics(shadowSize, shadowTouchPoint);

             final View view = mView.get();
             if (view !=  null) {
                shadowSize.set(( int) (view.getWidth() * 1.5F),
                        ( int) (view.getHeight() * 1.5F));
                shadowTouchPoint.set(shadowSize.x / 2, shadowSize.y / 2);
            }  else {
                 //  Log.e(View.VIEW_LOG_TAG,
                
//  "Asked for drag thumb metrics but no view");
            }
        }
    }
}
复制代码

代码说明

1、 MyDragShadowBuilder主要用于缩放拖拽的ImageView,这里放大了1.5倍,而又不至于影响原控件,这里是放大两倍

2、这里是通过长按来唤起拖拽操作,所以监听了onLongPress

3、注意拖拽onDragListener是Android 3.0才新增的API

 

文章

Android Drag and Drop - Tutorial 

Android开发者指南-用户界面-拖放-Drag and Drop 

下载

 VogellaDraganddrop.zip

 

结束

欢迎交流!想做成拖动插入时自动两边挤开的效果,没弄出来,出来是抖动的效果。 


转载:http://www.cnblogs.com/over140/p/3599319.html

目录
相关文章
|
3月前
|
XML 存储 Java
浅谈Android的TextView控件
浅谈Android的TextView控件
50 0
|
4月前
|
XML 编解码 Android开发
安卓开发中的自定义视图控件
【9月更文挑战第14天】在安卓开发中,自定义视图控件是一种高级技巧,它可以让开发者根据项目需求创建出独特的用户界面元素。本文将通过一个简单示例,引导你了解如何在安卓项目中实现自定义视图控件,包括创建自定义控件类、处理绘制逻辑以及响应用户交互。无论你是初学者还是有经验的开发者,这篇文章都会为你提供有价值的见解和技巧。
65 3
|
5月前
|
前端开发 Android开发 开发者
安卓开发中的自定义视图:构建你的第一个控件
【8月更文挑战第26天】在安卓开发的浩瀚海洋中,自定义视图是一块充满魔力的乐土。它不仅是开发者展示创造力的舞台,更是实现独特用户体验的关键。本文将带你步入自定义视图的世界,从基础概念到实战应用,一步步教你如何打造自己的第一个控件。无论你是初学者还是有经验的开发者,这篇文章都将为你的开发之旅增添新的风景。
|
7月前
|
前端开发 API Android开发
25. 【Android教程】列表控件 ListView
25. 【Android教程】列表控件 ListView
263 2
|
6月前
|
XML 数据格式
Android-自定义三角形评分控件
Android-自定义三角形评分控件
56 0
|
7月前
|
XML Android开发 数据格式
Android基础控件介绍
Android基础控件介绍
|
7月前
|
Android开发
Android 自定义View 测量控件宽高、自定义viewgroup测量
Android 自定义View 测量控件宽高、自定义viewgroup测量
151 0
|
Android开发
android 横向滑动分类效果实现
android 横向滑动分类效果实现
android 横向滑动分类效果实现
|
1月前
|
搜索推荐 前端开发 API
探索安卓开发中的自定义视图:打造个性化用户界面
在安卓应用开发的广阔天地中,自定义视图是一块神奇的画布,让开发者能够突破标准控件的限制,绘制出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战技巧,逐步揭示如何在安卓平台上创建和运用自定义视图来提升用户体验。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开新的视野,让你的应用在众多同质化产品中脱颖而出。
57 19
|
1月前
|
JSON Java API
探索安卓开发:打造你的首个天气应用
在这篇技术指南中,我们将一起潜入安卓开发的海洋,学习如何从零开始构建一个简单的天气应用。通过这个实践项目,你将掌握安卓开发的核心概念、界面设计、网络编程以及数据解析等技能。无论你是初学者还是有一定基础的开发者,这篇文章都将为你提供一个清晰的路线图和实用的代码示例,帮助你在安卓开发的道路上迈出坚实的一步。让我们一起开始这段旅程,打造属于你自己的第一个安卓应用吧!
65 14