这是indexloc提供的服务,不要输入任何密码
Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions app/src/main/AndroidManifest.xml
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@
android:icon="@mipmap/ic_launcher"
android:roundIcon="@mipmap/ic_launcher_round"
android:label="@string/app_name"
android:name=".TermuxAPI"
android:supportsRtl="true"
android:theme="@android:style/Theme.Material.Light" >
<receiver android:name="com.termux.api.TermuxApiReceiver"/>
Expand Down
79 changes: 79 additions & 0 deletions app/src/main/java/com/termux/api/SensorAPI.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
package com.termux.api;

import android.content.Context;
import android.content.Intent;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.util.JsonWriter;
import android.util.SparseArray;
import com.termux.api.util.ResultReturner;

public class SensorAPI implements SensorEventListener{
private static SensorManager mSensorManager;

private static SparseArray<float[]> mSensorValues = new SparseArray<>();

SensorAPI(Context context){
mSensorManager = (SensorManager) context.getSystemService(Context.SENSOR_SERVICE);

tryRegisterSensor(mSensorManager, Sensor.TYPE_ACCELEROMETER);
tryRegisterSensor(mSensorManager, Sensor.TYPE_AMBIENT_TEMPERATURE);
tryRegisterSensor(mSensorManager, Sensor.TYPE_LIGHT);
tryRegisterSensor(mSensorManager, Sensor.TYPE_RELATIVE_HUMIDITY);
tryRegisterSensor(mSensorManager, Sensor.TYPE_PRESSURE);
tryRegisterSensor(mSensorManager, Sensor.TYPE_PROXIMITY);
}

private void tryRegisterSensor(SensorManager manager, int type){
Sensor sensor = manager.getDefaultSensor(type);
if (sensor != null){
manager.registerListener(this, sensor, SensorManager.SENSOR_DELAY_NORMAL);
}
}

public static void onReceive(TermuxApiReceiver apiReceiver, Intent intent, final int type) {
ResultReturner.returnData(apiReceiver, intent, new ResultReturner.ResultJsonWriter() {
@Override
public void writeJson(JsonWriter out) throws Exception {
Sensor sensor;
if ((sensor = mSensorManager.getDefaultSensor(type)) != null) {
out.beginObject();
out.name("info").value(sensor.toString());
float[] data;
if ((data = mSensorValues.get(type)) != null) {
switch (type) {
case Sensor.TYPE_ACCELEROMETER:
out.name("data").beginObject();
out.name("x").value(data[0]);
out.name("y").value(data[1]);
out.name("z").value(data[2]);
out.endObject();
default:
out.name("data").value(data[0]);
}
} else {
out.name("data").value("");
}
out.endObject();
} else {
out.beginObject();
out.name("info").value("");
out.name("data").value("");
out.endObject();
}
}
});
}

@Override
public void onAccuracyChanged(Sensor sensor, int accuracy) {

}

@Override
public void onSensorChanged(SensorEvent event) {
mSensorValues.put(event.sensor.getType(), event.values);
}
}
21 changes: 21 additions & 0 deletions app/src/main/java/com/termux/api/TermuxAPI.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
package com.termux.api;

import android.app.Application;
import android.hardware.SensorManager;

public class TermuxAPI extends Application {
private SensorAPI sensorAPI;

@Override
public void onCreate() {
super.onCreate();
sensorAPI = new SensorAPI(this);
}

@Override
public void onTerminate() {
((SensorManager) getSystemService(SENSOR_SERVICE)).unregisterListener(sensorAPI);

super.onTerminate();
}
}
19 changes: 19 additions & 0 deletions app/src/main/java/com/termux/api/TermuxApiReceiver.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import android.content.Context;
import android.content.Intent;

import android.hardware.Sensor;
import com.termux.api.util.TermuxApiLogger;
import com.termux.api.util.TermuxApiPermissionActivity;

Expand Down Expand Up @@ -68,6 +69,24 @@ public void onReceive(Context context, Intent intent) {
case "Share":
ShareAPI.onReceive(this, context, intent);
break;
case "SensorAccelerometer":
SensorAPI.onReceive(this, intent, Sensor.TYPE_ACCELEROMETER);
break;
case "SensorProximity":
SensorAPI.onReceive(this, intent, Sensor.TYPE_PROXIMITY);
break;
case "SensorTemp":
SensorAPI.onReceive(this, intent, Sensor.TYPE_AMBIENT_TEMPERATURE);
break;
case "SensorLight":
SensorAPI.onReceive(this, intent, Sensor.TYPE_LIGHT);
break;
case "SensorPressure":
SensorAPI.onReceive(this, intent, Sensor.TYPE_PRESSURE);
break;
case "SensorHumidity":
SensorAPI.onReceive(this, intent, Sensor.TYPE_RELATIVE_HUMIDITY);
break;
case "SmsInbox":
if (TermuxApiPermissionActivity.checkAndRequestPermissions(context, intent, Manifest.permission.READ_SMS, Manifest.permission.READ_CONTACTS)) {
SmsInboxAPI.onReceive(this, context, intent);
Expand Down