1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-12 18:57:36 +01:00

SuperCars: add blinking function and live battery status, fine-tune driving, race!

This commit is contained in:
vanous 2022-10-02 16:46:13 +02:00
parent 663525091d
commit b957c76d71
4 changed files with 129 additions and 20 deletions

View File

@ -1,10 +1,14 @@
package nodomain.freeyourgadget.gadgetbridge.devices.supercars;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.os.Bundle;
import android.os.CountDownTimer;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.TextView;
import androidx.localbroadcastmanager.content.LocalBroadcastManager;
@ -13,15 +17,20 @@ import org.slf4j.LoggerFactory;
import nodomain.freeyourgadget.gadgetbridge.R;
import nodomain.freeyourgadget.gadgetbridge.activities.AbstractGBActivity;
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
import nodomain.freeyourgadget.gadgetbridge.service.devices.supercars.SuperCarsSupport;
public class ControlActivity extends AbstractGBActivity implements JoystickView.JoystickListener {
private static final Logger LOG = LoggerFactory.getLogger(ControlActivity.class);
LocalBroadcastManager localBroadcastManager;
boolean lights = false;
boolean turbo = false;
CountDownTimer periodicDataSenderRunner;
private GBDevice device;
TextView batteryPercentage;
boolean lights = false;
boolean blinking = false;
boolean turbo = false;
SuperCarsConstants.Direction direction = SuperCarsConstants.Direction.CENTER;
SuperCarsConstants.Movement movement = SuperCarsConstants.Movement.IDLE;
SuperCarsConstants.Speed speed = SuperCarsConstants.Speed.NORMAL;
@ -31,9 +40,26 @@ public class ControlActivity extends AbstractGBActivity implements JoystickView.
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_supercars_control);
localBroadcastManager = LocalBroadcastManager.getInstance(this);
Intent intent = getIntent();
Bundle bundle = intent.getExtras();
if (bundle != null) {
device = bundle.getParcelable(GBDevice.EXTRA_DEVICE);
} else {
throw new IllegalArgumentException("Must provide a device when invoking this activity");
}
CheckBox turboMode = findViewById(R.id.turboMode);
CheckBox lightsOn = findViewById(R.id.lightsOn);
CheckBox lightsBlinking = findViewById(R.id.lightsBlinking);
batteryPercentage = findViewById(R.id.battery_percentage_label);
setBatteryLabel();
localBroadcastManager = LocalBroadcastManager.getInstance(ControlActivity.this);
IntentFilter filter = new IntentFilter();
filter.addAction(GBDevice.ACTION_DEVICE_CHANGED);
localBroadcastManager.registerReceiver(commandReceiver, filter);
turboMode.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
@ -45,23 +71,69 @@ public class ControlActivity extends AbstractGBActivity implements JoystickView.
lightsOn.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) {
if (lightsBlinking.isChecked()) {
lightsBlinking.setChecked(false);
blinking = false;
}
}
lights = isChecked;
setLights();
}
});
//when this activity is open, data is sent continuously every 200ms
lightsBlinking.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) {
if (lightsOn.isChecked()) {
lightsOn.setChecked(false);
lights = false;
}
}
blinking = isChecked;
setLights();
}
});
//when this activity is open, data is sent continuously every 100ms
periodicDataSender();
periodicDataSenderRunner.start();
}
private void setLights() {
if (!blinking) {
if (lights) {
light = SuperCarsConstants.Light.ON;
} else {
light = SuperCarsConstants.Light.OFF;
}
}
}
private void setBatteryLabel() {
String level = device.getBatteryLevel() > 0 ? String.format("%1s%%", device.getBatteryLevel()) : device.getName();
batteryPercentage.setText(level);
}
private void sendLocalBroadcast(Intent intent) {
localBroadcastManager.sendBroadcast(intent);
}
public void periodicDataSender() {
periodicDataSenderRunner = new CountDownTimer(Long.MAX_VALUE, 200) {
periodicDataSenderRunner = new CountDownTimer(Long.MAX_VALUE, 100) {
public void onTick(long millisUntilFinished) {
if (blinking) {
if (light.equals(SuperCarsConstants.Light.ON)) {
light = SuperCarsConstants.Light.OFF;
} else {
light = SuperCarsConstants.Light.ON;
}
}
create_intent_with_data();
}
@ -83,9 +155,9 @@ public class ControlActivity extends AbstractGBActivity implements JoystickView.
@Override
public void onJoystickMoved(float xPercent, float yPercent, int id) {
if (yPercent < 0) {
if (yPercent < 0.2 && yPercent != 0) {
movement = SuperCarsConstants.Movement.UP;
} else if (yPercent > 0) {
} else if (yPercent > 0.2) {
movement = SuperCarsConstants.Movement.DOWN;
} else {
movement = SuperCarsConstants.Movement.IDLE;
@ -99,11 +171,6 @@ public class ControlActivity extends AbstractGBActivity implements JoystickView.
direction = SuperCarsConstants.Direction.CENTER;
}
if (lights) {
light = SuperCarsConstants.Light.ON;
} else {
light = SuperCarsConstants.Light.OFF;
}
if (turbo) {
speed = SuperCarsConstants.Speed.TURBO;
} else {
@ -115,6 +182,7 @@ public class ControlActivity extends AbstractGBActivity implements JoystickView.
protected void onDestroy() {
super.onDestroy();
periodicDataSenderRunner.cancel();
LocalBroadcastManager.getInstance(this).unregisterReceiver(commandReceiver);
}
@Override
@ -128,4 +196,19 @@ public class ControlActivity extends AbstractGBActivity implements JoystickView.
super.onPause();
periodicDataSenderRunner.cancel();
}
BroadcastReceiver commandReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
LOG.debug("device receiver received " + intent.getAction());
if (intent.getAction().equals(GBDevice.ACTION_DEVICE_CHANGED)) {
GBDevice newDevice = intent.getParcelableExtra(GBDevice.EXTRA_DEVICE);
if (newDevice.equals(device)) {
device = newDevice;
setBatteryLabel();
}
}
}
};
}

View File

@ -67,7 +67,7 @@ public class SuperCarsSupport extends AbstractBTLEDeviceSupport {
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(COMMAND_DRIVE_CONTROL)) {
send_data(
queueDataToBLE(
(SuperCarsConstants.Speed) intent.getSerializableExtra(EXTRA_SPEED),
(SuperCarsConstants.Movement) intent.getSerializableExtra(EXTRA_MOVEMENT),
(SuperCarsConstants.Light) intent.getSerializableExtra(EXTRA_LIGHT),
@ -112,7 +112,8 @@ public class SuperCarsSupport extends AbstractBTLEDeviceSupport {
if (decoded_data.length == 16) {
GBDeviceEventBatteryInfo batteryEvent = new GBDeviceEventBatteryInfo();
batteryEvent.state = BatteryState.BATTERY_NORMAL;
batteryEvent.level = decoded_data[4];
int level = decoded_data[4];
batteryEvent.level = level;
evaluateGBDeviceEvent(batteryEvent);
}
}
@ -294,10 +295,10 @@ public class SuperCarsSupport extends AbstractBTLEDeviceSupport {
return false;
}
private void send_data(SuperCarsConstants.Speed speed,
SuperCarsConstants.Movement movement,
SuperCarsConstants.Light light,
SuperCarsConstants.Direction direction) {
private void queueDataToBLE(SuperCarsConstants.Speed speed,
SuperCarsConstants.Movement movement,
SuperCarsConstants.Light light,
SuperCarsConstants.Direction direction) {
byte[] command = craft_packet(speed, direction, movement, light);
TransactionBuilder builder = new TransactionBuilder("send data");

View File

@ -10,6 +10,17 @@
android:orientation="vertical"
tools:ignore="MissingConstraints">
<TextView
android:id="@+id/battery_percentage_label"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_weight="1"
android:foregroundGravity="center_horizontal"
android:gravity="center_horizontal"
android:text=""
android:textSize="48sp" />
<nodomain.freeyourgadget.gadgetbridge.devices.supercars.JoystickView
android:id="@+id/joystickLeft"
android:layout_width="wrap_content"
@ -26,14 +37,27 @@
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="@string/supercars_turbo_speed_label" />
android:height="48dp"
android:text="@string/supercars_turbo_speed_label"
tools:ignore="TouchTargetSizeCheck" />
<CheckBox
android:id="@+id/lightsOn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="@string/supercars_lights_label" />
android:height="48dp"
android:text="@string/supercars_lights_label"
tools:ignore="TouchTargetSizeCheck" />
<CheckBox
android:id="@+id/lightsBlinking"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:height="48dp"
android:text="@string/supercars_lights_blinking_label"
tools:ignore="TouchTargetSizeCheck" />
</LinearLayout>
</LinearLayout>

View File

@ -1854,4 +1854,5 @@
<string name="devicetype_super_cars">Shell Racing</string>
<string name="supercars_turbo_speed_label">Turbo Speed</string>
<string name="supercars_lights_label">Lights</string>
<string name="supercars_lights_blinking_label">Blinking</string>
</resources>