- 浏览: 96644 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
sincerehui:
android二维码的编码与解码(图片解码与摄像头解码) -
nyh1006:
学习一下!
UIScrollView循环滚动 -
bravewly:
为啥扫不出结果呢?是我扫的方式不对么?
android二维码的编码与解码(图片解码与摄像头解码) -
messigoogle:
我说您这个也是跟eoe上的差不多吧,加载的Assert中的图片 ...
android瀑布流 -
gundumw100:
LazyScrollView是偶写的。欢迎使用。呵呵。http ...
android瀑布流
看那些iPhone的view的切换效果非常帅,今天研究了一下从一个view到另一个view的切换翻转的效果,现在和大家分享一下
我先重写了Animation类,然后在类里先写一个接口,用来传递动画进度的
/** 用于监听动画进度。当值过半时需更新的内容。 */ private InterpolatedTimeListener listener; public void setInterpolatedTimeListener(InterpolatedTimeListener listener) { this.listener = listener; } /** 动画进度监听器。 */ public static interface InterpolatedTimeListener { public void interpolatedTime(float interpolatedTime); }
写实例方法,保存view的中心坐标和需要的动画类型
public RotateAnimation(float cX, float cY, boolean type) { centerX = cX; centerY = cY; this.type = type; // 设置动画时长 setDuration(DURATION); }
再在initialize方法中初始化Camera
@Override public void initialize(int width, int height, int parentWidth, int parentHeight) { // 在构造函数之后、applyTransformation()之前调用本方法。 super.initialize(width, height, parentWidth, parentHeight); camera = new Camera(); }
最后在applyTransformation方法中实现动画效果
@Override protected void applyTransformation(float interpolatedTime, Transformation transformation) { // interpolatedTime:动画进度值,范围为0~1,0.5为正好翻转一半 if (listener != null) { listener.interpolatedTime(interpolatedTime); } float from = 0.0f, to = 0.0f; if (type == ROTATE_DECREASE) { from = 0.0f; to = 180.0f; } else if (type == ROTATE_INCREASE) { from = 360.0f; to = 180.0f; } // 旋转的角度 float degree = from + (to - from) * interpolatedTime; boolean overHalf = (interpolatedTime > 0.5f); if (overHalf) { // 翻转过半的情况下,为保证数字仍为可读的文字而非镜面效果的文字,需翻转180度。 degree = degree - 180; } // 旋转深度 float depth = (0.5f - Math.abs(interpolatedTime - 0.5f)) * DEPTH_Z; final Matrix matrix = transformation.getMatrix(); camera.save(); // 深度——》相当于与屏幕的距离 camera.translate(0.0f, 0.0f, depth); // 以x轴旋转 // camera.rotateX(degree); // 以y轴旋转 camera.rotateY(degree); camera.getMatrix(matrix); camera.restore(); if (DEBUG) { if (overHalf) { matrix.preTranslate(-centerX * 2, -centerY); matrix.postTranslate(centerX * 2, centerY); } } else { // 确保图片的翻转过程一直处于组件的中心点位置 /* * preTranslate是指在setScale前平移,postTranslate是指在setScale后平移,它们参数是平移的距离, * 而不是平移目的地的坐标! * 由于缩放是以(0,0)为中心的,所以为了把界面的中心与(0,0)对齐,就要preTranslate(-centerX, * -centerY),setScale完成后, 调用postTranslate(centerX, * centerY),再把图片移回来,这样看到的动画效果就是activity的界面图片从中心不停的缩放了 * 注:centerX和centerY是界面中心的坐标 */ matrix.preTranslate(-centerX, -centerY); matrix.postTranslate(centerX, centerY); } }
其中如果camera.rotateX(degree)这样是以x轴翻转,camera.rotateY(degree)是以y轴翻转。
这样就写完RotateAnimation类了
下面让我们来看一下MainActivity类,是怎么调用的
先求出view的中心坐标
float cX = m_main_rl.getWidth() / 2.0f; float cY = m_main_rl.getHeight() / 2.0f;
然后初始化RotateAnimation
rotateAnim = new RotateAnimation(cX, cY,RotateAnimation.ROTATE_DECREASE);
然后在动画运行到一半的时候做一些操作就行了,我这里偷懒就是把一个view隐藏把另一个view显示出来,你们可以addview和removeview。
@Override public void interpolatedTime(float interpolatedTime) { // 监听到翻转进度过半时,更新txtNumber显示内容。 if (enableRefresh && interpolatedTime > 0.5f) { setHint(); enableRefresh = false; } } public void setHint() { m_login_ll.setVisibility(View.GONE); m_option_ll.setVisibility(View.GONE); if (btn_id == R.id.hz_login_btn) { m_option_ll.setVisibility(View.VISIBLE); } else if (btn_id == R.id.hz_logout_btn) { m_login_ll.setVisibility(View.VISIBLE); } }
这样从一个view到另一个view的翻转效果就实现了,其实方法很简单。
发表评论
-
实现ScrollView的嵌套
2012-12-27 10:39 2162今天忽然需要写两个ScrollView嵌套,如: &l ... -
Android4.0新的SDK新特性 (汉化)
2012-10-31 15:40 1352Android 4.0 是一次重要的平台发布版,为用户和 ... -
Fragments (Android官方文档中文版)
2012-10-30 15:44 916原作者为: 苍山。感谢他分享的内容 概述 ... -
android瀑布流
2012-10-26 10:54 2488今天研究了一下瀑布流,来说一下我实现它的方法。 看一下 ... -
android二维码的编码与解码(图片解码与摄像头解码)
2012-10-24 17:43 3796今天上网找了找可以从图片解析二维码 ,而不是从摄像头,找了半天 ... -
Android 连接WIF获取的信息剖析
2012-10-10 13:48 1128Android的参数大致分成两块:系统服务参数和平台系统 ... -
android使用字体库更改字体
2012-07-27 15:34 1394TextView tv = (TextView) thi ... -
Android代码混淆的实践
2012-07-11 12:46 932开发 apk 的时候当然要考虑保护好自己的代码,Android ... -
给Android的音量按钮添加监听事件
2012-07-09 17:02 1369@Override public boolean onK ... -
去掉listview背景变黑和顶底部边缘模糊
2012-06-29 17:24 1182listview在滚动是背景变黑:android:cacheC ... -
Android 在OnCreate()中获取控件高度与宽度
2012-06-20 17:01 2923试过在OnCreate()中获取控件高度与宽度的童鞋都知道,g ... -
android EditText插入字符串到光标所在位置
2012-03-07 14:01 2190EditText mEditText = (EditText) ... -
android tabactivity view切换edittext不弹出软键盘的解决方案
2011-12-21 12:03 2136public void onFocusChange(View ... -
更改CheckBox的样式
2011-12-13 08:43 2393首先在styles.xml添加如下的自定义样式: <s ... -
Android中RatingBar的自定义效果
2011-11-16 10:14 1532有时候android系统提供给我们的ratingbar效果 ... -
TabHost点击按钮布局改变
2011-11-15 09:48 1061main.xml <?xml version=&quo ... -
android获得控件在屏幕中的绝对坐标
2011-11-10 12:56 2613int[] location = new int[2] ; ... -
手势识别
2011-11-10 09:29 885[功能] 何为手势识别? 比如:你在屏幕上从左至右划出的一个动 ... -
Android px和dip以及sp的区别及转换代码
2011-11-09 16:11 1632/** * 根据手机的分辨率从 dp 的单位 转成为 px ... -
android获取屏幕长宽,status bar高度,设置全屏显示
2011-11-09 16:08 1617//获取屏幕长宽 WindowManager wm = ...
相关推荐
该源码来自源码天堂android源码频道的,源码实现了类似iphone的两个视图切换翻转动画Animation,看那些iPhone的view的切换效果非常帅,今天研究了一下从一个view到另一个view的切换翻转的效果,现在和大家分享一下。
"iPhone范例代码,翻转动画特效"这个主题聚焦于如何在iPhone应用中实现一种常见的动画效果——翻转效果。这种效果通常用于界面元素的切换,例如卡片翻转或者视图翻转,给人一种立体感和动态交互的体验。 苹果的...
"(0166)-iOS/iPhone/iPAD/iPod源代码-视图切换(View Transition)-Flip View"这个资源包专注于一种特殊的视图切换效果——Flip View,它模仿了Flipboard应用中的翻页效果,这种效果可以应用于页面切换、图片...
在iOS 4.0及更高版本中,苹果引入了`UIViewAnimationTransitionFlipFromLeft`和`UIViewAnimationTransitionFlipFromRight`这两个枚举值,它们可以方便地实现翻转效果。 接下来,我们将在`UIViewController`之间进行...
在Android开发中,为了提供与iOS设备相似的用户体验,开发者经常需要实现仿iPhone风格的界面元素,例如翻页效果。本资源提供了一个这样的组件——一个仿iPhone风格的翻页控件,包括源码和Jar包,供学习者参考和使用...
视图过渡是指在两个或多个视图之间平滑地切换,为用户提供流畅的导航体验。iOS提供多种方法来实现视图切换,包括`UIStoryboardSegue`、`presentViewController:animated:completion:`和`pushViewController:animated...
首先,我们要了解iOS中的转场动画主要依赖于`UIViewControllerTransitioningDelegate`和`UIViewControllerAnimatedTransitioning`这两个协议。`UIViewControllerTransitioningDelegate`允许你自定义一个控制器的呈现...
在`ObjectC_UIRotate`这个项目中,我们可以看到作者是如何实现界面横竖屏切换的。通常,源代码会包含以下关键部分: - 重写UIViewController的代理方法,如前所述,控制旋转行为。 - 使用Auto Layout定义视图的约束...
如果想要实现更个性化的页面切换,我们还可以使用`UIViewController`的`presentViewController:animated:completion:`和`dismissViewControllerAnimated:completion:`方法,这两个方法可以用来呈现和隐藏控制器,...
例如,效果一可能是一个简单的视图旋转动画,通过`ObjectAnimator.ofFloat(view, "rotation", startAngle, endAngle)`来实现,其中`startAngle`和`endAngle`分别是动画开始和结束时的角度。效果二可能包含视图的缩放...
- 在旋转切换图片时,我们会使用CATransform3DMakeRotation来设置3D旋转,实现图片在视图中的翻转效果。 4. **CAAnimation**: - CAAnimation是Core Animation中的动画类,用于创建各种动画效果。 - 我们可以...
例如,以下代码展示了如何在两个视图控制器之间创建一个立方体旋转的过渡效果: ```swift import QuartzCore let transition = CATransition() transition.type = kCATransitionCube transition.subtype = ...
7. **布局嵌套**: 开关可能是一个包含多个子视图的复合视图,如一个背景视图、一个滑块视图和两个状态指示图标。这需要通过布局管理器(如LinearLayout或ConstraintLayout)来组织。 8. **状态保存与恢复**: 为了...
在本例中,开发者可能创建了两个不同的图像:一个无箭头的普通状态,另一个带有箭头的选中状态。通过监听TabBar的选中事件,可以动态地改变TabBarItem的显示状态,实现箭头的出现和消失动画。 其次,为了实现动画...
你需要实现两个方法:`pageViewController(_:viewControllerBefore:)`和`pageViewController(_:viewControllerAfter:)`,分别返回当前页面的前一个和后一个视图控制器。这些视图控制器应该包含你的页面内容,例如...
12.1 图形世界的两个视图 304 12.2 本章的绘图应用程序 305 12.3 Quart绘图方法 305 12.3.1 Quartz 2D的图形上下文 305 12.3.2 坐标系 306 12.3.3 指定颜色 307 12.3.4 在上下文中绘制图像 308 12.3.5 绘制形状:...
- 实现`UINavigationControllerDelegate`协议,通过`navigationController:animationControllerForOperation:fromViewController:toViewController:`方法返回自定义的动画控制器。 6. **注意权限问题** - 自定义...
使用这两个XML文件,可以通过以下方式实现Zoom In和Zoom Out的过渡动画: ```java overridePendingTransition(R.anim.zoomin, R.anim.zoomout); ``` #### 二、Android菜单动画 在本节中讨论的是基于Android ...