From: Mike Beattie Date: Wed, 29 Aug 2012 13:01:06 +0000 (+1200) Subject: altosdroid: initial attempt at a UI. X-Git-Tag: 1.1~47^2 X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=commitdiff_plain;h=17b6ffb6c090112367eac944494f0fa58da453c7 altosdroid: initial attempt at a UI. Signed-off-by: Mike Beattie --- diff --git a/altosdroid/res/layout/altosdroid.xml b/altosdroid/res/layout/altosdroid.xml new file mode 100644 index 00000000..33d89d52 --- /dev/null +++ b/altosdroid/res/layout/altosdroid.xml @@ -0,0 +1,350 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/altosdroid/res/values/strings.xml b/altosdroid/res/values/strings.xml index 324641cd..59f4f827 100644 --- a/altosdroid/res/values/strings.xml +++ b/altosdroid/res/values/strings.xml @@ -41,4 +41,23 @@ Telemetry Service Stopped + + Callsign + State + Speed + m/s + Acceleration + m/s² + Range + m + Altitude + m + Azimuth + ° + Bearing + ° + Latitude + Longitude + + diff --git a/altosdroid/src/org/altusmetrum/AltosDroid/AltosDroid.java b/altosdroid/src/org/altusmetrum/AltosDroid/AltosDroid.java index c4aa4193..ba424e79 100644 --- a/altosdroid/src/org/altusmetrum/AltosDroid/AltosDroid.java +++ b/altosdroid/src/org/altusmetrum/AltosDroid/AltosDroid.java @@ -64,6 +64,16 @@ public class AltosDroid extends Activity { // Layout Views private TextView mTitle; private TextView mSerialView; + private TextView mCallsignView; + private TextView mStateView; + private TextView mSpeedView; + private TextView mAccelView; + private TextView mRangeView; + private TextView mAltitudeView; + private TextView mAzimuthView; + private TextView mBearingView; + private TextView mLatitudeView; + private TextView mLongitudeView; // Service private boolean mIsBound = false; @@ -112,6 +122,7 @@ public class AltosDroid extends Activity { } break; case MSG_TELEMETRY: + ad.update_ui((AltosState) msg.obj); // TEST! ad.mSerialView.setText(Dumper.dump(msg.obj)); break; @@ -162,6 +173,33 @@ public class AltosDroid extends Activity { } } + void update_ui(AltosState state) { + mCallsignView.setText(state.data.callsign); + mStateView.setText(state.data.state()); + double speed = state.speed; + if (!state.ascent) + speed = state.baro_speed; + mSpeedView.setText(String.format("%6.0f", speed)); + mAccelView.setText(String.format("%6.0f", state.acceleration)); + mRangeView.setText(String.format("%6.0f", state.range)); + mAltitudeView.setText(String.format("%6.0f", state.height)); + mAzimuthView.setText(String.format("%3.0f", state.elevation)); + if (state.from_pad != null) + mBearingView.setText(String.format("%3.0f", state.from_pad.bearing)); + mLatitudeView.setText(pos(state.gps.lat, "N", "S")); + mLongitudeView.setText(pos(state.gps.lon, "W", "E")); + } + + String pos(double p, String pos, String neg) { + String h = pos; + if (p < 0) { + h = neg; + p = -p; + } + int deg = (int) Math.floor(p); + double min = (p - Math.floor(p)) * 60.0; + return String.format("%s %d° %9.6f", h, deg, min); + } @Override public void onCreate(Bundle savedInstanceState) { @@ -170,7 +208,8 @@ public class AltosDroid extends Activity { // Set up the window layout requestWindowFeature(Window.FEATURE_CUSTOM_TITLE); - setContentView(R.layout.main); + //setContentView(R.layout.main); + setContentView(R.layout.altosdroid); getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.custom_title); // Set up the custom title @@ -179,11 +218,22 @@ public class AltosDroid extends Activity { mTitle = (TextView) findViewById(R.id.title_right_text); // Set up the temporary Text View - mSerialView = (TextView) findViewById(R.id.in); + mSerialView = (TextView) findViewById(R.id.text); mSerialView.setMovementMethod(new ScrollingMovementMethod()); mSerialView.setClickable(false); mSerialView.setLongClickable(false); + mCallsignView = (TextView) findViewById(R.id.callsign_value); + mStateView = (TextView) findViewById(R.id.state_value); + mSpeedView = (TextView) findViewById(R.id.speed_value); + mAccelView = (TextView) findViewById(R.id.accel_value); + mRangeView = (TextView) findViewById(R.id.range_value); + mAltitudeView = (TextView) findViewById(R.id.altitude_value); + mAzimuthView = (TextView) findViewById(R.id.azimuth_value); + mBearingView = (TextView) findViewById(R.id.bearing_value); + mLatitudeView = (TextView) findViewById(R.id.latitude_value); + mLongitudeView = (TextView) findViewById(R.id.longitude_value); + // Get local Bluetooth adapter mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();