c# – 在android中的相对布局上实现滑动和点击的最佳方法是什么?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 在android中的相对布局上实现滑动和点击的最佳方法是什么?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5024字,纯文字阅读大概需要8分钟。
内容图文
我正在创建一个相对布局,并希望添加单击以及滑动(触摸并在布局上移动指针以实时移动它)并检测左右滑动.到目前为止,我已尝试过以下代码.
public bool OnTouch(View v, MotionEvent e)
{
if (gestureDetector.OnTouchEvent(e))
{
//This is a Click
return true;
}
else
{
int initialTouchX = 0, initialTouchY = 0;
int newx = 0;
var x = v.Left;
switch (e.Action)
{
case MotionEventActions.Down:
{
_viewX = e.GetX();
_viewY = e.GetY();
initialTouchX = (int)e.RawX;
initialTouchY = (int)e.RawY;
break;
}
case MotionEventActions.Move:
{
var left = (int)(e.RawX - _viewX);
newx = left;
var right = (int)(left + v.Width);
var top = (int)(e.RawY - _viewY);
var bottom = (int)(top + v.Height);
v.Layout(left, top, right, bottom);
break;
}
case MotionEventActions.Up:
{
int lastX = (int)e.GetX();
int lastY = (int)e.GetY();
if ((x - newx) > 40)
{
//Detect Right Swipe
}
else if ((newx - x > 40))
{
//Detect Left Swipe
}
else
{
//Skip others
}
break;
}
}
}
return true;
}
我的gestureDetector.OnTouchEvent(e)代码
gestureDetector = new GestureDetector(this, new SingleTapUp());
class SingleTapUp : Android.Views.GestureDetector.SimpleOnGestureListener
{
public override bool OnSingleTapUp(MotionEvent e) {
// Toast.MakeText(this,, ToastLength.Long).Show();
return true;
}
}
我的代码在某些设备和模拟器上运行良好.但有时候不工作并且点击布局会自动移动(布局将自己置于触摸指针中心).我认为有些事情是错误的并导致了这个问题.你可以建议我做到最好/最标准的方法.任何帮助将不胜感激.
解决方法:
我以这种方式实现swype:
public class MainActivity : Activity, GestureDetector.IOnGestureListener
{
private GestureDetector _gestureDetector;
public bool OnDown(MotionEvent e)
{
return false;
}
public bool OnFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)
{
bool result = false;
int SWIPE_THRESHOLD = 80;
int SWIPE_VELOCITY_THRESHOLD = 80;
try
{
float diffY = e2.GetY() - e1.GetY();
float diffX = e2.GetX() - e1.GetX();
if (Math.Abs(diffX) > Math.Abs(diffY))
{
if (Math.Abs(diffX) > SWIPE_THRESHOLD && Math.Abs(velocityX) > SWIPE_VELOCITY_THRESHOLD)
{
if (diffX > 0)
{
//code for swipe right here
}
else
{
//code for swipe Left here
}
}
}
}
catch (Exception exception)
{
//exception.printStackTrace();
}
return result;
}
public void OnLongPress(MotionEvent e) {}
public bool OnScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY)
{
return false;
}
public void OnShowPress(MotionEvent e) {}
public bool OnSingleTapUp(MotionEvent e)
{
return false;
}
public override bool OnTouchEvent(MotionEvent e)
{
_gestureDetector.OnTouchEvent(e);
return false;
}
protected override void OnCreate (Bundle bundle)
{
base.OnCreate (bundle);
SetContentView (Resource.Layout.Main);
_gestureDetector = new GestureDetector(this);
}
}
对于ViewPager,您可以将页面与此页面转换重叠:
using System;
using Android.Views;
using Android.Support.V4.View;
namespace SomeName
{
public class SinkAndSlideTransformer : Java.Lang.Object, ViewPager.IPageTransformer
{
public void TransformPage(View view, float position)
{
if (position < -1 || position > 1)
{
view.Alpha = 0; // The view is offscreen.
}
else
{
view.Alpha = 1;
if (position < 0)
{
// 'Sink' the view if it's to the left.
// Scale the view.
view.ScaleX = 1 - Math.Abs (position);
view.ScaleY = 1 - Math.Abs (position);
// Set the translationX to keep the view in the middle.
view.TranslationX = view.Width * Math.Abs (position);
}
}
}
}
}
哪个会产生这种效果:
使用此适配器:
using System;
using System.Collections.Generic;
using Android.App;
using Android.Content;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
using Android.Support.V4.View;
using Square.Picasso;
namespace StaffPro
{
public class SlideshowPagerAdapter : PagerAdapter
{
List<Uri> _items = new List<Uri>();
private readonly Activity _context;
public SlideshowPagerAdapter (Activity context, List<Uri> items) : base()
{
_items = items;
_context = context;
}
public override int Count
{
get { return _items.Count; }
}
public override bool IsViewFromObject(View view, Java.Lang.Object _object)
{
return view == ((RelativeLayout) _object);
}
public override Java.Lang.Object InstantiateItem(ViewGroup container, int position)
{
var view = LayoutInflater.From (container.Context).Inflate (Resource.Layout.SlideshowViewPager, container, false);
ImageView imageView = view.FindViewById<ImageView> (Resource.Id.slideshowImageView);
Picasso.With(_context).Load(_items [position].ToString()).Into(imageView);
container.AddView(view);
return view;
}
public override void DestroyItem(ViewGroup container, int position, Java.Lang.Object _object)
{
container.RemoveView((View)_object);
}
}
}
并使用以下内容调用viewpages和适配器:
var viewPagerAdapter = new SlideshowPagerAdapter(Activity, some_Uri_images);
slideshowViewPager.Adapter = viewPagerAdapter;
slideshowViewPager.SetPageTransformer (true, new SinkAndSlideTransformer ());
您可以找到更多转换here.
还要记住,ViewPager有一个名为setPageMargin()的方法.该方法可以接收负值,这将使片段/视图彼此重叠.
您还可以在转换代码中使用view.Rotation来实现随机删除的照片和您想要的重叠效果.
如果您需要保留加载和显示的许多图像,请同时检查ViewPager.OffscreenPageLimit它将覆盖存储下一个和上一个项目的页面的默认缓存限制,但要注意高内存使用情况.
内容总结
以上是互联网集市为您收集整理的c# – 在android中的相对布局上实现滑动和点击的最佳方法是什么?全部内容,希望文章能够帮你解决c# – 在android中的相对布局上实现滑动和点击的最佳方法是什么?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。