我试图实现一个简单的图像库,其中我有一次要在设备屏幕上显示的图像。当我们从左向右滑动屏幕时,它应该显示下一个图像。
为此,我实现了一个视图鳍状肢并为其添加了图像视图。
但我不知道如何捕捉那个滑动事件。
有谁能告诉我一个例子吗?如何滑动图像
如何滑动图像
回答
Gallery已弃用:(http://developer.android.com/reference/android/widget/Gallery。 html – 2012-07-24 00:51:07
您想使用ViewPager
可供Android Support Jar。这里是一个教程:http://thepseudocoder.wordpress.com/2011/10/05/android-page-swiping-using-viewpager/
你不想使用Gallery
作为一些建议,因为它不推荐使用。然而从documentation他们建议ViewPager
和HorizantleScrollView
相对容易地解决这个问题:
This class is deprecated.
This widget is no longer supported. Other horizontally scrolling widgets include
HorizontalScrollView and ViewPager from the support library.
IMO ViewPager并不适用于所有情况,它通常与片段相关联,如果你只想用一个单独的片段来滑动图片,每次滑动看起来都是过度的 – 2012-08-09 17:28:19
我需要为我的应用程序一样的东西,并使用了ViewPager
: http://blog.sqisland.com/2012/09/android-swipe-image-viewer-with-viewpager.html
以前我使用的ImageSwitcher
组合与GestureDetector
:http://blog.sqisland.com/2012/07/android-swipe-image-viewer.html
代码ViewPager
是简单得多,经验是好得多因为th当您的手指滑过屏幕时,图像会滑动。我直接创建了ImageView
,不需要片段。
这应该是被接受的答案!你刚刚用你的[解决方案](https://github.com/chiuki/android-swipe-image-viewer)并节省了我几小时的时间,非常感谢你! – Emzor 2016-02-09 10:25:26
你可以做到这样的,它切切实实的工作没有任何视图
public class Swipe extends Activity implements OnClickListener {
private static final int SWIPE_MIN_DISTANCE = 120;
//private static final int SWIPE_MAX_OFF_PATH = 250;
private static final int SWIPE_THRESHOLD_VELOCITY = 200;
final GestureDetector gdt = new GestureDetector(new GestureListener());
private GestureDetector gestureDetector;
ImageView img;
View.OnTouchListener gestureListener;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.swipe);
img = (ImageView)findViewById(R.id.imageView1swipe);
img.setOnTouchListener(new OnTouchListener() {
public boolean onTouch(final View view, final MotionEvent event) {
// TODO Auto-generated method stub
gdt.onTouchEvent(event);
//Log.i("Hello my Log 1","How dfgfd are you");
return true;
}
});
,并在您的.java声明此方法
private class GestureListener extends SimpleOnGestureListener {
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
float velocityY) {
Log.i("Hello my Log 2","How dfgfd are you");
if (e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE
&& Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
Log.i("dfsd", "Right to left");
return false; // Right to left
} else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE
&& Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
return false; // Left to right
}
if (e1.getY() - e2.getY() > SWIPE_MIN_DISTANCE
&& Math.abs(velocityY) > SWIPE_THRESHOLD_VELOCITY) {
return false; // Bottom to top
} else if (e2.getY() - e1.getY() > SWIPE_MIN_DISTANCE
&& Math.abs(velocityY) > SWIPE_THRESHOLD_VELOCITY) {
return false; // Top to bottom
}
return false;
}'
可能this会帮你安排所有的重击图片
请注意,你应该在这里发布答案的有用点,在这个网站上,或者你的岗位风险被删除了[参见常见问题解答,它提到的只是“比链接更多的答案”](http://stackoverflow.com/faq#deletion)。但愿只作为'参考'。答案应该独立,不需要链接。 – 2013-02-27 06:38:00
你也可以这样做,也可以不使用视图挡板
<?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">
<ImageView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_gravity="center"
android:gravity="center"
android:layout_margin="10dip"
android:id="@+id/image_place_holder"
/>
</RelativeLayout>
活动课
public class MainActivity extends Activity {
private Integer[] mImageIds = { R.drawable.img1, R.drawable.img2,
R.drawable.img3 };
private static final String DEBUG_TAG = "MainActivity ";
ImageView imageView;
float startXValue = 1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.gallery);
imageView = (ImageView) findViewById(R.id.image_place_holder);
imageView.setImageResource(mImageIds[num]);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
float endXValue = 0;
float x1 = event.getAxisValue(MotionEvent.AXIS_X);
int action = MotionEventCompat.getActionMasked(event);
switch (action) {
case (MotionEvent.ACTION_DOWN):
startXValue = event.getAxisValue(MotionEvent.AXIS_X);
return true;
case (MotionEvent.ACTION_UP):
endXValue = event.getAxisValue(MotionEvent.AXIS_X);
if (endXValue > startXValue) {
if (endXValue - startXValue > 100) {
System.out.println("Left-Right");
imageView.setImageResource(mImageIds[2]);
}
}else {
if (startXValue -endXValue> 100) {
System.out.println("Right-Left");
imageView.setImageResource(mImageIds[0]);
}
}
return true;
default:
return super.onTouchEvent(event);
}
}
}
我这是怎么实现的:
package com.demoimageslider;
import java.util.List;
import java.util.Vector;
import com.nineoldandroids.view.ViewHelper;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
public class MainActivity extends FragmentActivity {
private PagerAdapter mPagerAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.initialisePaging();
}
private void initialisePaging() {
List<Fragment> fragments = new Vector<Fragment>();
fragments.add(Fragment.instantiate(this, Tab1Fragment.class.getName()));
fragments.add(Fragment.instantiate(this, Tab2Fragment.class.getName()));
fragments.add(Fragment.instantiate(this, Tab3Fragment.class.getName()));
this.mPagerAdapter = new PagerAdapter(
super.getSupportFragmentManager(), fragments);
ViewPager pager = (ViewPager) super.findViewById(R.id.pager);
pager.setAdapter(this.mPagerAdapter);
pager.setPageTransformer(true, new ZoomOutPageTransformer());
}
public static class Tab1Fragment extends Fragment {
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (container == null) {
return null;
}
return (ImageView) inflater.inflate(R.layout.tab_frag1_layout,
container, false);
}
}
public static class Tab2Fragment extends Fragment {
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (container == null) {
return null;
}
return (ImageView) inflater.inflate(R.layout.tab_frag2_layout,
container, false);
}
}
public static class Tab3Fragment extends Fragment {
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (container == null) {
return null;
}
return (ImageView) inflater.inflate(R.layout.tab_frag3_layout,
container, false);
}
}
public static class PagerAdapter extends FragmentPagerAdapter {
private List<Fragment> fragments;
public PagerAdapter(FragmentManager fm, List<Fragment> fragments) {
super(fm);
this.fragments = fragments;
}
@Override
public Fragment getItem(int position) {
return this.fragments.get(position);
}
@Override
public int getCount() {
return this.fragments.size();
}
}
public static class ZoomOutPageTransformer implements
ViewPager.PageTransformer {
private static final float MIN_SCALE = 0.85f;
private static final float MIN_ALPHA = 0.5f;
public void transformPage(View view, float position) {
int pageWidth = view.getWidth();
int pageHeight = view.getHeight();
if (position < -1) { // [-Infinity,-1)
// This page is way off-screen to the left.
// view.setAlpha(0);
ViewHelper.setAlpha(view, 0);
} else if (position <= 1) { // [-1,1]
// Modify the default slide transition to shrink the page as
// well
float scaleFactor = Math.max(MIN_SCALE, 1 - Math.abs(position));
float vertMargin = pageHeight * (1 - scaleFactor)/2;
float horzMargin = pageWidth * (1 - scaleFactor)/2;
if (position < 0) {
// view.setTranslationX(horzMargin - vertMargin/2);
ViewHelper.setTranslationX(view, horzMargin - vertMargin
/2);
} else {
// view.setTranslationX(-horzMargin + vertMargin/2);
ViewHelper.setTranslationX(view, -horzMargin + vertMargin
/2);
}
// Scale the page down (between MIN_SCALE and 1)
// view.setScaleX(scaleFactor);
// view.setScaleY(scaleFactor);
ViewHelper.setScaleX(view, scaleFactor);
ViewHelper.setScaleY(view, scaleFactor);
// Fade the page relative to its size.
// view.setAlpha(MIN_ALPHA +
// (scaleFactor - MIN_SCALE)/
// (1 - MIN_SCALE) * (1 - MIN_ALPHA));
ViewHelper.setAlpha(view, MIN_ALPHA + (scaleFactor - MIN_SCALE)
/(1 - MIN_SCALE) * (1 - MIN_ALPHA));
} else { // (1,+Infinity]
// This page is way off-screen to the right.
// view.setAlpha(0);
ViewHelper.setAlpha(view, 0);
}
}
}
}
我用nineoldroids库,以支持在较旧的Android版本的效果。
您可以通过使用ViewPager延伸PagerAdapter ......这样
public class ImageAdapter extends PagerAdapter {
private Context context;
private int[] GalImages = new int[] {
R.drawable.cap8, R.drawable.cap2, R.drawable.cap3, R.drawable.cap1,R.drawable.cap5,
R.drawable.cap6, R.drawable.cap7, R.drawable.cap9,R.drawable.cap4,
R.drawable.cap10
};
ImageAdapter(Context context)
{
this.context=context;
}
@Override
public int getCount() {
return GalImages.length;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
ImageView imageView = new ImageView(context);
int padding = context.getResources().getDimensionPixelSize(R.dimen.activity_horizontal_margin);
imageView.setPadding(padding, padding, padding, padding);
imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
imageView.setImageResource(GalImages[position]);
container.addView(imageView, 0);
return imageView;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((ImageView) object);
}
}
XML代码......
<android.support.v4.view.ViewPager
android:id="@+id/mvieww"
android:layout_width="match_parent"
android:layout_height="match_parent" />
- 1. JavaFX:如何滑动图像
- 2. 如何滑动图像?
- 3. Android图像滑动图像
- 4. jQuery滑动图像?
- 5. Javascript图像滑动
- 6. 如何使用jQuery来滑动图像?
- 7. 如何移动滑块图像结外
- 8. 自动滑动图像。
- 9. 图像滑动视图
- 10. 如何在弹出图像时左右滑动图像
- 11. 如何在滑动图像时拉伸图像
- 12. 如何 - 图像滑块
- 13. 如何在图像滑块中制作滑动效果?
- 14. 如何修复负载上的滑动滑块跳跃图像
- 15. 在滑动手机7滑动图像滑动或轻弹
- 16. 不能用Orbit滑块滑动图像
- 17. 平滑滑动背景图像
- 18. 滑动滑块内的背景图像
- 19. 滑动时图像的平滑过渡
- 20. 滑动即可滑入新图像
- 21. Android平滑图像动画
- 22. 使用yii2滑动图像
- 23. javascript图像滑块启动
- 24. Xcode中的滑动图像
- 25. Sitecore上的滑动图像
- 26. 如何移动/从左边的图像滑动到右侧
- 27. 如何使用appIntro自动播放图像滑动
- 28. 使背景图像自动滑动
- 29. 图像动画和滑动以更改android中的图像?
- 30. 平滑图像
为什么要捕捉那个滑动事件? – 2011-02-24 07:35:10
我想抓住那个滑动事件,以便基于滑动我可以将图像从左到右或反之亦然 – WISH 2011-02-24 08:01:58