- 浏览: 1225698 次
- 性别:
- 来自: 荆州
文章分类
- 全部博客 (396)
- Android 基础 (72)
- Java 基础 (42)
- Android(动画效果) (26)
- Android(自定义组件) (13)
- Android(手机服务) (38)
- Android(网络相关) (27)
- Android(多媒体) (12)
- Android(小技巧) (30)
- Android(用户界面) (39)
- 基础概念 (24)
- Android组件学习 (21)
- Android数据库相关 (11)
- 生活杂谈 (10)
- 调试技巧部分 (8)
- Sql Server相关 (1)
- Android(xml相关) (2)
- Android 开发 (12)
- 韩语学习 (4)
- Mac添加环境变量的三种方法 (1)
- iPhone开发 (1)
- Android Studio (1)
最新评论
-
ppfbsar:
下载网络文件到SD卡上 -
851228082:
好文!彻底理解单类型导入与按需导入的区别了。还有一点可以通过 ...
谈java的导入(import) -
麦田的设计者:
老乡啊
sqlite 数据库保存图片 -
sf_dream:
我要是读写list、map之类的集合呢
ObjectOutputStream和ObjectInputStream类的学习 -
xfyunyun:
博主,请问webview加载html字符串时怎么进行缓存处理呢 ...
WebView使用总结2(加载HTML内容形式的String)
内容如题:
1.SlideExample.java文件
2.SampleGuest.java文件
3.main.xml文件
4.程序所用到的anim中的几个xml文件内容
push_left_in.xml
push_left_out.xml
push_right_in.xml
push_right_out.xml
6.至于程序中所用到的图片,大家可以自己找几张,修改名称即可
1.SlideExample.java文件
package com.example; import android.app.Activity; import android.os.Bundle; import android.view.GestureDetector; import android.view.MotionEvent; import android.view.ViewGroup; public class SlideExample extends Activity { public ViewGroup container1, container2; private GestureDetector gestureDetector; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); // 监听屏幕动作事件 SampleGuest gestureListener = new SampleGuest(this); gestureDetector = new GestureDetector(gestureListener); container1 = (ViewGroup) findViewById(R.id.container1); container2 = (ViewGroup) findViewById(R.id.container2); } // called automatically, any screen action will Triggered it public boolean onTouchEvent(MotionEvent event) { if (gestureDetector.onTouchEvent(event)) return true; else return false; } }
2.SampleGuest.java文件
package com.example; import android.util.Log; import android.view.MotionEvent; import android.view.View; import android.view.GestureDetector.OnGestureListener; import android.view.animation.AnimationUtils; public class SampleGuest implements OnGestureListener { SlideExample se; private static final int SWIPE_MAX_OFF_PATH = 100; private static final int SWIPE_MIN_DISTANCE = 100; private static final int SWIPE_THRESHOLD_VELOCITY = 100; public SampleGuest(SlideExample se) { this.se = se; } // 用户轻触触摸屏,由1个MotionEvent ACTION_DOWN触发 public boolean onDown(MotionEvent e) { Log.d("TAG", "[onDown]"); return true; } // 用户按下触摸屏、快速移动后松开,由1个MotionEvent ACTION_DOWN, // 多个ACTION_MOVE, 1个ACTION_UP触发 // e1:第1个ACTION_DOWN MotionEvent // e2:最后一个ACTION_MOVE MotionEvent // velocityX:X轴上的移动速度,像素/秒 // velocityY:Y轴上的移动速度,像素/秒 public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH) return false; if ((e1.getX() - e2.getX()) > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) { se.container1.setAnimation(AnimationUtils.loadAnimation(se, R.anim.push_left_out)); se.container2.setVisibility(View.VISIBLE); se.container2.setAnimation(AnimationUtils.loadAnimation(se, R.anim.push_right_in)); se.container1.setVisibility(View.GONE); } else if ((e2.getX() - e1.getX()) > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) { se.container1.setVisibility(View.VISIBLE); se.container1.setAnimation(AnimationUtils.loadAnimation(se, R.anim.push_left_in)); se.container2.setAnimation(AnimationUtils.loadAnimation(se, R.anim.push_right_out)); se.container2.setVisibility(View.GONE); } return true; } // 用户长按触摸屏,由多个MotionEvent ACTION_DOWN触发 public void onLongPress(MotionEvent e) { Log.d("TAG", "[onLongPress]"); } // 用户按下触摸屏,并拖动,由1个MotionEvent ACTION_DOWN, 多个ACTION_MOVE触发 public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { Log.d("TAG", "[onScroll]"); return true; } // 用户轻触触摸屏,尚未松开或拖动,由一个1个MotionEvent ACTION_DOWN触发 // 注意和onDown()的区别,强调的是没有松开或者拖动的状态 public void onShowPress(MotionEvent e) { Log.d("TAG", "[onShowPress]"); } // 用户(轻触触摸屏后)松开,由一个1个MotionEvent ACTION_UP触发 public boolean onSingleTapUp(MotionEvent e) { Log.d("TAG", "[onSingleTapUp]"); return true; } }
3.main.xml文件
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:id="@+id/container"> <RelativeLayout android:layout_width="fill_parent" android:id="@+id/container1" android:layout_height="fill_parent" android:visibility="visible"> <ImageView android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@drawable/one" /> </RelativeLayout> <RelativeLayout android:layout_width="fill_parent" android:background="@drawable/gray" android:id="@+id/container2" android:visibility="gone" android:layout_height="fill_parent"> <ImageView android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@drawable/three" /> </RelativeLayout> </RelativeLayout>
4.程序所用到的anim中的几个xml文件内容
push_left_in.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="-100%p" android:toXDelta="0" android:duration="1000"/> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="100" /> </set>
push_left_out.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="0" android:toXDelta="-100%p" android:duration="1000" /> <alpha android:fromAlpha="1.0" android:toAlpha="1.0" android:duration="400" /> </set>
push_right_in.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="100%p" android:toXDelta="0" android:duration="1000"/> <alpha android:fromAlpha="1.0" android:toAlpha="1.0" android:duration="400" /> </set>
push_right_out.xml
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="0" android:toXDelta="100%p" android:duration="1000"/> <alpha android:fromAlpha="1.0" android:toAlpha="1.0" android:duration="400" /> </set>
6.至于程序中所用到的图片,大家可以自己找几张,修改名称即可
发表评论
-
自定义ProgressDialog
2013-04-21 15:58 1179就2段关键代码: <?xml version=&qu ... -
弹性 ScrollView
2013-04-21 15:14 1432CustomerScrollView.java: clas ... -
走马灯效果文字
2012-02-15 16:05 1914走马灯效果的代码,对Tex ... -
API DEMO中3D旋转Layout效果
2011-12-08 13:07 3036LayoutChange.java: package cn ... -
自定义Loading Dialog
2011-09-12 21:00 2734好久没有更新blog,这段时间忙着换工作的事情,现在赶紧的拾掇 ... -
关于旋转动画效果
2011-05-01 17:13 2266好久没有写过blog了,5.1还在继续劳动,:( 刚研究完一个 ... -
Dialog伸缩动画效果
2011-01-13 14:45 6616效果图: ViewScale.java: publ ... -
球体旋转Anim(主要学习点Matrix知识)
2010-12-09 20:20 2124这点Code主要对View重写进行球体旋转: 知识点: 1.重 ... -
Anim中实现Scale和Alpha操作ImageView
2010-12-09 19:51 2881针对这个动画效果的应用,可以了解如下几个知识点: 1.几种动画 ... -
Image的放大,缩小(zoom in,zoom out)
2010-09-15 10:51 3390package com.example; impor ... -
TextView中各种Interpolator的使用
2010-09-09 13:07 3563package net.blogjava.mobile.i ... -
点击button拖动效果
2010-09-09 10:05 1624这个简单的代码段可以熟悉getX(),getRawX()等方法 ... -
API中画arc的简单代码
2010-09-07 14:45 1548package com.test; import a ... -
文本抖动效果
2010-09-05 21:58 2889几句代码如下: Animation animation = ... -
球体运动效果
2010-08-14 22:42 1782看个效果图: 自定义的View: package ... -
关于Drawable动画效果的实现demo(参考ray的博客例子)
2010-08-12 23:09 3130直接上代码把,上面都写了很清楚的注释: package c ... -
一种动画2中不同实现方式(代码和xml)
2010-08-05 21:01 1472AnimTwo.java文件: package cn.co ... -
Activity之间切换的各种效果(遗憾没有3D的效果)
2010-08-05 19:25 7206下面的Demo是我找到的一个觉得用来在程序中进行Activit ... -
Layout之间3D切换效果Demo
2010-07-26 21:58 4135先上个效果图(跟自己Blog中的浏览图片的代码类似,不过是la ... -
ImageView点击透明度变化效果
2010-07-26 20:53 46421. ClickAlphaChange.java文件 pa ...
相关推荐
标题“图片实现滑动切换”所指的就是通过编程技术实现在Android设备上,用户可以左右滑动来浏览多张图片的功能。这种效果通常可以通过`ViewFlipper`组件来实现,这也是描述中提到的关键点。 `ViewFlipper`是Android...
1. **监听触屏事件**:这是实现滑动切换的基础,通过监听用户的触摸动作,可以捕捉到滑动操作。 2. **识别手势**:当触屏事件发生时,系统需要进一步判断用户是否执行了滑动手势。 3. **响应手势**:一旦识别出手势...
要实现滑动屏幕切换图片,需要使用 GestureDetector 来监听用户的滑动手势,通过 OnGestureListener 监听器来回调滑动事件,并在滑动事件中更改图片。 二、实现滑动屏幕切换图片的步骤 1. 创建一个 ImageView 控件...
结合`GestureDetector`,`ViewFlipper`可以在用户滑动时实现平滑的视图切换,提升应用的用户体验。通过以上内容,你应该对如何在Android中实现手势检测和使用`ViewFlipper`有了更深入的理解。在实际项目中,可以根据...
通过这种方式,我们成功地使用`ViewFlipper`和`GestureDetector`实现了轮播图功能,包括手动滑动和自动播放。这种实现方式简单易懂,且适用于大多数Android项目中的轮播图需求。在实际开发中,你还可以根据需要添加...
下面将详细探讨如何在Android应用中使用ViewFlipper来实现页面的滑动切换。 首先,我们需要了解ViewFlipper的基本结构。一个ViewFlipper可以包含多个子视图,如ImageView、TextView或自定义布局。在初始化时,...
ViewFlipper是Android SDK提供的一种布局容器,专门用于实现屏幕的滑动切换效果。本篇将深入探讨如何利用ViewFlipper来实现滑动屏幕功能,并提供相关的知识点。 **一、ViewFlipper基础** 1. **定义**:ViewFlipper...
- **手势监听**: 为了实现滑动切换,你需要监听用户的滑动手势,这通常通过实现 `GestureDetector.OnGestureListener` 接口并覆盖其方法来完成。你可以使用 ` GestureDetector.SimpleOnGestureListener` 作为基础类...
本篇将深入探讨如何利用ViewFlipper组件和GestureDetector类实现左右滑动切换视图的效果,这在主页面或多个内容区域展示的场景中非常常见。 ViewFlipper是Android提供的一个布局容器,它可以方便地在多个子视图之间...
标题"Listview的左右滑动实现"涉及到了如何在ListView中添加手势监听,使得用户可以通过左右滑动来切换Activity,提升用户体验。以下是对这个主题的详细解释: 一、ListView基本概念 ListView是Android SDK中的一个...
4. **监听滑动事件**: 如果希望用户可以通过手势滑动来切换视图,可以为ViewFlipper添加滑动监听器,例如使用`GestureDetector`来检测滑动手势。 通过上述步骤,我们可以实现音乐播放器界面中ViewFlipper的滑动...
总结,"android滑动标签"主要是通过TabLayout和ViewPager实现界面的滑动切换,提供简洁的用户交互。而"滑动切换Activity"虽然不是标准实践,但在特定场景下可以通过手势检测和Intent来实现。理解并熟练运用这些组件...
在Android应用开发中,"仿微信滑动标题栏导航"是一种常见的交互设计,它提供了类似微信App的用户体验,用户可以通过滑动屏幕顶部的标题栏来切换不同的页面或展示更多的操作选项。这种设计使得应用程序更加直观且易于...
在iOS和Android平台上,开发者可以通过监听`UIPanGestureRecognizer`(iOS)和`GestureDetector`(Android)来捕获用户的滑动操作。在JavaScript环境中,可以使用`touchstart`, `touchmove`, `touchend`等触摸事件来...
- **滑动切换**:如果希望支持滑动切换,可以使用手势识别器(如Android的`GestureDetector`或iOS的`UISwipeGestureRecognizer`),处理左右滑动的动作。 4. **动画效果**: - **过渡动画**:在切换选中状态时,...
- 可能自定义了一个监听器,通过监听滑动方向(水平或垂直)来决定页面的切换方向。 通过这份源码,开发者不仅可以学习如何实现基本的滑动操作,还能掌握如何结合动画使界面过渡更加流畅,提升应用的用户体验。这...
为了实现用户手动滑动切换图片,我们需要添加手势识别功能。可以使用`GestureDetector`类来捕获滑动事件。首先,创建一个`GestureDetector`的匿名内部类并重写相关方法: ```java GestureDetector gestureDetector ...
4. **监听滑动事件**:你可以使用GestureDetector来检测用户的滑动手势。创建一个GestureDetector实例,重写onDown(), onFling()等方法,当检测到合适的滑动事件时,调用ViewFlipper的相应方法。 ```java ...
该资源是一个针对Android应用开发的项目,主要实现了Android 4.0系统风格的左右滑动切换Tab的用户界面。在Android开发中,这样的设计模式常用于构建多面板、多视图的应用,允许用户通过平滑的手势在不同的功能区域...
`GestureDetector`提供了`onDown()`、`onScroll()`、`onFling()`等方法,通过重写这些方法,我们可以捕捉到用户手指在屏幕上的移动轨迹,从而实现滑动操作。 1. 创建`GestureDetector`实例: ```java ...