blob: 748ea68f72bcf3eaa563b4459ce309f561b6e999 [file] [log] [blame]
/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.google.android.car.kitchensink.cluster;
import android.app.AlertDialog;
import android.car.cluster.CarInstrumentClusterManager;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.car.Car;
import android.support.car.CarAppFocusManager;
import android.support.car.CarConnectionCallback;
import android.support.car.CarNotConnectedException;
import android.support.car.navigation.CarNavigationStatusManager;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Toast;
import com.google.android.car.kitchensink.R;
/**
* Contains functions to test instrument cluster API.
*/
public class InstrumentClusterFragment extends Fragment {
private static final String TAG = InstrumentClusterFragment.class.getSimpleName();
private static final int DISPLAY_IN_CLUSTER_PERMISSION_REQUEST = 1;
private CarNavigationStatusManager mCarNavigationStatusManager;
private CarAppFocusManager mCarAppFocusManager;
private Car mCarApi;
private final CarConnectionCallback mCarConnectionCallback = new CarConnectionCallback() {
@Override
public void onConnected(Car car) {
Log.d(TAG, "Connected to Car Service");
try {
mCarNavigationStatusManager =
mCarApi.getCarManager(CarNavigationStatusManager.class);
mCarAppFocusManager = mCarApi.getCarManager(CarAppFocusManager.class);
} catch (CarNotConnectedException e) {
Log.e(TAG, "Car is not connected!", e);
}
}
@Override
public void onDisconnected(Car car) {
Log.d(TAG, "Disconnect from Car Service");
}
};
private void initCarApi() {
if (mCarApi != null && mCarApi.isConnected()) {
mCarApi.disconnect();
mCarApi = null;
}
mCarApi = Car.createCar(getContext(), mCarConnectionCallback);
mCarApi.connect();
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container,
@Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.instrument_cluster, container, false);
view.findViewById(R.id.cluster_start_button).setOnClickListener(v -> initCluster());
view.findViewById(R.id.cluster_turn_left_button).setOnClickListener(v -> sendTurn());
view.findViewById(R.id.cluster_start_activity).setOnClickListener(v -> startNavActivity());
return view;
}
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
initCarApi();
super.onCreate(savedInstanceState);
}
private void startNavActivity() {
CarInstrumentClusterManager clusterManager;
try {
clusterManager = (CarInstrumentClusterManager) mCarApi.getCarManager(
android.car.Car.CAR_INSTRUMENT_CLUSTER_SERVICE);
} catch (CarNotConnectedException e) {
Log.e(TAG, "Failed to get CarInstrumentClusterManager", e);
Toast.makeText(getContext(), "Failed to get CarInstrumentClusterManager",
Toast.LENGTH_LONG).show();
return;
}
// Implicit intent
Intent intent = new Intent(Intent.ACTION_MAIN);
intent.addCategory(CarInstrumentClusterManager.CATEGORY_NAVIGATION);
try {
clusterManager.startActivity(intent);
} catch (android.car.CarNotConnectedException e) {
Log.e(TAG, "Failed to startActivity in cluster", e);
Toast.makeText(getContext(), "Failed to start activity in cluster",
Toast.LENGTH_LONG).show();
return;
}
}
private void sendTurn() {
// TODO(deanh): Make this actually meaningful.
Bundle bundle = new Bundle();
bundle.putString("someName", "someValue time=" + System.currentTimeMillis());
try {
mCarNavigationStatusManager.sendEvent(1, bundle);
} catch(CarNotConnectedException e) {
Log.e(TAG, "Failed to send turn information.", e);
}
}
private void initCluster() {
try {
mCarAppFocusManager
.addFocusListener(new CarAppFocusManager.OnAppFocusChangedListener() {
@Override
public void onAppFocusChanged(CarAppFocusManager manager, int appType,
boolean active) {
Log.d(TAG, "onAppFocusChanged, appType: " + appType + " active: "
+ active);
}
}, CarAppFocusManager.APP_FOCUS_TYPE_NAVIGATION);
} catch (CarNotConnectedException e) {
Log.e(TAG, "Failed to register focus listener", e);
}
CarAppFocusManager.OnAppFocusOwnershipCallback
focusCallback = new CarAppFocusManager.OnAppFocusOwnershipCallback() {
@Override
public void onAppFocusOwnershipLost(CarAppFocusManager manager, int focus) {
Log.w(TAG, "onAppFocusOwnershipLost, focus: " + focus);
new AlertDialog.Builder(getContext())
.setTitle(getContext().getApplicationInfo().name)
.setMessage(R.string.cluster_nav_app_context_loss)
.show();
}
@Override
public void onAppFocusOwnershipGranted(CarAppFocusManager manager, int focus) {
Log.w(TAG, "onAppFocusOwnershipGranted, focus: " + focus);
}
};
try {
mCarAppFocusManager.requestAppFocus(CarAppFocusManager.APP_FOCUS_TYPE_NAVIGATION,
focusCallback);
} catch (CarNotConnectedException e) {
Log.e(TAG, "Failed to set active focus", e);
}
try {
boolean ownsFocus = mCarAppFocusManager.isOwningFocus(
CarAppFocusManager.APP_FOCUS_TYPE_NAVIGATION, focusCallback);
Log.d(TAG, "Owns APP_FOCUS_TYPE_NAVIGATION: " + ownsFocus);
if (!ownsFocus) {
throw new RuntimeException("Focus was not acquired.");
}
} catch (CarNotConnectedException e) {
Log.e(TAG, "Failed to get owned focus", e);
}
// TODO(deanh): re-implement this using sendEvent()
}
@Override
public void onResume() {
super.onResume();
Log.i(TAG, "onResume!");
if (getActivity().checkSelfPermission(android.car.Car.PERMISSION_CAR_DISPLAY_IN_CLUSTER)
!= PackageManager.PERMISSION_GRANTED) {
Log.i(TAG, "Requesting: " + android.car.Car.PERMISSION_CAR_DISPLAY_IN_CLUSTER);
requestPermissions(new String[] {android.car.Car.PERMISSION_CAR_DISPLAY_IN_CLUSTER},
DISPLAY_IN_CLUSTER_PERMISSION_REQUEST);
} else {
Log.i(TAG, "All required permissions granted");
}
}
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions,
int[] grantResults) {
if (DISPLAY_IN_CLUSTER_PERMISSION_REQUEST == requestCode) {
for (int i = 0; i < permissions.length; i++) {
boolean granted = grantResults[i] == PackageManager.PERMISSION_GRANTED;
Log.i(TAG, "onRequestPermissionsResult, requestCode: " + requestCode
+ ", permission: " + permissions[i] + ", granted: " + granted);
}
}
}
}