This is step one of theming the set-up lock screen flow to match the setup wizard theme. This shows the general approach of creating a subclass of both the activity and fragment and overriding methods to achieve the desired behavior for setup. ag/594000 is a much more comprehensive change for what the final change will look like. Bug: 18482708 Change-Id: Idff34937f39f46a0c488df2cae4c46155b80cab7
260 lines
10 KiB
Java
260 lines
10 KiB
Java
/*
|
|
* Copyright (C) 2012 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.android.settings.wifi;
|
|
|
|
import android.app.Activity;
|
|
import android.app.AlertDialog;
|
|
import android.app.Dialog;
|
|
import android.app.DialogFragment;
|
|
import android.content.BroadcastReceiver;
|
|
import android.content.Context;
|
|
import android.content.DialogInterface;
|
|
import android.content.Intent;
|
|
import android.content.IntentFilter;
|
|
import android.content.res.Resources;
|
|
import android.net.ConnectivityManager;
|
|
import android.net.NetworkInfo;
|
|
import android.net.wifi.WifiManager;
|
|
import android.os.Bundle;
|
|
import android.preference.PreferenceFragment;
|
|
import android.util.Log;
|
|
|
|
import com.android.settings.ButtonBarHandler;
|
|
import com.android.settings.R;
|
|
import com.android.settings.SetupWizardUtils;
|
|
import com.android.setupwizard.navigationbar.SetupWizardNavBar;
|
|
import com.android.setupwizard.navigationbar.SetupWizardNavBar.NavigationBarListener;
|
|
|
|
public class WifiSetupActivity extends WifiPickerActivity
|
|
implements ButtonBarHandler, NavigationBarListener {
|
|
private static final String TAG = "WifiSetupActivity";
|
|
|
|
private static final String EXTRA_ALLOW_SKIP = "allowSkip";
|
|
|
|
// this boolean extra specifies whether to auto finish when connection is established
|
|
private static final String EXTRA_AUTO_FINISH_ON_CONNECT = "wifi_auto_finish_on_connect";
|
|
|
|
// Whether auto finish is suspended until user connects to an access point
|
|
private static final String EXTRA_REQUIRE_USER_NETWORK_SELECTION =
|
|
"wifi_require_user_network_selection";
|
|
|
|
// Key for whether the user selected network in saved instance state bundle
|
|
private static final String PARAM_USER_SELECTED_NETWORK = "userSelectedNetwork";
|
|
|
|
// Activity result when pressing the Skip button
|
|
private static final int RESULT_SKIP = Activity.RESULT_FIRST_USER;
|
|
|
|
// Whether we allow skipping without a valid network connection
|
|
private boolean mAllowSkip = true;
|
|
// Whether to auto finish when the user selected a network and successfully connected
|
|
private boolean mAutoFinishOnConnection;
|
|
// Whether the user connected to a network. This excludes the auto-connecting by the system.
|
|
private boolean mUserSelectedNetwork;
|
|
// Whether the device is connected to WiFi
|
|
private boolean mWifiConnected;
|
|
|
|
private SetupWizardNavBar mNavigationBar;
|
|
|
|
private final IntentFilter mFilter = new IntentFilter(WifiManager.NETWORK_STATE_CHANGED_ACTION);
|
|
private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
|
@Override
|
|
public void onReceive(Context context, Intent intent) {
|
|
// Refresh the connection state with the latest connection info. Use the connection info
|
|
// from ConnectivityManager instead of the one attached in the intent to make sure
|
|
// we have the most up-to-date connection state. b/17511772
|
|
refreshConnectionState();
|
|
}
|
|
};
|
|
|
|
@Override
|
|
protected void onCreate(Bundle savedInstanceState) {
|
|
super.onCreate(savedInstanceState);
|
|
|
|
final Intent intent = getIntent();
|
|
|
|
mAutoFinishOnConnection = intent.getBooleanExtra(EXTRA_AUTO_FINISH_ON_CONNECT, false);
|
|
mAllowSkip = intent.getBooleanExtra(EXTRA_ALLOW_SKIP, true);
|
|
// Behave like the user already selected a network if we do not require selection
|
|
mUserSelectedNetwork = !intent.getBooleanExtra(EXTRA_REQUIRE_USER_NETWORK_SELECTION, false);
|
|
}
|
|
|
|
@Override
|
|
protected void onSaveInstanceState(Bundle outState) {
|
|
super.onSaveInstanceState(outState);
|
|
outState.putBoolean(PARAM_USER_SELECTED_NETWORK, mUserSelectedNetwork);
|
|
}
|
|
|
|
@Override
|
|
protected void onRestoreInstanceState(Bundle savedInstanceState) {
|
|
super.onRestoreInstanceState(savedInstanceState);
|
|
mUserSelectedNetwork = savedInstanceState.getBoolean(PARAM_USER_SELECTED_NETWORK, true);
|
|
}
|
|
|
|
private void refreshConnectionState() {
|
|
final ConnectivityManager connectivity = (ConnectivityManager)
|
|
getSystemService(Context.CONNECTIVITY_SERVICE);
|
|
boolean connected = connectivity != null &&
|
|
connectivity.getNetworkInfo(ConnectivityManager.TYPE_WIFI).isConnected();
|
|
refreshConnectionState(connected);
|
|
}
|
|
|
|
private void refreshConnectionState(boolean connected) {
|
|
mWifiConnected = connected;
|
|
if (connected) {
|
|
if (mAutoFinishOnConnection && mUserSelectedNetwork) {
|
|
Log.d(TAG, "Auto-finishing with connection");
|
|
finishOrNext(Activity.RESULT_OK);
|
|
// Require a user selection before auto-finishing next time we are here. The user
|
|
// can either connect to a different network or press "next" to proceed.
|
|
mUserSelectedNetwork = false;
|
|
}
|
|
if (mNavigationBar != null) {
|
|
mNavigationBar.getNextButton().setText(R.string.setup_wizard_next_button_label);
|
|
mNavigationBar.getNextButton().setEnabled(true);
|
|
}
|
|
} else {
|
|
if (mNavigationBar != null) {
|
|
mNavigationBar.getNextButton().setText(R.string.skip_label);
|
|
mNavigationBar.getNextButton().setEnabled(mAllowSkip);
|
|
}
|
|
}
|
|
}
|
|
|
|
/* package */ void networkSelected() {
|
|
Log.d(TAG, "Network selected by user");
|
|
mUserSelectedNetwork = true;
|
|
}
|
|
|
|
@Override
|
|
public void onResume() {
|
|
super.onResume();
|
|
registerReceiver(mReceiver, mFilter);
|
|
refreshConnectionState();
|
|
}
|
|
|
|
@Override
|
|
public void onPause() {
|
|
unregisterReceiver(mReceiver);
|
|
super.onPause();
|
|
}
|
|
|
|
@Override
|
|
protected void onApplyThemeResource(Resources.Theme theme, int resid, boolean first) {
|
|
resid = SetupWizardUtils.getTheme(getIntent(), resid);
|
|
super.onApplyThemeResource(theme, resid, first);
|
|
}
|
|
|
|
@Override
|
|
protected boolean isValidFragment(String fragmentName) {
|
|
return WifiSettingsForSetupWizard.class.getName().equals(fragmentName);
|
|
}
|
|
|
|
@Override
|
|
/* package */ Class<? extends PreferenceFragment> getWifiSettingsClass() {
|
|
return WifiSettingsForSetupWizard.class;
|
|
}
|
|
|
|
/**
|
|
* Complete this activity and return the results to the caller. If using WizardManager, this
|
|
* will invoke the next scripted action; otherwise, we simply finish.
|
|
*/
|
|
public void finishOrNext(int resultCode) {
|
|
Log.d(TAG, "finishOrNext resultCode=" + resultCode
|
|
+ " isUsingWizardManager=" + SetupWizardUtils.isUsingWizardManager(this));
|
|
if (SetupWizardUtils.isUsingWizardManager(this)) {
|
|
SetupWizardUtils.sendResultsToSetupWizard(this, resultCode);
|
|
} else {
|
|
setResult(resultCode);
|
|
finish();
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void onNavigationBarCreated(final SetupWizardNavBar bar) {
|
|
mNavigationBar = bar;
|
|
SetupWizardUtils.setImmersiveMode(this, bar);
|
|
}
|
|
|
|
@Override
|
|
public void onNavigateBack() {
|
|
onBackPressed();
|
|
}
|
|
|
|
@Override
|
|
public void onNavigateNext() {
|
|
if (mWifiConnected) {
|
|
finishOrNext(RESULT_OK);
|
|
} else {
|
|
// Warn of possible data charges if there is a network connection, or lack of updates
|
|
// if there is none.
|
|
final int message = isNetworkConnected() ? R.string.wifi_skipped_message :
|
|
R.string.wifi_and_mobile_skipped_message;
|
|
WifiSkipDialog.newInstance(message).show(getFragmentManager(), "dialog");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @return True if there is a valid network connection, whether it is via WiFi, mobile data or
|
|
* other means.
|
|
*/
|
|
private boolean isNetworkConnected() {
|
|
final ConnectivityManager connectivity = (ConnectivityManager)
|
|
getSystemService(Context.CONNECTIVITY_SERVICE);
|
|
if (connectivity == null) {
|
|
return false;
|
|
}
|
|
final NetworkInfo info = connectivity.getActiveNetworkInfo();
|
|
return info != null && info.isConnected();
|
|
}
|
|
|
|
public static class WifiSkipDialog extends DialogFragment {
|
|
public static WifiSkipDialog newInstance(int messageRes) {
|
|
final Bundle args = new Bundle();
|
|
args.putInt("messageRes", messageRes);
|
|
final WifiSkipDialog dialog = new WifiSkipDialog();
|
|
dialog.setArguments(args);
|
|
return dialog;
|
|
}
|
|
|
|
public WifiSkipDialog() {
|
|
// no-arg constructor for fragment
|
|
}
|
|
|
|
@Override
|
|
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
|
int messageRes = getArguments().getInt("messageRes");
|
|
return new AlertDialog.Builder(getActivity())
|
|
.setMessage(messageRes)
|
|
.setCancelable(false)
|
|
.setNegativeButton(R.string.wifi_skip_anyway,
|
|
new DialogInterface.OnClickListener() {
|
|
@Override
|
|
public void onClick(DialogInterface dialog, int id) {
|
|
WifiSetupActivity activity = (WifiSetupActivity) getActivity();
|
|
activity.finishOrNext(RESULT_SKIP);
|
|
}
|
|
})
|
|
.setPositiveButton(R.string.wifi_dont_skip,
|
|
new DialogInterface.OnClickListener() {
|
|
@Override
|
|
public void onClick(DialogInterface dialog, int id) {
|
|
}
|
|
})
|
|
.create();
|
|
}
|
|
}
|
|
}
|