aboutsummaryrefslogtreecommitdiff
path: root/tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink
diff options
context:
space:
mode:
authorEnrico Granata <egranata@google.com>2018-05-22 20:18:43 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2018-05-22 20:18:43 +0000
commitdd1f128095b5c48a9a1da4bc5ff5eb619cd258ed (patch)
tree065cc9b2abc5f7de79bc783867bd5e9abd6e59c0 /tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink
parent8726539cd81d1489bada8c92ec694dcc0217c988 (diff)
parent3ac2057bd91eb506a4731338f724897cc8f449ae (diff)
downloadCar-dd1f128095b5c48a9a1da4bc5ff5eb619cd258ed.tar.gz
Merge "Service and KitchenSink logic to read the kernel's input event queues" into pi-dev
Diffstat (limited to 'tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink')
-rw-r--r--tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink/input/InputTestFragment.java38
1 files changed, 38 insertions, 0 deletions
diff --git a/tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink/input/InputTestFragment.java b/tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink/input/InputTestFragment.java
index ff6ef21c55..4b9ec1d25b 100644
--- a/tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink/input/InputTestFragment.java
+++ b/tests/EmbeddedKitchenSinkApp/src/com/google/android/car/kitchensink/input/InputTestFragment.java
@@ -30,6 +30,7 @@ import android.hardware.automotive.vehicle.V2_0.VehiclePropertyType;
import android.os.Bundle;
import android.os.RemoteException;
import android.support.v4.app.Fragment;
+import android.text.method.ScrollingMovementMethod;
import android.util.Log;
import android.view.KeyEvent;
import android.view.LayoutInflater;
@@ -40,6 +41,12 @@ import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;
+import android.support.v4.app.Fragment;
+
+import com.android.car.keventreader.EventReaderService;
+import com.android.car.keventreader.IEventCallback;
+import com.android.car.keventreader.KeypressEvent;
+
import com.google.android.car.kitchensink.R;
import com.google.android.collect.Lists;
@@ -67,6 +74,25 @@ public class InputTestFragment extends Fragment {
private IVehicle mVehicle;
+ private EventReaderService mEventReaderService;
+
+ private final IEventCallback.Stub mKeypressEventHandler = new IEventCallback.Stub() {
+ private String prettyPrint(KeypressEvent event) {
+ return String.format("Event{source = %s, keycode = %s, key%s}\n",
+ event.source,
+ event.keycodeToString(),
+ event.isKeydown ? "down" : "up");
+ }
+
+ @Override
+ public void onEvent(KeypressEvent keypressEvent) throws RemoteException {
+ Log.d(TAG, "received event " + keypressEvent);
+ mInputEventsList.append(prettyPrint(keypressEvent));
+ }
+ };
+
+ private TextView mInputEventsList;
+
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
@@ -79,6 +105,12 @@ public class InputTestFragment extends Fragment {
throw new RuntimeException("Failed to connect to IVehicle");
}
Log.d(TAG, "Connected to IVehicle service: " + mVehicle);
+
+ mEventReaderService = EventReaderService.tryGet();
+ Log.d(TAG, "Key Event Reader service: " + mEventReaderService);
+ if (mEventReaderService != null) {
+ mEventReaderService.registerCallback(mKeypressEventHandler);
+ }
}
@Nullable
@@ -87,6 +119,9 @@ public class InputTestFragment extends Fragment {
@Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.input_test, container, false);
+ mInputEventsList = view.findViewById(R.id.events_list);
+ mInputEventsList.setMovementMethod(new ScrollingMovementMethod());
+
TextView steeringWheelLabel = new TextView(getActivity() /*context*/);
steeringWheelLabel.setText(R.string.steering_wheel);
steeringWheelLabel.setTextSize(getResources().getDimension(R.dimen.car_title2_size));
@@ -161,6 +196,9 @@ public class InputTestFragment extends Fragment {
public void onDestroyView() {
super.onDestroyView();
mButtons.clear();
+ if (mEventReaderService != null) {
+ mEventReaderService.unregisterCallback(mKeypressEventHandler);
+ }
}
private void addButtonsToPanel(LinearLayout root, List<View> buttons) {