【android】移植IOS视图响应陀螺仪交互行为
IOS有个很有趣味的特性:背景图片可以响应陀螺仪方向的变化,去改变X、Y轴上的值,从而让整个界面看着充满着灵性。具体步骤是:解锁苹果产品,在IOS7以上,摆动手势,观察桌面背景图片的变化。
刚好,我们的产品现在遇到了一个场景:标题栏以下,占据40%空间的是一张png图片,背景是一片星空,如果不给点交互,感觉太死板了
这时候想,如果把IOS这个特性移植到本场景中,作用对象是背景那个星空,那多美啊~
二话不说,跪求美工大哥把png图片的前景和背景分离,拿到两张图片,开搞~
实现之后的效果产品大哥也觉得很赞,就把这套方案共享出来了,调用很简单,一共三句:声明、注册、解注册。
本模块工作原理:监听加速器里的陀螺仪传感器,获取其在x、y轴上的偏移数据,换算成一个垂直、水平上的位移值,赋值给视图的x、y属性。
先来看下效果,比较渣,建议下载APK demo体验;源码地址:http://git.oschina.net/yso/IOSParallelView
一句话讲解陀螺仪xyz方向:以portrait屏幕方向为例,手机的左下角为原点,x轴:水平方向,越右越大;y轴:垂直方向,越高越大;z轴:屏幕对着你的方向,越近越大;
下面来说下具体的实现步骤:
准备工作
1:设置一个视图响应陀螺仪事件,最大移动的距离为30dp(举个例子);
2:设置视图宽高为:原始宽高 +2倍的30dp(用于左移和右移到极限都能看到图片)
3:把图片往屏幕的左上角扯30dp距离,(通过设置 x、y为-30dp)
ps:因此,我们设置x、y的范围是-60dp(再往左上角扯30dp)~0dp(往右下角扯了60dp)
接下来开始响应陀螺仪事件了
1:将陀螺仪在x、y轴上的数据拿到,互换x、y参数位置,传递给调用方
//为什么要互换 x,y;是因为陀螺仪在y轴上的左右倾斜数据,最终会反应在图片在水平位置上的变化;同理x轴上下倾斜反应在垂直位置上的变化
//为调用端统一坐标,我们在这里就做了调换,调用端按照正常的坐标系使用即可
2:调用端60dp* 拿到偏移数据*修正常量(0.02f挺好),变成在水平、垂直上的偏移量(我们规定为-30dp~30dp,总不能无限偏移吧。。)
3:将结果减去30dp(为什么-30dp是因为我们x、y初始就是-30dp,不是0),赋值在视图的x、y属性上。
4:没了。
调用超级简单,贴上代码
初始化里传入Context、要移动的视图、单向移动的最大距离;
在onResume里面注册传感器事件,开始监听陀螺仪
在onPause里面注销传感器事件
public class MainActivity extends AppCompatActivity {
ParallelViewHelper parallelViewHelper; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
parallelViewHelper = new ParallelViewHelper(this, findViewById(R.id.main_image_background));
} @Override
protected void onResume() {
super.onResume();
parallelViewHelper.start();
} @Override
protected void onPause() {
super.onPause();
parallelViewHelper.stop();
}
}
已知问题:
不能响应屏幕改变事件、不能在横屏上工作。因为现在的APK大部分都定死了方向为portrait,我就不做这方面的优化了。
解决思路:响应activity的onConfigChange事件,拿到屏幕旋转方向。
或者创建一个监听系统方向变化的类OrientationEventListener,在事件中拿到屏幕旋转的角度。
老规矩有啥建议欢迎一起交流~
【android】移植IOS视图响应陀螺仪交互行为的更多相关文章
- 提供给Android和iOS开发人员的UWP移植向导
(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:前几天微软发布了一个针对Android和iOS开发人员理解Windows Apps概念 ...
- js和android及ios交互
Android中Java和JavaScript交互 这种交互,Hybrid App 会用的比较多一点, 本文将介绍如何实现Java代码和Javascript代码的相互调用. Android提供了一个很 ...
- Android与IOS异同点对照(1)------ 显示
Android与IOS作为当前世界上最流行的两大移动端操作系统,都拥有无数的粉丝. 那么对于Android或者IOS的开发人员来说,这两个系统都拥有什么同样或者不同的地方那?如今让我们一起来了解一下A ...
- iOS 视图控制器转场详解
iOS 视图控制器转场详解 前言的前言 唐巧前辈在微信公众号「iOSDevTips」以及其博客上推送了我的文章后,我的 Github 各项指标有了大幅度的增长,多谢唐巧前辈的推荐.有些人问我相关的问题 ...
- GitHub Android 最火开源项目Top20 GitHub 上的开源项目不胜枚举,越来越多的开源项目正在迁移到GitHub平台上。基于不要重复造轮子的原则,了解当下比较流行的Android与iOS开源项目很是必要。利用这些项目,有时能够让你达到事半功倍的效果。
1. ActionBarSherlock(推荐) ActionBarSherlock应该算得上是GitHub上最火的Android开源项目了,它是一个独立的库,通过一个API和主题,开发者就可以很方便 ...
- ArcGIS Runtime SDKs v10.2.4最新(Android、iOS、OSX和.NET)
ArcGIS Runtime SDKs v10.2.4最新,它包含:Android.iOS.OS X和.NET四大平台,用户和开发人员可以登录Esri最新的SDK安装包.或者通过云盘下载(http:/ ...
- iOS与JS开发交互总结
hybrid.jpg 前言 Web 页面中的 JS 与 iOS Native 如何交互是每个 iOS 猿必须掌握的技能.而说到 Native 与 JS 交互,就不得不提一嘴 Hybrid. Hybri ...
- View Programming Guide for iOS ---- iOS 视图编程指南(二)---View and Window Architecture
View and Window Architecture 视图和窗口架构 Views and windows present your application’s user interface and ...
- View Programming Guide for iOS ---- iOS 视图编程指南(一)
Next About Windows and Views 关于窗口和视图 In iOS, you use windows and views to present your application’s ...
随机推荐
- 开源免费天气预报接口API以及全国所有地区代码[值得收藏]
国家气象局提供的天气预报接口 接口地址: http://www.weather.com.cn/data/sk/101010100.html http://www.weather.com.cn/data ...
- 使用synchronized(非this对象)同步代码块解决脏读问题
首先通过示例来学习验证多个线程调用同一个方法时随机的. package syn_out_asyn; import java.util.ArrayList; import java.util.List; ...
- JS-制作留言提交系统(支持ctrl+回车)
弹出键值说明: //console.log(ev.keyCode)//回车:13//ctrl:17 <!DOCTYPE html> <html> <head> &l ...
- Java可视化JVM监控软件
jdk自带.jdk安装目录下 1.JConsole 选择 不安全 可用不多 2.VisualVM
- 【Android】Android 发送短信和打电话的方法
发送短信的方法 有两种方法可以实现发送短信,其一是使用intent-startActivity,URI数据格式为"smsto:num",调用的action为Intent.ACTIO ...
- java类的初始化的默认值
转自:http://blog.csdn.net/abc5382334/article/details/18254517 对于类的成员变量 不管程序有没有显示的初始化,Java 虚拟机都会先自动给 ...
- java父类可以强制转化成子类吗?
转自:http://blog.csdn.net/ld422586546/article/details/9707997 Java中父类强制转换成子类的原则:父类型的引用指向的是哪个子类的实例,就能转换 ...
- 几种常用的SQL优化工具及方法
转自:http://blog.itpub.net/35489/viewspace-764856/ 1. sql 详细执行计划,主要检查驱动路径,索引是否合适:同一个pl/sql窗口连续执行即可:exp ...
- oneThink的ArticleController控制,详看
本人新手小白,看下 onethink 的 ArticleController , 它里面写的方法,和一些自己以后改进的方向: <?php namespace Home\Controller; c ...
- SQL中distinct的用法(转载)
1.作用于单列 2.作用于多列 3.COUNT统计 4.distinct必须放在开头 5.其他 在表中,可能会包含重复值.这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值.关键词 ...