当前位置: 首页 > 编程笔记 >

Android HorizontalScrollView内子控件横向拖拽实例代码

饶德本
2023-03-14
本文向大家介绍Android HorizontalScrollView内子控件横向拖拽实例代码,包括了Android HorizontalScrollView内子控件横向拖拽实例代码的使用技巧和注意事项,需要的朋友参考一下

前言

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

正文

截图

实现代码:

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(this, new 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 HorizontalScrollView内子控件横向拖拽实例,欢迎交流,有需要参考下。

 类似资料:
  • 本文向大家介绍js实现控制文件拖拽并获取拖拽内容功能,包括了js实现控制文件拖拽并获取拖拽内容功能的使用技巧和注意事项,需要的朋友参考一下 在用户拖拽文件到浏览器的某个元素上时,js可以监听到与拖拽相关的事件,并对拖拽结果进行处理,本文讨论下和拖拽文件相关的一些问题,不过没有处理太多关于兼容性的问题。 拖拽事件 js能够监听到拖拽的事件有drag、dragend、dragenter、dragexi

  • 本文向大家介绍完美的js div拖拽实例代码,包括了完美的js div拖拽实例代码的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了完美的js div拖拽实例代码,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍oracle横向纵向求和代码实例,包括了oracle横向纵向求和代码实例的使用技巧和注意事项,需要的朋友参考一下 有一张工资表SALARY如下, (NO 员工编号 ,MONEY 工资) NO    NAME     ITEM       MONEY 001    张三        工资        80 001    张三        补贴        86 001    张

  • 本文向大家介绍js实现鼠标拖拽缩放div实例代码,包括了js实现鼠标拖拽缩放div实例代码的使用技巧和注意事项,需要的朋友参考一下 封装为了jq插件,如下 drag.js html文件 以上所述是小编给大家介绍的js实现鼠标拖拽缩放div详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对呐喊教程网站的支持!

  • 本文向大家介绍WPF实现控件拖动的示例代码,包括了WPF实现控件拖动的示例代码的使用技巧和注意事项,需要的朋友参考一下 实现控件拖动的基本原理是对鼠标位置的捕获,同时根据鼠标按键的按下、释放确定控件移动的幅度和时机。 简单示例: 在Grid中有一个Button,通过鼠标事件改编Button的Margin属性,从而改变Button在Grid中的相对位置。 为Button控件绑定三个事件:鼠标按下、鼠

  • 本文向大家介绍Android条目拖拽删除功能实例代码,包括了Android条目拖拽删除功能实例代码的使用技巧和注意事项,需要的朋友参考一下 项目中需求,要做条目条目拖拽删除效果,实际效果和QQ消息删除一样,侧滑有制定和删除。 效果图 第一步效果图 1.0自定义控件 SwipeLayout 继承FrameLayout重写里面三个构造方法,分别调用initView(). 2.0在布局中使用自定义控件