指南针主要是通过方向传感器来获取方位的,使用传感器呢,我们主要用到SensorManager类和Sensor类,通过getSystemService(Context.SENSOR_SERVICE)来初始化SensorManager对象,通过getDefaultSensor(Sensor.TYPE_ORIENTATION)来初始化Sensor对象。在下边我们需要对传感器进行注册,注册方法registerListener(SensorEventListener listener, Sensor sensor,int samplingPeriodUs)的第一个参数我们需要实现这个接口并复写相应的方法,在方法onSensorChanged(SensorEvent event)中我们可以通过event.values[0]来获取方位,这个数值的方位是(正北:0/360 正东:90 正南:180 正西:270)我们获取的是0到360的数值,但是实际上这些数值对应的方位和现实中指南针的方位是对称的,也就是关于Z轴对称。因此我们经常采用-event.values[0]。然后整个轮盘转动我这里采用的是一个自定义的旋转动画来做的,接下来就直接上代码了。
源代码:(码云:https://gitee.com/zhanma/codes/qw28ndj0akcpvf65hl1rg41)
MainActivity:
data:image/s3,"s3://crabby-images/c8ec4/c8ec46fc4e70840f0c8609e77e673b0c58d8d109" alt=""
data:image/s3,"s3://crabby-images/985b5/985b5d27439a7cde4f49c5562eeb454169be8a98" alt=""
data:image/s3,"s3://crabby-images/2bea2/2bea248132c2b59711d3ca19ae72479e8b983207" alt=""
data:image/s3,"s3://crabby-images/2af73/2af73e01183456b7c5b944b2b9b5f527a17a8ecf" alt=""
DefinedRotateAnimation (自定义旋转动画):
data:image/s3,"s3://crabby-images/d2640/d264018dff49b617cda1f52816eb8fada01eb02b" alt=""
data:image/s3,"s3://crabby-images/cce0a/cce0afaa3abe5ae2ac7afd95cf87f13ec74745d2" alt=""
MainActivity中44行提到一个bringToFront(),这个方法用来把控件调到前景,因为我在指南针中设置了一个(TextView)指标,方便看出来当前的转到正中央的数值是多少。然后TextView控件和ImageView正好后者把前者覆盖了,因此调用此方法把它调到上一层。自定义动画这块用到initialize方法,用来初始化动画,applyTransformation方法用来实现动画变形(也就是实现动画的效果)
运行截图:
data:image/s3,"s3://crabby-images/75341/7534122d3016d691bbfcc6794e0a9ecf53ff0dff" alt=""
data:image/s3,"s3://crabby-images/8c68c/8c68cbff5d07166092ecb98b4b11758363272ee9" alt=""
由于模拟器不方便测试这方向传感器,所以我就使用真机调试,上面的运行截图都是从真机上截图下来的。
以上是关于Android指南针的制作。
网友评论