基于方向传感器的一个小应用——指北针(高手勿喷)
注释比较多
http://www.iteye.com/topic/737999
android 重力感应的使用
http://blog.csdn.net/pku_android/article/details/7438745
Android的传感器编程小结
http://www.cnblogs.com/nio-nio/archive/2009/10/23/1588610.html
Android方向传感器实践——自己动手做水平尺
http://blog.csdn.net/tinya0913/article/details/6095307
http://disanji.net/2011/08/30/android%E6%B8%B8%E6%88%8F%E5%BC%80%E5%8F%91%E4%B9%8B%E5%B0%8F%E7%90%83%E9%87%8D%E5%8A%9B%E6%84%9F%E5%BA%94%E5%AE%9E%E7%8E%B0/
http://hi.baidu.com/lieal/blog/item/f8ec3fed7aa8a4ccb21cb128.html
http://hi.baidu.com/huareal/blog/item/c5179bc6ac566021e5dd3bf1.html
Android设备信息获取
android.os.Build 包
Log.d(TAG, "device name : " +Build.MODEL);
HTC a510e 传感器支持情况:
04-22 23:54:43.003: D/debug(12091): BMA150 3-axis Accelerometer
04-22 23:54:43.003: D/debug(12091): AK8973 3-axis Magnetic field sensor
04-22 23:54:43.003: D/debug(12091): AK8973 Orientation sensor
04-22 23:54:43.003: D/debug(12091): CM3602 Proximity sensor
04-22 23:54:43.003: D/debug(12091): CM3602 Light sensor
04-22 23:54:43.003: D/debug(12091): Gravity Sensor
04-22 23:54:43.003: D/debug(12091): Linear Acceleration Sensor
04-22 23:54:43.013: D/debug(12091): Rotation Vector Sensor
st18i 传感器支持情况:
04-23 00:18:25.314: D/debug(8972): BMA150 accelerometer
04-23 00:18:25.314: D/debug(8972): AK8975 Compass
04-23 00:18:25.314: D/debug(8972): AK8975 Compass Raw
04-23 00:18:25.314: D/debug(8972): AK8975 Magnetic Field
04-23 00:18:25.314: D/debug(8972): APDS9702 Proximity
04-23 00:18:25.314: D/debug(8972): Gravity Sensor
04-23 00:18:25.314: D/debug(8972): Linear Acceleration Sensor
04-23 00:18:25.314: D/debug(8972): Rotation Vector Sensor
引用
支持以下六种传感器:
加速度传感器 Accelerometer
地磁传感器 Magnetic field sensor
温度传感器 Temperature sensor
距离传感器 Proximity sensor
方向传感器 Orientation sensor
亮度传感器 Light sensor
http://madgoat.cn/2011/01/%E6%A3%80%E6%B5%8B%E6%89%8B%E6%9C%BA%E4%B8%AD%E7%9A%84sensor%E4%BC%A0%E6%84%9F%E5%99%A8%E7%B1%BB%E5%9E%8B/
Android 重力感应和屏幕旋转关系
http://www.apkcode.com/html/2011/interface_0218/1848.html
关于重力感应系统的详细解释
http://www.eoeandroid.com/thread-3105-1-1.html
Android重力感应模拟器实现与实例开发
http://wxmijl.blog.163.com/blog/static/13245928201062734631474/
传感器模拟器
http://code.google.com/p/openintents/downloads/detail?name=sensorsimulator-1.1.1.zip&can=2&q=
Android重力感应器Sensor编程
http://www.apkcode.com/html/2011/interface_0218/1848.html
Android opengl 立方体 多纹理
http://blog.csdn.net/one2zero/article/details/5895548
此例:2.3.3报错,解决后,无图
【Android】OpenGL 3D立方体多纹理贴图【附源码】
http://blog.sina.com.cn/s/blog_62f987620100p64x.html
http://www.eoeandroid.com/thread-44154-4-1.html53楼
请教如何在android中画出一个3D的圆球模型啊?
bluefuture 发表于 2010-11-22 21:18
DrawGlobe extends GLBase
{
private final float R = 0.5f;
private final int N = 50;
private final int T = 6;
private final int M = 9;
private final int NT = N * (T + M) - 1;
private final float Start = (float)Math.PI / 2;
private final float BASE = 2 * (float)Math.PI / N;
private final float ADD_1 = (float)Math.PI / T;
private final float ADD_2 = (float)Math.PI / (M - 1);
private final int LEN = 3 * NT;
private float an = 1;
private float[] coords;
FloatBuffer coordBuffer;
private void setCoords()
{
coords = new float[LEN];
int i, j, k, p, pos;
float angle = -ADD_1, rad, x1;
for(k = 0, p = 0; k < T; k++)
{
angle += ADD_1;
for (i = 0; i < N; i++, p++)
{
pos = p * 3;
rad = i * BASE + Start;
x1 = R * (float)Math.cos(rad);
coords[pos] = x1 * (float)Math.cos(angle);
coords[pos + 1] = R * (float)Math.sin(rad);
coords[pos + 2] = x1 * (float)Math.sin(angle);
}
}
float alpha = Start, beta = 0;
float y, r;
int ra = N /((M - 1) * 2);
for(k = 1; k < M; k++)
{
beta += ADD_2;
y = R * (float)Math.cos(beta);
for(j = 0; j < ra; j++,p++)
{
pos = p * 3;
rad = alpha - j * BASE;
coords[pos] = R * (float)Math.cos(rad);
coords[pos + 1] = R * (float)Math.sin(rad);
coords[pos + 2] = 0;
}
alpha -= ADD_2;
if(alpha == -Start)
break;
for(i = 0; i < N; i++, p++)
{
pos = p * 3;
rad = i * BASE;
r = R * (float)Math.sin(beta);
coords[pos] = r * (float)Math.cos(rad);
coords[pos + 1] = y;
coords[pos + 2] = r * (float)Math.sin(rad);
}
}
alpha = -Start;
for(i = 0; i < N/2; i++,p++)
{
pos = p * 3;
rad = i * BASE + alpha;
coords[pos] = R * (float)Math.cos(rad);
coords[pos + 1] = R * (float)Math.sin(rad);
coords[pos + 2] = 0;
}
}
public DrawGlobe(Context c)
{
super(c);
setCoords();
coordBuffer = makeFloatBuffer(coords);
}
private void initial(GL10 gl)
{
an += 1.0;
if(an == 360.0)
an = 0;
gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT);
gl.glLoadIdentity();
gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);
}
private void destroy(GL10 gl)
{
gl.glDisableClientState(GL10.GL_VERTEX_ARRAY);
}
@Override
protected void drawFrame(GL10 gl)
{
initial(gl);
draw(gl);
destroy(gl);
}
private void draw(GL10 gl)
{
gl.glEnable(GL10.GL_DEPTH_TEST);
gl.glColor4f(0.5f, 0, 1, 1);
gl.glViewport(0, 0, 480, 480);
gl.glRotatef(an, 0, 1f, 0);
gl.glRotatef(an, 1f, 1f, 0);
gl.glVertexPointer(3, GL10.GL_FLOAT, 0, coordBuffer);
gl.glDrawArrays(GL10.GL_LINE_LOOP, 0, NT);
}
}
这样就可以画出一个球了!
android 完整游戏源码(alignbody)
http://wanran.iteye.com/blog/1049401
引用
2.背景音乐的播放
3.mvc设计模式应用
4.sharedPerferenced数据保存
5.手机震动
6.基础的网络传输
浅谈Android中重力感应的实现方式
http://www.itivy.com/android/archive/2011/6/27/android-gravity-sensing.html
引用
在Android应用程序的开发中,占据主要地位的当属游戏的开发。我们在这篇文章中将会针对在游戏中需要用到的重力感应功能,来为大家详细分析Android重力感应的实现方法,以帮助大家解决相关问题。
Android中的很多游戏的游戏都使用了重力感应的技术,但其api demo却并没有重力感应的实例(不知道是不是我没找到,找到的朋友麻烦告诉我一下,谢谢),因为开发的需要,就研究了一下重力感应这方面,因为网上关于这方面的东西比较少,所以写出来跟大家交流一下,算是抛砖引玉吧。(ps.因为重力感应式需要真机才能测试的,所以,下面提供的demo程序只能在真机上跑。)
因为官方说明比较含糊难懂,我用最简单的方式讲一下Android重力感应系统的坐标系
以屏幕的左下方为原点(2d编程的时候,是以屏幕左上方为原点的,这个值得注意一下),箭头指向的方向为正。从-10到10,以浮点数为等级单位,想象一下以下情形:
手机屏幕向上(z轴朝天)水平放置的时侯,(x,y,z)的值分别为(0,0,10);
手机屏幕向下(z轴朝地)水平放置的时侯,(x,y,z)的值分别为(0,0,-10);
手机屏幕向左侧放(x轴朝天)的时候,(x,y,z)的值分别为(10,0,0);
手机竖直(y轴朝天)向上的时候,(x,y,z)的值分别为(0,10,0);
其他的如此类推,规律就是:朝天的就是正数,朝地的就是负数。利用x,y,z三个值求三角函数,就可以精确检测手机的运动状态了。
接下来,用最短的代码完成Android重力感应功能,程序效果就是在title上面输出x,y,z的值。
package com.ray.test;
import Android.app.Activity;
import Android.os.Bundle;
import Android.hardware.SensorManager;
import Android.hardware.Sensor;
import Android.hardware.SensorEventListener;
import Android.hardware.SensorEvent;
public class SensorTest extends Activity {
private SensorManager sensorMgr;
Sensor sensor = sensorMgr.getDefaultSensor
(Sensor.TYPE_ACCELEROMETER);
private float x, y, z;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
sensorMgr = (SensorManager)
getSystemService(SENSOR_SERVICE);
SensorEventListener lsn = new SensorEventListener() {
public void onSensorChanged(SensorEvent e) {
x = e.values[SensorManager.DATA_X];
y = e.values[SensorManager.DATA_Y];
z = e.values[SensorManager.DATA_Z];
setTitle("x="+(int)x+","+"y="+(int)y+","+"z="+(int)z);
}
public void onAccuracyChanged(Sensor s, int accuracy) {
}
};
//注册listener,第三个参数是检测的精确度
sensorMgr.registerListener(lsn, sensor,
SensorManager.SENSOR_DELAY_GAME);
}
}