java中窗体怎么设置方位,java – 无论屏幕方向如何,我如何获得正确的方位(磁方向)?...

无论当前的屏幕方向(横向或纵向),我都希望获得当前的磁性方向.

这是我目前采用的方法,我不想使用(短):

mSensorManager.getDefaultSensor(Sensor.TYPE_ORIENTATION);

private SensorEventListener sensorEventListener = new SensorEventListener() {

public void onSensorChanged(SensorEvent event) {

/* Get measured value */

float current_measured_bearing = (float) event.values[0];

/* Compensate device orientation */

switch (((WindowManager) getSystemService(WINDOW_SERVICE))

.getDefaultDisplay().getRotation()) {

case Surface.ROTATION_90:

current_measured_bearing = current_measured_bearing + 90f;

break;

case Surface.ROTATION_180:

current_measured_bearing = current_measured_bearing - 180f;

break;

case Surface.ROTATION_270:

current_measured_bearing = current_measured_bearing - 90f;

break;

}

但最后一部分肯定是错的!在这种情况下,如何正确使用较新的方法getRotationMatrix()? (与方向无关)或者我是否只需要根据旋转矩阵使用event.values []数组的其他值?或者我需要’重新映射坐标’?那么that是实现这一目标的正确方法吗?

我正在为具有360°屏幕旋转和API等级11的设备开发.

我知道这些问题经常被问到,但我不能将他们的答案转移到我的问题上.

解决方法:

好的,我终于设法让代码工作了!

首先,我注册了一个Sensor.TYPE_MAGNETIC_FIELD和Sensor.TYPE_GRAVITY :(就像Hoan Nguyen说的那样!)

/**

* Initialize the Sensors (Gravity and magnetic field, required as a compass

* sensor)

*/

private void initSensors() {

LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);

SensorManager sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);

Sensor mSensorGravity = sensorManager.getDefaultSensor(Sensor.TYPE_GRAVITY);

Sensor mSensorMagneticField = sensorManager

.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD);

/* Initialize the gravity sensor */

if (mSensorGravity != null) {

Log.i(TAG, "Gravity sensor available. (TYPE_GRAVITY)");

sensorManager.registerListener(mSensorEventListener,

mSensorGravity, SensorManager.SENSOR_DELAY_GAME);

} else {

Log.i(TAG, "Gravity sensor unavailable. (TYPE_GRAVITY)");

}

/* Initialize the magnetic field sensor */

if (mSensorMagneticField != null) {

Log.i(TAG, "Magnetic field sensor available. (TYPE_MAGNETIC_FIELD)");

sensorManager.registerListener(mSensorEventListener,

mSensorMagneticField, SensorManager.SENSOR_DELAY_GAME);

} else {

Log.i(TAG,

"Magnetic field sensor unavailable. (TYPE_MAGNETIC_FIELD)");

}

}

我使用SensorEventListner进行计算:

private SensorEventListener mSensorEventListener = new SensorEventListener() {

@Override

public void onAccuracyChanged(Sensor sensor, int accuracy) {

}

@Override

public void onSensorChanged(SensorEvent event) {

if (event.sensor.getType() == Sensor.TYPE_GRAVITY) {

mGravity = event.values.clone();

} else if (event.sensor.getType() == Sensor.TYPE_MAGNETIC_FIELD) {

mMagnetic = event.values.clone();

}

if (mGravity != null && mMagnetic != null) {

/* Create rotation Matrix */

float[] rotationMatrix = new float[9];

if (SensorManager.getRotationMatrix(rotationMatrix, null,

mGravity, mMagnetic)) {

/* Compensate device orientation */

// http://android-developers.blogspot.de/2010/09/one-screen-turn-deserves-another.html

float[] remappedRotationMatrix = new float[9];

switch (getWindowManager().getDefaultDisplay()

.getRotation()) {

case Surface.ROTATION_0:

SensorManager.remapCoordinateSystem(rotationMatrix,

SensorManager.AXIS_X, SensorManager.AXIS_Y,

remappedRotationMatrix);

break;

case Surface.ROTATION_90:

SensorManager.remapCoordinateSystem(rotationMatrix,

SensorManager.AXIS_Y,

SensorManager.AXIS_MINUS_X,

remappedRotationMatrix);

break;

case Surface.ROTATION_180:

SensorManager.remapCoordinateSystem(rotationMatrix,

SensorManager.AXIS_MINUS_X,

SensorManager.AXIS_MINUS_Y,

remappedRotationMatrix);

break;

case Surface.ROTATION_270:

SensorManager.remapCoordinateSystem(rotationMatrix,

SensorManager.AXIS_MINUS_Y,

SensorManager.AXIS_X, remappedRotationMatrix);

break;

}

/* Calculate Orientation */

float results[] = new float[3];

SensorManager.getOrientation(remappedRotationMatrix,

results);

/* Get measured value */

float current_measured_bearing = (float) (results[0] * 180 / Math.PI);

if (current_measured_bearing < 0) {

current_measured_bearing += 360;

}

/* Smooth values using a 'Low Pass Filter' */

current_measured_bearing = current_measured_bearing

+ SMOOTHING_FACTOR_COMPASS

* (current_measured_bearing - compass_last_measured_bearing);

/* Update normal output */

visual_compass_value.setText(String.valueOf(Math

.round(current_bearing))

+ getString(R.string.degrees));

/*

* Update variables for next use (Required for Low Pass

* Filter)

*/

compass_last_measured_bearing = current_measured_bearing;

}

}

}

};

标签:android-sensors,android,java,bearing,digital-compass

来源: https://codeday.me/bug/20190723/1508925.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值