首页 > 其他分享 >Android 10 开启WiFi后出现弹窗改为出现一次,后面不关闭WiFi,不要弹出提示

Android 10 开启WiFi后出现弹窗改为出现一次,后面不关闭WiFi,不要弹出提示

时间:2022-12-13 21:44:07浏览次数:67  
标签:10 return void WiFi private final import Android android

\frameworks\opt\net\wifi\service\java\com\android\server\wifi\AvailableNetworkNotifier.java
package com.android.server.wifi;
import static com.android.server.wifi.ConnectToNetworkNotificationBuilder.ACTION_CONNECT_TO_NETWORK; import static com.android.server.wifi.ConnectToNetworkNotificationBuilder.ACTION_PICK_WIFI_NETWORK; import static com.android.server.wifi.ConnectToNetworkNotificationBuilder.ACTION_PICK_WIFI_NETWORK_AFTER_CONNECT_FAILURE; import static com.android.server.wifi.ConnectToNetworkNotificationBuilder.ACTION_USER_DISMISSED_NOTIFICATION; import static com.android.server.wifi.ConnectToNetworkNotificationBuilder.AVAILABLE_NETWORK_NOTIFIER_TAG;
import android.annotation.IntDef; import android.annotation.NonNull; import android.app.Notification; import android.app.NotificationManager; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.database.ContentObserver; import android.net.wifi.ScanResult; import android.net.wifi.WifiConfiguration; import android.net.wifi.WifiManager; import android.os.Handler; import android.os.Looper; import android.os.Message; import android.os.Messenger; import android.os.Process; import android.os.UserHandle; import android.os.UserManager; import android.provider.Settings; import android.text.TextUtils; import android.util.ArraySet; import android.util.Log;
import com.android.internal.annotations.VisibleForTesting; import com.android.server.wifi.nano.WifiMetricsProto.ConnectToNetworkNotificationAndActionCount; import com.android.server.wifi.util.ScanResultUtil;
import java.io.FileDescriptor; import java.io.PrintWriter; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.util.List; import java.util.Set; //XCSW wenjie.gu add for tooltip start import android.os.SystemProperties; //XCSW wenjie.gu add for tooltip end  
/**  * Base class for all network notifiers (e.g. OpenNetworkNotifier, CarrierNetworkNotifier).  *  * NOTE: These API's are not thread safe and should only be used from WifiCoreThread.  */ public class AvailableNetworkNotifier {
    /** Time in milliseconds to display the Connecting notification. */     private static final int TIME_TO_SHOW_CONNECTING_MILLIS = 10000;
    /** Time in milliseconds to display the Connected notification. */     private static final int TIME_TO_SHOW_CONNECTED_MILLIS = 5000;
    /** Time in milliseconds to display the Failed To Connect notification. */     private static final int TIME_TO_SHOW_FAILED_MILLIS = 5000;
    /** The state of the notification */     @IntDef({             STATE_NO_NOTIFICATION,             STATE_SHOWING_RECOMMENDATION_NOTIFICATION,             STATE_CONNECTING_IN_NOTIFICATION,             STATE_CONNECTED_NOTIFICATION,             STATE_CONNECT_FAILED_NOTIFICATION     })     @Retention(RetentionPolicy.SOURCE)     private @interface State {}
    /** No recommendation is made and no notifications are shown. */     private static final int STATE_NO_NOTIFICATION = 0;     /** The initial notification recommending a network to connect to is shown. */     private static final int STATE_SHOWING_RECOMMENDATION_NOTIFICATION = 1;     /** The notification of status of connecting to the recommended network is shown. */     private static final int STATE_CONNECTING_IN_NOTIFICATION = 2;     /** The notification that the connection to the recommended network was successful is shown. */     private static final int STATE_CONNECTED_NOTIFICATION = 3;     /** The notification to show that connection to the recommended network failed is shown. */     private static final int STATE_CONNECT_FAILED_NOTIFICATION = 4;
    /** Current state of the notification. */     @State private int mState = STATE_NO_NOTIFICATION;
    /**      * The {@link Clock#getWallClockMillis()} must be at least this value for us      * to show the notification again.      */     private long mNotificationRepeatTime;     /**      * When a notification is shown, we wait this amount before possibly showing it again.      */     private final long mNotificationRepeatDelay;     /** Default repeat delay in seconds. */     @VisibleForTesting     static final int DEFAULT_REPEAT_DELAY_SEC = 900;
    /** Whether the user has set the setting to show the 'available networks' notification. */     private boolean mSettingEnabled;     /** Whether the screen is on or not. */     private boolean mScreenOn;
    /** List of SSIDs blacklisted from recommendation. */     private final Set<String> mBlacklistedSsids = new ArraySet<>();
    private final Context mContext;     private final Handler mHandler;     private final FrameworkFacade mFrameworkFacade;     private final WifiMetrics mWifiMetrics;     private final Clock mClock;     private final WifiConfigManager mConfigManager;     private final ClientModeImpl mClientModeImpl;     private final Messenger mSrcMessenger;     private final ConnectToNetworkNotificationBuilder mNotificationBuilder;
    private ScanResult mRecommendedNetwork;
    /** Tag used for logs and metrics */     private final String mTag;     /** Identifier of the {@link SsidSetStoreData}. */     private final String mStoreDataIdentifier;     /** Identifier for the settings toggle, used for registering ContentObserver */     private final String mToggleSettingsName;
    /** System wide identifier for notification in Notification Manager */     private final int mSystemMessageNotificationId;
    /**      * The nominator id for this class, from      * {@link com.android.server.wifi.nano.WifiMetricsProto.ConnectionEvent.ConnectionNominator}      */     private final int mNominatorId;     //XCSW wenjie.gu add for tooltip start     private boolean notification_Value;     //XCSW wenjie.gu add for tooltip end
    public AvailableNetworkNotifier(             String tag,             String storeDataIdentifier,             String toggleSettingsName,             int notificationIdentifier,             int nominatorId,             Context context,             Looper looper,             FrameworkFacade framework,             Clock clock,             WifiMetrics wifiMetrics,             WifiConfigManager wifiConfigManager,             WifiConfigStore wifiConfigStore,             ClientModeImpl clientModeImpl,             ConnectToNetworkNotificationBuilder connectToNetworkNotificationBuilder) {         mTag = tag;         mStoreDataIdentifier = storeDataIdentifier;         mToggleSettingsName = toggleSettingsName;         mSystemMessageNotificationId = notificationIdentifier;         mNominatorId = nominatorId;         mContext = context;         mHandler = new Handler(looper);         mFrameworkFacade = framework;         mWifiMetrics = wifiMetrics;         mClock = clock;         mConfigManager = wifiConfigManager;         mClientModeImpl = clientModeImpl;         mNotificationBuilder = connectToNetworkNotificationBuilder;         mScreenOn = false;         mSrcMessenger = new Messenger(new Handler(looper, mConnectionStateCallback));         wifiConfigStore.registerStoreData(new SsidSetStoreData(mStoreDataIdentifier,                 new AvailableNetworkNotifierStoreData()));
        // Setting is in seconds         mNotificationRepeatDelay = mFrameworkFacade.getIntegerSetting(context,                 Settings.Global.WIFI_NETWORKS_AVAILABLE_REPEAT_DELAY,                 DEFAULT_REPEAT_DELAY_SEC) * 1000L;         NotificationEnabledSettingObserver settingObserver = new NotificationEnabledSettingObserver(                 mHandler);         settingObserver.register();
        IntentFilter filter = new IntentFilter();         filter.addAction(ACTION_USER_DISMISSED_NOTIFICATION);         filter.addAction(ACTION_CONNECT_TO_NETWORK);         filter.addAction(ACTION_PICK_WIFI_NETWORK);         filter.addAction(ACTION_PICK_WIFI_NETWORK_AFTER_CONNECT_FAILURE);         mContext.registerReceiver(                 mBroadcastReceiver, filter, null /* broadcastPermission */, mHandler);     }
    private final BroadcastReceiver mBroadcastReceiver =             new BroadcastReceiver() {                 @Override                 public void onReceive(Context context, Intent intent) {                     if (!mTag.equals(intent.getExtra(AVAILABLE_NETWORK_NOTIFIER_TAG))) {                         return;                     }                     switch (intent.getAction()) {                         case ACTION_USER_DISMISSED_NOTIFICATION:                             handleUserDismissedAction();                             break;                         case ACTION_CONNECT_TO_NETWORK:                             handleConnectToNetworkAction();                             break;                         case ACTION_PICK_WIFI_NETWORK:                             handleSeeAllNetworksAction();                             break;                         case ACTION_PICK_WIFI_NETWORK_AFTER_CONNECT_FAILURE:                             handlePickWifiNetworkAfterConnectFailure();                             break;                         default:                             Log.e(mTag, "Unknown action " + intent.getAction());                     }                 }             };
    private final Handler.Callback mConnectionStateCallback = (Message msg) -> {         switch (msg.what) {             // Success here means that an attempt to connect to the network has been initiated.             // Successful connection updates are received via the             // WifiConnectivityManager#handleConnectionStateChanged() callback.             case WifiManager.CONNECT_NETWORK_SUCCEEDED:                 break;             case WifiManager.CONNECT_NETWORK_FAILED:                 handleConnectionAttemptFailedToSend();                 break;             default:                 Log.e("AvailableNetworkNotifier", "Unknown message " + msg.what);         }         return true;     };
    /**      * Clears the pending notification. This is called by {@link WifiConnectivityManager} on stop.      *      * @param resetRepeatTime resets the time delay for repeated notification if true.      */     public void clearPendingNotification(boolean resetRepeatTime) {         if (resetRepeatTime) {             mNotificationRepeatTime = 0;         }
        if (mState != STATE_NO_NOTIFICATION) {             getNotificationManager().cancel(mSystemMessageNotificationId);
            if (mRecommendedNetwork != null) {                 Log.d(mTag, "Notification with state="                         + mState                         + " was cleared for recommended network: "                         + "\"" + mRecommendedNetwork.SSID + "\"");             }             mState = STATE_NO_NOTIFICATION;             mRecommendedNetwork = null;         }     }
    private boolean isControllerEnabled() {         return mSettingEnabled && !UserManager.get(mContext)                 .hasUserRestriction(UserManager.DISALLOW_CONFIG_WIFI, UserHandle.CURRENT);     }
    /**      * If there are available networks, attempt to post a network notification.      *      * @param availableNetworks Available networks to choose from and possibly show notification      */     public void handleScanResults(@NonNull List<ScanDetail> availableNetworks) {         //XCSW wenjie.gu add for tooltip start         notification_Value =SystemProperties.getBoolean("persist.sys.wifi.notification.value", true);         //XCSW wenjie.gu add for tooltip end         if (!isControllerEnabled()) {             clearPendingNotification(true /* resetRepeatTime */);             return;         }         if (availableNetworks.isEmpty() && mState == STATE_SHOWING_RECOMMENDATION_NOTIFICATION) {             clearPendingNotification(false /* resetRepeatTime */);             return;         }
        // Not enough time has passed to show a recommendation notification again         if (mState == STATE_NO_NOTIFICATION                 && mClock.getWallClockMillis() < mNotificationRepeatTime) {             return;         }
        // Do nothing when the screen is off and no notification is showing.         if (mState == STATE_NO_NOTIFICATION && !mScreenOn) {             return;         }
        // Only show a new or update an existing recommendation notification.         if (mState == STATE_NO_NOTIFICATION                 || mState == STATE_SHOWING_RECOMMENDATION_NOTIFICATION) {             ScanResult recommendation =                     recommendNetwork(availableNetworks);             //XCSW wenjie.gu add for tooltip start             if (recommendation != null && notification_Value) {                 postInitialNotification(recommendation);             } else {                 clearPendingNotification(false /* resetRepeatTime */);             }             //XCSW wenjie.gu add for tooltip end         }
    }
    /**      * Recommends a network to connect to from a list of available networks, while ignoring the      * SSIDs in the blacklist.      *      * @param networks List of networks to select from      */     public ScanResult recommendNetwork(@NonNull List<ScanDetail> networks) {         ScanResult result = null;         int highestRssi = Integer.MIN_VALUE;         for (ScanDetail scanDetail : networks) {             ScanResult scanResult = scanDetail.getScanResult();
            if (scanResult.level > highestRssi) {                 result = scanResult;                 highestRssi = scanResult.level;             }         }
        if (result != null && mBlacklistedSsids.contains(result.SSID)) {             result = null;         }         return result;     }
    /** Handles screen state changes. */     public void handleScreenStateChanged(boolean screenOn) {         mScreenOn = screenOn;     }
    /**      * Called by {@link WifiConnectivityManager} when Wi-Fi is connected. If the notification      * was in the connecting state, update the notification to show that it has connected to the      * recommended network.      *      * @param ssid The connected network's ssid      */     public void handleWifiConnected(String ssid) {         removeNetworkFromBlacklist(ssid);         if (mState != STATE_CONNECTING_IN_NOTIFICATION) {             clearPendingNotification(true /* resetRepeatTime */);             return;         }
        postNotification(mNotificationBuilder.createNetworkConnectedNotification(mTag,                 mRecommendedNetwork));
        Log.d(mTag, "User connected to recommended network: "                 + "\"" + mRecommendedNetwork.SSID + "\"");         mWifiMetrics.incrementConnectToNetworkNotification(mTag,                 ConnectToNetworkNotificationAndActionCount.NOTIFICATION_CONNECTED_TO_NETWORK);         mState = STATE_CONNECTED_NOTIFICATION;         mHandler.postDelayed(                 () -> {                     if (mState == STATE_CONNECTED_NOTIFICATION) {                         clearPendingNotification(true /* resetRepeatTime */);                     }                 },                 TIME_TO_SHOW_CONNECTED_MILLIS);     }
    /**      * Handles when a Wi-Fi connection attempt failed.      */     public void handleConnectionFailure() {         if (mState != STATE_CONNECTING_IN_NOTIFICATION) {             return;         }         postNotification(mNotificationBuilder.createNetworkFailedNotification(mTag));
        Log.d(mTag, "User failed to connect to recommended network: "                 + "\"" + mRecommendedNetwork.SSID + "\"");         mWifiMetrics.incrementConnectToNetworkNotification(mTag,                 ConnectToNetworkNotificationAndActionCount.NOTIFICATION_FAILED_TO_CONNECT);         mState = STATE_CONNECT_FAILED_NOTIFICATION;         mHandler.postDelayed(                 () -> {                     if (mState == STATE_CONNECT_FAILED_NOTIFICATION) {                         clearPendingNotification(false /* resetRepeatTime */);                     }                 },                 TIME_TO_SHOW_FAILED_MILLIS);     }
    private NotificationManager getNotificationManager() {         return (NotificationManager) mContext.getSystemService(Context.NOTIFICATION_SERVICE);     }
    private void postInitialNotification(ScanResult recommendedNetwork) {         if (mRecommendedNetwork != null                 && TextUtils.equals(mRecommendedNetwork.SSID, recommendedNetwork.SSID)) {             return;         }
        postNotification(mNotificationBuilder.createConnectToAvailableNetworkNotification(mTag,                 recommendedNetwork));
        if (mState == STATE_NO_NOTIFICATION) {             mWifiMetrics.incrementConnectToNetworkNotification(mTag,                     ConnectToNetworkNotificationAndActionCount.NOTIFICATION_RECOMMEND_NETWORK);         } else {             mWifiMetrics.incrementNumNetworkRecommendationUpdates(mTag);         }         mState = STATE_SHOWING_RECOMMENDATION_NOTIFICATION;         mRecommendedNetwork = recommendedNetwork;         mNotificationRepeatTime = mClock.getWallClockMillis() + mNotificationRepeatDelay;         //XCSW wenjie.gu add for tooltip start         SystemProperties.set("persist.sys.wifi.notification.value", "false");         //XCSW wenjie.gu add for tooltip end     }
    private void postNotification(Notification notification) {         getNotificationManager().notify(mSystemMessageNotificationId, notification);     }
    private void handleConnectToNetworkAction() {         mWifiMetrics.incrementConnectToNetworkNotificationAction(mTag, mState,                 ConnectToNetworkNotificationAndActionCount.ACTION_CONNECT_TO_NETWORK);         if (mState != STATE_SHOWING_RECOMMENDATION_NOTIFICATION) {             return;         }         postNotification(mNotificationBuilder.createNetworkConnectingNotification(mTag,                 mRecommendedNetwork));         mWifiMetrics.incrementConnectToNetworkNotification(mTag,                 ConnectToNetworkNotificationAndActionCount.NOTIFICATION_CONNECTING_TO_NETWORK);
        Log.d(mTag,                 "User initiated connection to recommended network: "                         + "\"" + mRecommendedNetwork.SSID + "\"");         WifiConfiguration network = createRecommendedNetworkConfig(mRecommendedNetwork);
        NetworkUpdateResult result = mConfigManager.addOrUpdateNetwork(network, Process.WIFI_UID);         if (result.isSuccess()) {             mWifiMetrics.setNominatorForNetwork(result.netId, mNominatorId);
            Message msg = Message.obtain();             msg.what = WifiManager.CONNECT_NETWORK;             msg.arg1 = result.netId;             msg.obj = null;             msg.replyTo = mSrcMessenger;             mClientModeImpl.sendMessage(msg);             addNetworkToBlacklist(mRecommendedNetwork.SSID);         }
        mState = STATE_CONNECTING_IN_NOTIFICATION;         mHandler.postDelayed(                 () -> {                     if (mState == STATE_CONNECTING_IN_NOTIFICATION) {                         handleConnectionFailure();                     }                 },                 TIME_TO_SHOW_CONNECTING_MILLIS);     }
    private void addNetworkToBlacklist(String ssid) {         mBlacklistedSsids.add(ssid);         mWifiMetrics.setNetworkRecommenderBlacklistSize(mTag, mBlacklistedSsids.size());         mConfigManager.saveToStore(false /* forceWrite */);         Log.d(mTag, "Network is added to the network notification blacklist: "                 + "\"" + ssid + "\"");     }
    private void removeNetworkFromBlacklist(String ssid) {         if (ssid == null) {             return;         }         if (!mBlacklistedSsids.remove(ssid)) {             return;         }         mWifiMetrics.setNetworkRecommenderBlacklistSize(mTag, mBlacklistedSsids.size());         mConfigManager.saveToStore(false /* forceWrite */);         Log.d(mTag, "Network is removed from the network notification blacklist: "                 + "\"" + ssid + "\"");     }
    WifiConfiguration createRecommendedNetworkConfig(ScanResult recommendedNetwork) {         return ScanResultUtil.createNetworkFromScanResult(recommendedNetwork);     }
    private void handleSeeAllNetworksAction() {         mWifiMetrics.incrementConnectToNetworkNotificationAction(mTag, mState,                 ConnectToNetworkNotificationAndActionCount.ACTION_PICK_WIFI_NETWORK);         startWifiSettings();     }
    private void startWifiSettings() {         // Close notification drawer before opening the picker.         mContext.sendBroadcast(new Intent(Intent.ACTION_CLOSE_SYSTEM_DIALOGS));         mContext.startActivity(                 new Intent(Settings.ACTION_WIFI_SETTINGS)                         .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK));         clearPendingNotification(false /* resetRepeatTime */);     }
    private void handleConnectionAttemptFailedToSend() {         handleConnectionFailure();         mWifiMetrics.incrementNumNetworkConnectMessageFailedToSend(mTag);     }
    private void handlePickWifiNetworkAfterConnectFailure() {         mWifiMetrics.incrementConnectToNetworkNotificationAction(mTag, mState,                 ConnectToNetworkNotificationAndActionCount                         .ACTION_PICK_WIFI_NETWORK_AFTER_CONNECT_FAILURE);         startWifiSettings();     }
    private void handleUserDismissedAction() {         Log.d(mTag, "User dismissed notification with state=" + mState);         mWifiMetrics.incrementConnectToNetworkNotificationAction(mTag, mState,                 ConnectToNetworkNotificationAndActionCount.ACTION_USER_DISMISSED_NOTIFICATION);         if (mState == STATE_SHOWING_RECOMMENDATION_NOTIFICATION) {             // blacklist dismissed network             addNetworkToBlacklist(mRecommendedNetwork.SSID);         }         resetStateAndDelayNotification();     }
    private void resetStateAndDelayNotification() {         mState = STATE_NO_NOTIFICATION;         mNotificationRepeatTime = System.currentTimeMillis() + mNotificationRepeatDelay;         mRecommendedNetwork = null;     }
    /** Dump this network notifier's state. */     public void dump(FileDescriptor fd, PrintWriter pw, String[] args) {         pw.println(mTag + ": ");         pw.println("mSettingEnabled " + mSettingEnabled);         pw.println("currentTime: " + mClock.getWallClockMillis());         pw.println("mNotificationRepeatTime: " + mNotificationRepeatTime);         pw.println("mState: " + mState);         pw.println("mBlacklistedSsids: " + mBlacklistedSsids.toString());     }
    private class AvailableNetworkNotifierStoreData implements SsidSetStoreData.DataSource {         @Override         public Set<String> getSsids() {             return new ArraySet<>(mBlacklistedSsids);         }
        @Override         public void setSsids(Set<String> ssidList) {             mBlacklistedSsids.addAll(ssidList);             mWifiMetrics.setNetworkRecommenderBlacklistSize(mTag, mBlacklistedSsids.size());         }     }
    private class NotificationEnabledSettingObserver extends ContentObserver {         NotificationEnabledSettingObserver(Handler handler) {             super(handler);         }
        public void register() {             mFrameworkFacade.registerContentObserver(mContext,                     Settings.Global.getUriFor(mToggleSettingsName), true, this);             mSettingEnabled = getValue();         }
        @Override         public void onChange(boolean selfChange) {             super.onChange(selfChange);             mSettingEnabled = getValue();             clearPendingNotification(true /* resetRepeatTime */);         }
        private boolean getValue() {             boolean enabled =                     mFrameworkFacade.getIntegerSetting(mContext, mToggleSettingsName, 1) == 1;             mWifiMetrics.setIsWifiNetworksAvailableNotificationEnabled(mTag, enabled);             Log.d(mTag, "Settings toggle enabled=" + enabled);             return enabled;         }     } } ==========================================================================================================================================================================================   vendor\mediatek\proprietary\packages\apps\MtkSettings\src\com\android\settings\wifi\WifiSettings.java

/*  * Copyright (C) 2010 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 static android.net.NetworkCapabilities.TRANSPORT_WIFI; import static android.os.UserManager.DISALLOW_CONFIG_WIFI;
import android.annotation.NonNull; import android.app.Activity; import android.app.Dialog; import android.app.settings.SettingsEnums; import android.content.ContentResolver; import android.content.Context; import android.content.DialogInterface; import android.content.Intent; import android.content.res.Resources; import android.net.ConnectivityManager; import android.net.Network; import android.net.NetworkInfo; import android.net.NetworkInfo.State; import android.net.NetworkRequest; import android.net.NetworkTemplate; import android.net.wifi.WifiConfiguration; import android.net.wifi.WifiManager; import android.net.wifi.ScanResult; import android.os.Bundle; import android.os.Handler; import android.os.Looper; import android.os.PowerManager; import android.provider.Settings; import android.util.FeatureFlagUtils; import android.util.Log; import android.view.ContextMenu; import android.view.ContextMenu.ContextMenuInfo; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.Toast;
import androidx.annotation.VisibleForTesting; import androidx.preference.Preference; import androidx.preference.PreferenceCategory;
import com.android.settings.LinkifyUtils; import com.android.settings.R; import com.android.settings.RestrictedSettingsFragment; import com.android.settings.SettingsActivity; import com.android.settings.core.FeatureFlags; import com.android.settings.core.SubSettingLauncher; import com.android.settings.dashboard.SummaryLoader; import com.android.settings.datausage.DataUsageUtils; import com.android.settings.datausage.DataUsagePreference; import com.android.settings.location.ScanningSettings; import com.android.settings.search.BaseSearchIndexProvider; import com.android.settings.search.Indexable; import com.android.settings.search.SearchIndexableRaw; import com.android.settings.Utils; import com.android.settings.widget.SummaryUpdater.OnSummaryChangeListener; import com.android.settings.widget.SwitchBarController; import com.android.settings.wifi.details.WifiNetworkDetailsFragment; import com.android.settings.wifi.dpp.WifiDppUtils; import com.android.settingslib.RestrictedLockUtils; import com.android.settingslib.RestrictedLockUtilsInternal; import com.android.settingslib.search.SearchIndexable; import com.android.mtksettingslib.wifi.AccessPoint; import com.android.mtksettingslib.wifi.AccessPoint.AccessPointListener; import com.android.mtksettingslib.wifi.AccessPointPreference; import com.android.mtksettingslib.wifi.WifiSavedConfigUtils; import com.android.mtksettingslib.wifi.WifiTracker; import com.android.mtksettingslib.wifi.WifiTrackerFactory; import com.mediatek.settings.UtilsExt; import com.mediatek.settings.ext.IWifiSettingsExt;
import java.util.ArrayList; import java.util.List; import android.text.TextUtils; //XCSW wenjie.gu add for tooltip start import android.os.SystemProperties; //XCSW wenjie.gu add for tooltip end
/**  * Two types of UI are provided here.  *  * The first is for "usual Settings", appearing as any other Setup fragment.  *  * The second is for Setup Wizard, with a simplified interface that hides the action bar  * and menus.  */ @SearchIndexable public class WifiSettings extends RestrictedSettingsFragment         implements Indexable, WifiTracker.WifiListener, AccessPointListener,         WifiDialog.WifiDialogListener, DialogInterface.OnDismissListener {
    private static final String TAG = "WifiSettings";
    private static final int MENU_ID_CONNECT = Menu.FIRST + 6;     @VisibleForTesting     static final int MENU_ID_FORGET = Menu.FIRST + 7;     private static final int MENU_ID_MODIFY = Menu.FIRST + 8;
    public static final int WIFI_DIALOG_ID = 1;
    @VisibleForTesting     static final int ADD_NETWORK_REQUEST = 2;
    // public static List<ScanResult> scanResultList;
    // Instance state keys     private static final String SAVE_DIALOG_MODE = "dialog_mode";     private static final String SAVE_DIALOG_ACCESS_POINT_STATE = "wifi_ap_state";
    private static final String PREF_KEY_EMPTY_WIFI_LIST = "wifi_empty_list";     private static final String PREF_KEY_CONNECTED_ACCESS_POINTS = "connected_access_point";     private static final String PREF_KEY_ACCESS_POINTS = "access_points";     private static final String PREF_KEY_CONFIGURE_WIFI_SETTINGS = "configure_settings";     private static final String PREF_KEY_SAVED_NETWORKS = "saved_networks";     private static final String PREF_KEY_STATUS_MESSAGE = "wifi_status_message";     @VisibleForTesting     static final String PREF_KEY_DATA_USAGE = "wifi_data_usage";
    private static final int REQUEST_CODE_WIFI_DPP_ENROLLEE_QR_CODE_SCANNER = 0;
    private static boolean isVerboseLoggingEnabled() {         return WifiTracker.sVerboseLogging || Log.isLoggable(TAG, Log.VERBOSE);     }
    private final Runnable mUpdateAccessPointsRunnable = () -> {         updateAccessPointPreferences();     };     private final Runnable mHideProgressBarRunnable = () -> {         setProgressBarVisible(false);     };
    protected WifiManager mWifiManager;     private ConnectivityManager mConnectivityManager;     private WifiManager.ActionListener mConnectListener;     private WifiManager.ActionListener mSaveListener;     private WifiManager.ActionListener mForgetListener;     private CaptivePortalNetworkCallback mCaptivePortalNetworkCallback;     private IWifiSettingsExt mWifiSettingsExt;
    /**      * The state of {@link #isUiRestricted()} at {@link #onCreate(Bundle)}}. This is neccesary to      * ensure that behavior is consistent if {@link #isUiRestricted()} changes. It could be changed      * by the Test DPC tool in AFW mode.      */     private boolean mIsRestricted;
    private WifiEnabler mWifiEnabler;     // An access point being edited is stored here.     private AccessPoint mSelectedAccessPoint;
    private WifiDialog mDialog;
    private View mProgressHeader;
    // this boolean extra specifies whether to disable the Next button when not connected. Used by     // account creation outside of setup wizard.     private static final String EXTRA_ENABLE_NEXT_ON_CONNECT = "wifi_enable_next_on_connect";     // This string extra specifies a network to open the connect dialog on, so the user can enter     // network credentials.  This is used by quick settings for secured networks, among other     // things.     public static final String EXTRA_START_CONNECT_SSID = "wifi_start_connect_ssid";
    // should Next button only be enabled when we have a connection?     private boolean mEnableNextOnConnection;
    // Save the dialog details     private int mDialogMode;     private AccessPoint mDlgAccessPoint;     private Bundle mAccessPointSavedState;
    @VisibleForTesting     WifiTracker mWifiTracker;     private String mOpenSsid;
    private AccessPointPreference.UserBadgeCache mUserBadgeCache;
    private PreferenceCategory mConnectedAccessPointPreferenceCategory;     private PreferenceCategory mAccessPointsPreferenceCategory;     @VisibleForTesting     AddWifiNetworkPreference mAddWifiNetworkPreference;     @VisibleForTesting     Preference mConfigureWifiSettingsPreference;     @VisibleForTesting     Preference mSavedNetworksPreference;     @VisibleForTesting     DataUsagePreference mDataUsagePreference;     private LinkablePreference mStatusMessagePreference;
    // For Search     public static final String DATA_KEY_REFERENCE = "main_toggle_wifi";
    /**      * Tracks whether the user initiated a connection via clicking in order to autoscroll to the      * network once connected.      */     private boolean mClickedConnect;
    /* End of "used in Wifi Setup context" */
    public WifiSettings() {         super(DISALLOW_CONFIG_WIFI);     }
    @Override     public void onViewCreated(View view, Bundle savedInstanceState) {         super.onViewCreated(view, savedInstanceState);         final Activity activity = getActivity();         if (activity != null) {             mProgressHeader = setPinnedHeaderView(R.layout.progress_header)                     .findViewById(R.id.progress_bar_animation);             setProgressBarVisible(false);         }         ((SettingsActivity) activity).getSwitchBar().setSwitchBarText(                 R.string.wifi_settings_master_switch_title,                 R.string.wifi_settings_master_switch_title);     }
    @Override     public void onCreate(Bundle icicle) {         super.onCreate(icicle);         mWifiSettingsExt = UtilsExt.getWifiSettingsExt(getPrefContext());
      // TODO(b/37429702): Add animations and preference comparator back after initial screen is         // loaded (ODR).         setAnimationAllowed(false);
        addPreferences();
        mIsRestricted = isUiRestricted();     }
    private void addPreferences() {         addPreferencesFromResource(R.xml.wifi_settings);
        mConnectedAccessPointPreferenceCategory =                 (PreferenceCategory) findPreference(PREF_KEY_CONNECTED_ACCESS_POINTS);         mAccessPointsPreferenceCategory =                 (PreferenceCategory) findPreference(PREF_KEY_ACCESS_POINTS);         mConfigureWifiSettingsPreference = findPreference(PREF_KEY_CONFIGURE_WIFI_SETTINGS);         mSavedNetworksPreference = findPreference(PREF_KEY_SAVED_NETWORKS);         mAddWifiNetworkPreference = new AddWifiNetworkPreference(getPrefContext());         mStatusMessagePreference = (LinkablePreference) findPreference(PREF_KEY_STATUS_MESSAGE);         mUserBadgeCache = new AccessPointPreference.UserBadgeCache(getPackageManager());         mDataUsagePreference = findPreference(PREF_KEY_DATA_USAGE);         mDataUsagePreference.setVisible(DataUsageUtils.hasWifiRadio(getContext()));         mDataUsagePreference.setTemplate(NetworkTemplate.buildTemplateWifiWildcard(),                 0 /*subId*/,                 null /*service*/);
        mWifiSettingsExt.init(getPreferenceScreen());     }
    @Override     public void onActivityCreated(Bundle savedInstanceState) {         super.onActivityCreated(savedInstanceState);
        mWifiTracker = WifiTrackerFactory.create(                 getActivity(), this, getSettingsLifecycle(), true, true);         mWifiManager = mWifiTracker.getManager();
        final Activity activity = getActivity();         if (activity != null) {             mConnectivityManager = getActivity().getSystemService(ConnectivityManager.class);         }
        mConnectListener = new WifiConnectListener(getActivity());
        mSaveListener = new WifiManager.ActionListener() {             @Override             public void onSuccess() {             }
            @Override             public void onFailure(int reason) {                 Activity activity = getActivity();                 if (activity != null) {                     Toast.makeText(activity,                             R.string.wifi_failed_save_message,                             Toast.LENGTH_SHORT).show();                 }             }         };
        mForgetListener = new WifiManager.ActionListener() {             @Override             public void onSuccess() {             }
            @Override             public void onFailure(int reason) {                 Activity activity = getActivity();                 if (activity != null) {                     Toast.makeText(activity,                             R.string.wifi_failed_forget_message,                             Toast.LENGTH_SHORT).show();                 }             }         };
        if (savedInstanceState != null) {             mDialogMode = savedInstanceState.getInt(SAVE_DIALOG_MODE);             if (savedInstanceState.containsKey(SAVE_DIALOG_ACCESS_POINT_STATE)) {                 mAccessPointSavedState =                         savedInstanceState.getBundle(SAVE_DIALOG_ACCESS_POINT_STATE);             }         }
        // if we're supposed to enable/disable the Next button based on our current connection         // state, start it off in the right state         Intent intent = getActivity().getIntent();         mEnableNextOnConnection = intent.getBooleanExtra(EXTRA_ENABLE_NEXT_ON_CONNECT, false);
        if (mEnableNextOnConnection) {             if (hasNextButton()) {                 final ConnectivityManager connectivity = (ConnectivityManager)                         getActivity().getSystemService(Context.CONNECTIVITY_SERVICE);                 if (connectivity != null) {                     NetworkInfo info = connectivity.getNetworkInfo(                             ConnectivityManager.TYPE_WIFI);                     changeNextButtonState(info.isConnected());                 }             }         }
        registerForContextMenu(getListView());         setHasOptionsMenu(true);
        if (intent.hasExtra(EXTRA_START_CONNECT_SSID)) {             mOpenSsid = intent.getStringExtra(EXTRA_START_CONNECT_SSID);         }     }
    @Override     public void onDestroyView() {         super.onDestroyView();
        if (mWifiEnabler != null) {             mWifiEnabler.teardownSwitchController();         }     }
    @Override     public void onStart() {         super.onStart();
        // On/off switch is hidden for Setup Wizard (returns null)         mWifiEnabler = createWifiEnabler();
        if (mIsRestricted) {             restrictUi();             return;         }
        onWifiStateChanged(mWifiManager.getWifiState());     }
    private void restrictUi() {         if (!isUiRestrictedByOnlyAdmin()) {             getEmptyTextView().setText(R.string.wifi_empty_list_user_restricted);         }         getPreferenceScreen().removeAll();     }
    /**      * @return new WifiEnabler or null (as overridden by WifiSettingsForSetupWizard)      */     private WifiEnabler createWifiEnabler() {         final SettingsActivity activity = (SettingsActivity) getActivity();         return new WifiEnabler(activity, new SwitchBarController(activity.getSwitchBar()),                 mMetricsFeatureProvider);     }
    @Override     public void onResume() {         final Activity activity = getActivity();         super.onResume();
        // Because RestrictedSettingsFragment's onResume potentially requests authorization,         // which changes the restriction state, recalculate it.         final boolean alreadyImmutablyRestricted = mIsRestricted;         mIsRestricted = isUiRestricted();         if (!alreadyImmutablyRestricted && mIsRestricted) {             restrictUi();         }
        if (mWifiEnabler != null) {             mWifiEnabler.resume(activity);         }     }
    @Override     public void onPause() {         super.onPause();         if (mWifiEnabler != null) {             mWifiEnabler.pause();         }     }
    @Override     public void onStop() {         getView().removeCallbacks(mUpdateAccessPointsRunnable);         getView().removeCallbacks(mHideProgressBarRunnable);         unregisterCaptivePortalNetworkCallback();         super.onStop();     }
    @Override     public void onActivityResult(int requestCode, int resultCode, Intent data) {         super.onActivityResult(requestCode, resultCode, data);
        if (requestCode == ADD_NETWORK_REQUEST) {             handleAddNetworkRequest(resultCode, data);             return;         } else if (requestCode == REQUEST_CODE_WIFI_DPP_ENROLLEE_QR_CODE_SCANNER) {             if (resultCode == Activity.RESULT_OK) {                 if (mDialog != null) {                     mDialog.dismiss();                 }                 mWifiTracker.resumeScanning();             }             return;         }
        final boolean formerlyRestricted = mIsRestricted;         mIsRestricted = isUiRestricted();         if (formerlyRestricted && !mIsRestricted                 && getPreferenceScreen().getPreferenceCount() == 0) {             // De-restrict the ui             addPreferences();         }     }
    @Override     public int getMetricsCategory() {         return SettingsEnums.WIFI;     }
    @Override     public void onSaveInstanceState(Bundle outState) {         super.onSaveInstanceState(outState);         // If dialog has been shown, save its state.         if (mDialog != null) {             outState.putInt(SAVE_DIALOG_MODE, mDialogMode);             if (mDlgAccessPoint != null) {                 mAccessPointSavedState = new Bundle();                 mDlgAccessPoint.saveWifiState(mAccessPointSavedState);                 outState.putBundle(SAVE_DIALOG_ACCESS_POINT_STATE, mAccessPointSavedState);             }         }     }
    @Override     public void onCreateContextMenu(ContextMenu menu, View view, ContextMenuInfo info) {         Preference preference = (Preference) view.getTag();
        if (preference instanceof LongPressAccessPointPreference) {             mSelectedAccessPoint =                     ((LongPressAccessPointPreference) preference).getAccessPoint();             menu.setHeaderTitle(mSelectedAccessPoint.getTitle());             if (mSelectedAccessPoint.isConnectable()) {                 menu.add(Menu.NONE, MENU_ID_CONNECT, 0 /* order */, R.string.wifi_connect);             }
            WifiConfiguration config = mSelectedAccessPoint.getConfig();             // Some configs are ineditable             if (WifiUtils.isNetworkLockedDown(getActivity(), config)) {                 return;             }
            // "forget" for normal saved network. And "disconnect" for ephemeral network because it             // could only be disconnected and be put in blacklists so it won't be used again.             if (mSelectedAccessPoint.isSaved() || mSelectedAccessPoint.isEphemeral()) {                 final int stringId = mSelectedAccessPoint.isEphemeral() ?                     R.string.wifi_disconnect_button_text : R.string.forget;                 menu.add(Menu.NONE, MENU_ID_FORGET, 0 /* order */, stringId);             }
            if ((mSelectedAccessPoint.isSaved() && !mSelectedAccessPoint.isActive())                     || mWifiSettingsExt.addModifyMenu(mSelectedAccessPoint.isSaved())) {                 menu.add(Menu.NONE, MENU_ID_MODIFY, 0 /* order */, R.string.wifi_modify);
                // current connected AP, add a disconnect option to it                 mWifiSettingsExt.updateContextMenu(menu,                     Menu.FIRST + 100, preference);             }         }     }
    @Override     public boolean onContextItemSelected(MenuItem item) {         if (mSelectedAccessPoint == null) {             return super.onContextItemSelected(item);         }         switch (item.getItemId()) {             case MENU_ID_CONNECT: {                 boolean isSavedNetwork = mSelectedAccessPoint.isSaved();                 if (isSavedNetwork) {                     connect(mSelectedAccessPoint.getConfig(), isSavedNetwork);                 } else if ((mSelectedAccessPoint.getSecurity() == AccessPoint.SECURITY_NONE) ||                         (mSelectedAccessPoint.getSecurity() == AccessPoint.SECURITY_OWE) ||                         (mSelectedAccessPoint.getSecurity()                                 == AccessPoint.SECURITY_OWE_TRANSITION)) {                     /** Bypass dialog for unsecured networks */                     mSelectedAccessPoint.generateOpenNetworkConfig();                     connect(mSelectedAccessPoint.getConfig(), isSavedNetwork);                 } else {                     showDialog(mSelectedAccessPoint, WifiConfigUiBase.MODE_CONNECT);                 }                 return true;             }             case MENU_ID_FORGET: {                 forget();                 return true;             }             case MENU_ID_MODIFY: {                 showDialog(mSelectedAccessPoint, WifiConfigUiBase.MODE_MODIFY);                 return true;             }         }         ///M: add mtk feature         if (mWifiSettingsExt != null && mSelectedAccessPoint != null) {             return mWifiSettingsExt.disconnect(item, mSelectedAccessPoint.getConfig());         }         return super.onContextItemSelected(item);     }
    @Override     public boolean onPreferenceTreeClick(Preference preference) {         // If the preference has a fragment set, open that         if (preference.getFragment() != null) {             preference.setOnPreferenceClickListener(null);             return super.onPreferenceTreeClick(preference);         }         /// M: For CMCC and CT feature: add fresh button click @{         if (mWifiSettingsExt.customRefreshButtonClick(preference)) {             return true;         }         /// @}         if (preference instanceof LongPressAccessPointPreference) {             mSelectedAccessPoint = ((LongPressAccessPointPreference) preference).getAccessPoint();             if (mSelectedAccessPoint == null) {                 return false;             }             if (mSelectedAccessPoint.isActive()) {                 return super.onPreferenceTreeClick(preference);             }             /**              * Bypass dialog and connect to unsecured networks, or previously connected saved              * networks, or Passpoint provided networks.              */             switch (WifiUtils.getConnectingType(mSelectedAccessPoint)) {                 case WifiUtils.CONNECT_TYPE_OSU_PROVISION:                     mSelectedAccessPoint.startOsuProvisioning(mConnectListener);                     mClickedConnect = true;                     break;
                case WifiUtils.CONNECT_TYPE_OPEN_NETWORK:                     mSelectedAccessPoint.generateOpenNetworkConfig();                     connect(mSelectedAccessPoint.getConfig(), mSelectedAccessPoint.isSaved());                     break;
                case WifiUtils.CONNECT_TYPE_SAVED_NETWORK:                     connect(mSelectedAccessPoint.getConfig(), true /* isSavedNetwork */);                     break;
                default:                     showDialog(mSelectedAccessPoint, WifiConfigUiBase.MODE_CONNECT);                     break;             }         } else if (preference == mAddWifiNetworkPreference) {             onAddNetworkPressed();         } else {             return super.onPreferenceTreeClick(preference);         }         return true;     }
    private void showDialog(AccessPoint accessPoint, int dialogMode) {         if (accessPoint != null) {             WifiConfiguration config = accessPoint.getConfig();             if (WifiUtils.isNetworkLockedDown(getActivity(), config) && accessPoint.isActive()) {                 RestrictedLockUtils.sendShowAdminSupportDetailsIntent(getActivity(),                         RestrictedLockUtilsInternal.getDeviceOwner(getActivity()));                 return;             }         }
        if (mDialog != null) {             removeDialog(WIFI_DIALOG_ID);             mDialog = null;         }
        // Save the access point and edit mode         mDlgAccessPoint = accessPoint;         mDialogMode = dialogMode;
        showDialog(WIFI_DIALOG_ID);     }
    @Override     public Dialog onCreateDialog(int dialogId) {         switch (dialogId) {             case WIFI_DIALOG_ID:                 // modify network                 if (mDlgAccessPoint == null && mAccessPointSavedState != null) {                     // restore AP from save state                     mDlgAccessPoint = new AccessPoint(getActivity(), mAccessPointSavedState);                     // Reset the saved access point data                     mAccessPointSavedState = null;                 }                 mDialog = WifiDialog                         .createModal(getActivity(), this, mDlgAccessPoint, mDialogMode);                 mSelectedAccessPoint = mDlgAccessPoint;                 return mDialog;         }         return super.onCreateDialog(dialogId);     }
    @Override     public void onDialogShowing() {         super.onDialogShowing();         setOnDismissListener(this);     }
    @Override     public void onDismiss(DialogInterface dialog) {         // We don't keep any dialog object when dialog was dismissed.         mDialog = null;     }
    @Override     public int getDialogMetricsCategory(int dialogId) {         switch (dialogId) {             case WIFI_DIALOG_ID:                 return SettingsEnums.DIALOG_WIFI_AP_EDIT;             default:                 return 0;         }     }
    /**      * Called to indicate the list of AccessPoints has been updated and      * getAccessPoints should be called to get the latest information.      */     @Override     public void onAccessPointsChanged() {         Log.d(TAG, "onAccessPointsChanged (WifiTracker) callback initiated");         updateAccessPointsDelayed();     }
    /**      * Updates access points from {@link WifiManager#getScanResults()}. Adds a delay to have      * progress bar displayed before starting to modify APs.      */     private void updateAccessPointsDelayed() {         // Safeguard from some delayed event handling         if (getActivity() != null && !mIsRestricted && mWifiManager.isWifiEnabled()) {             final View view = getView();             final Handler handler = view.getHandler();             if (handler != null && handler.hasCallbacks(mUpdateAccessPointsRunnable)) {                 return;             }             setProgressBarVisible(true);             view.postDelayed(mUpdateAccessPointsRunnable, 300 /* delay milliseconds */);         }     }
    /** Called when the state of Wifi has changed. */     @Override     public void onWifiStateChanged(int state) {         if (mIsRestricted) {             return;         }
        final int wifiState = mWifiManager.getWifiState();         switch (wifiState) {             case WifiManager.WIFI_STATE_ENABLED:                 updateAccessPointPreferences();                 break;
            case WifiManager.WIFI_STATE_ENABLING:                 //XCSW wenjie.gu add for tooltip start                 setNotificationValue();                 //XCSW wenjie.gu add for tooltip end                 removeConnectedAccessPointPreference();                 removeAccessPointPreference();                 addMessagePreference(R.string.wifi_starting);                 mWifiSettingsExt.emptyCategory(getPreferenceScreen());                 setProgressBarVisible(true);                 break;
            case WifiManager.WIFI_STATE_DISABLING:                 removeConnectedAccessPointPreference();                 removeAccessPointPreference();                 mWifiSettingsExt.emptyCategory(getPreferenceScreen());                 addMessagePreference(R.string.wifi_stopping);                 break;
            case WifiManager.WIFI_STATE_DISABLED:                 mWifiSettingsExt.emptyCategory(getPreferenceScreen());                 setOffMessage();                 setAdditionalSettingsSummaries();                 setProgressBarVisible(false);                 break;         }     }
    /**      * Called when the connection state of wifi has changed.      */     @Override     public void onConnectedChanged() {         changeNextButtonState(mWifiTracker.isConnected());     }
    /** Helper method to return whether an AccessPoint is disabled due to a wrong password */     private static boolean isDisabledByWrongPassword(AccessPoint accessPoint) {         WifiConfiguration config = accessPoint.getConfig();         if (config == null) {             return false;         }         WifiConfiguration.NetworkSelectionStatus networkStatus =                 config.getNetworkSelectionStatus();         if (networkStatus == null || networkStatus.isNetworkEnabled()) {             return false;         }         int reason = networkStatus.getNetworkSelectionDisableReason();         return WifiConfiguration.NetworkSelectionStatus.DISABLED_BY_WRONG_PASSWORD == reason;     }
    public List<ScanResult> getWifiScanResult() {         List<ScanResult> mScanResultList = new ArrayList<>();         List<ScanResult> scanResultList = mWifiManager.getScanResults();         if (scanResultList != null && scanResultList.size() > 0) {             for (int i = 0; i < scanResultList.size(); i++) {                 ScanResult scanResult = scanResultList.get(i);                 if (scanResult != null && !TextUtils.isEmpty(scanResult.SSID)) {                     mScanResultList.add(scanResult);                 } else {                     continue;                 }             }         }         return mScanResultList;     }
    private void updateAccessPointPreferences() {         // in case state has changed         if (!mWifiManager.isWifiEnabled()) {             return;         }         mWifiSettingsExt.emptyCategory(getPreferenceScreen());         // AccessPoints are sorted by the WifiTracker         final List<AccessPoint> accessPoints = mWifiTracker.getAccessPoints();         if (isVerboseLoggingEnabled()) {             Log.i(TAG, "updateAccessPoints called for: " + accessPoints);         }
        boolean hasAvailableAccessPoints = false;         mStatusMessagePreference.setVisible(false);         mConnectedAccessPointPreferenceCategory.setVisible(true);         mAccessPointsPreferenceCategory.setVisible(true);
        cacheRemoveAllPrefs(mAccessPointsPreferenceCategory);
        int index =                 configureConnectedAccessPointPreferenceCategory(accessPoints) ? 1 : 0;         int numAccessPoints = accessPoints.size();         // wangxianqi start         /* boolean isScan5GResultKey = false;         boolean isScan24GResultKey = false;         if (scanResultList != null) {             scanResultList.clear();         }         scanResultList  = getWifiScanResult();         int wifiFrequency = Settings.Global.getInt(getContentResolver(), Settings.Global.WIFI_FREQUENCY_SETTINGS, 0); */         // wangxianqi end         for (; index < numAccessPoints; index++) {             AccessPoint accessPoint = accessPoints.get(index);             // Ignore access points that are out of range.             //XCSW GuoYanjie add for DisableUnSafeWIFI start             if(android.os.SystemProperties.getInt("ro.disable.unsafeWifi",0) == 1){                 if ((accessPoint.getSecurity() == AccessPoint.SECURITY_NONE) || (accessPoint.getSecurity() == AccessPoint.SECURITY_WEP)){                     continue;                 }             }             //XCSW GuoYanjie add for DisableUnSafeWIFI end
            if (accessPoint.isReachable()) {                 String key = accessPoint.getKey();                 // wangxianqi start                 /* isScan24GResultKey = false;                 isScan5GResultKey = false;                 if (wifiFrequency == 0) {
                } else if (wifiFrequency == 1) {                     int indexInt = 0;                     for (; indexInt < scanResultList.size(); indexInt++) {                         if (key.contains(scanResultList.get(indexInt).SSID)) {                             int frequency = scanResultList.get(indexInt).frequency;                             boolean is5G = WifiUtils.is5GHzWifi(frequency);                             if (is5G) {                                 isScan24GResultKey = true;                                 break;                             }                         }                     }                     if (isScan24GResultKey) {                         continue;                     }                 } else if (wifiFrequency == 2) {                     int indexInt = 0;                     for (; indexInt < scanResultList.size(); indexInt++) {                         if (key.contains(scanResultList.get(indexInt).SSID)) {                             int frequency = scanResultList.get(indexInt).frequency;                             boolean is24G = WifiUtils.is24GHzWifi(frequency);                             if (is24G) {                                 isScan5GResultKey = true;                                 break;                             }                         }                     }                     if (isScan5GResultKey) {                         continue;                     }                 } */                 // wangxianqi end                 hasAvailableAccessPoints = true;                 LongPressAccessPointPreference pref =                         (LongPressAccessPointPreference) getCachedPreference(key);                 if (pref != null) {                     pref.setOrder(index);                     continue;                 }                 LongPressAccessPointPreference preference =                         createLongPressAccessPointPreference(accessPoint);                 preference.setKey(key);                 preference.setOrder(index);                 if (mOpenSsid != null && mOpenSsid.equals(accessPoint.getSsidStr())                         && (accessPoint.getSecurity() != AccessPoint.SECURITY_NONE &&                         accessPoint.getSecurity() != AccessPoint.SECURITY_OWE &&                         accessPoint.getSecurity() != AccessPoint.SECURITY_OWE_TRANSITION)) {                     if (!accessPoint.isSaved() || isDisabledByWrongPassword(accessPoint)) {                         onPreferenceTreeClick(preference);                         mOpenSsid = null;                     }                 }                 /// M: modify for cmcc feature @{                 // mAccessPointsPreferenceCategory.addPreference(preference);                 mWifiSettingsExt.addPreference(getPreferenceScreen(),                         mAccessPointsPreferenceCategory, preference,                         accessPoint.getConfig() != null);                 /// @}                 accessPoint.setListener(WifiSettings.this);                 preference.refresh();             }         }         removeCachedPrefs(mAccessPointsPreferenceCategory);
        mAddWifiNetworkPreference.setOrder(index);         /// M: modify for cmcc feature @{         //mAccessPointsPreferenceCategory.addPreference(mAddWifiNetworkPreference);         mWifiSettingsExt.addPreference(getPreferenceScreen(),                 mAccessPointsPreferenceCategory, mAddWifiNetworkPreference, false);         /// @}         setAdditionalSettingsSummaries();
        if (!hasAvailableAccessPoints) {             setProgressBarVisible(true);             Preference pref = new Preference(getPrefContext());             pref.setSelectable(false);             pref.setSummary(R.string.wifi_empty_list_wifi_on);             pref.setOrder(index++);             pref.setKey(PREF_KEY_EMPTY_WIFI_LIST);             /// M: modify for cmcc feature @{             // mAccessPointsPreferenceCategory.addPreference(pref);             mWifiSettingsExt.addPreference(getPreferenceScreen(),                     mAccessPointsPreferenceCategory, pref, false);             /// @}         } else {             // Continuing showing progress bar for an additional delay to overlap with animation             getView().postDelayed(mHideProgressBarRunnable, 1700 /* delay millis */);         }     }
    @NonNull     private LongPressAccessPointPreference createLongPressAccessPointPreference(             AccessPoint accessPoint) {         return new LongPressAccessPointPreference(accessPoint, getPrefContext(), mUserBadgeCache,                 false /* forSavedNetworks */, R.drawable.ic_wifi_signal_0, this);     }
    @NonNull     @VisibleForTesting     ConnectedAccessPointPreference createConnectedAccessPointPreference(             AccessPoint accessPoint, Context context) {         return new ConnectedAccessPointPreference(accessPoint, context, mUserBadgeCache,                 R.drawable.ic_wifi_signal_0, false /* forSavedNetworks */, this);     }
    /**      * Configure the ConnectedAccessPointPreferenceCategory and return true if the Category was      * shown.      */     private boolean configureConnectedAccessPointPreferenceCategory(             List<AccessPoint> accessPoints) {         /// M: in cmcc project, can not create connectedAccessPointPreference() {@         if (mWifiSettingsExt.removeConnectedAccessPointPreference()) {             return false;         }         /// @}         if (accessPoints.size() == 0) {             removeConnectedAccessPointPreference();             return false;         }
        AccessPoint connectedAp = accessPoints.get(0);         if (!connectedAp.isActive()) {             removeConnectedAccessPointPreference();             return false;         }
        // Is the preference category empty?         if (mConnectedAccessPointPreferenceCategory.getPreferenceCount() == 0) {             addConnectedAccessPointPreference(connectedAp);             return true;         }
        // Is the previous currently connected SSID different from the new one?         ConnectedAccessPointPreference preference =                 (ConnectedAccessPointPreference)                         (mConnectedAccessPointPreferenceCategory.getPreference(0));         // The AccessPoints need to be the same reference to ensure that updates are reflected         // in the UI.         if (preference.getAccessPoint() != connectedAp) {             removeConnectedAccessPointPreference();             addConnectedAccessPointPreference(connectedAp);             return true;         }
        // Else same AP is connected, simply refresh the connected access point preference         // (first and only access point in this category).         preference.refresh();         // Update any potential changes to the connected network and ensure that the callback is         // registered after an onStop lifecycle event.         registerCaptivePortalNetworkCallback(getCurrentWifiNetwork(), preference);         return true;     }
    /**      * Creates a Preference for the given {@link AccessPoint} and adds it to the      * {@link #mConnectedAccessPointPreferenceCategory}.      */     private void addConnectedAccessPointPreference(AccessPoint connectedAp) {         final ConnectedAccessPointPreference pref =                 createConnectedAccessPointPreference(connectedAp, getPrefContext());         registerCaptivePortalNetworkCallback(getCurrentWifiNetwork(), pref);
        // Launch details page or captive portal on click.         pref.setOnPreferenceClickListener(                 preference -> {                     pref.getAccessPoint().saveWifiState(pref.getExtras());                     if (mCaptivePortalNetworkCallback != null                             && mCaptivePortalNetworkCallback.isCaptivePortal()) {                         mConnectivityManager.startCaptivePortalApp(                                 mCaptivePortalNetworkCallback.getNetwork());                     } else {                         launchNetworkDetailsFragment(pref);                     }                     return true;                 });
        pref.setOnGearClickListener(                 preference -> {                     pref.getAccessPoint().saveWifiState(pref.getExtras());                     launchNetworkDetailsFragment(pref);                 });
        pref.refresh();
        mConnectedAccessPointPreferenceCategory.addPreference(pref);         mConnectedAccessPointPreferenceCategory.setVisible(true);         if (mClickedConnect) {             mClickedConnect = false;             scrollToPreference(mConnectedAccessPointPreferenceCategory);         }     }
    private void registerCaptivePortalNetworkCallback(             Network wifiNetwork, ConnectedAccessPointPreference pref) {         if (wifiNetwork == null || pref == null) {             Log.w(TAG, "Network or Preference were null when registering callback.");             return;         }
        if (mCaptivePortalNetworkCallback != null                 && mCaptivePortalNetworkCallback.isSameNetworkAndPreference(wifiNetwork, pref)) {             return;         }
        unregisterCaptivePortalNetworkCallback();
        mCaptivePortalNetworkCallback = new CaptivePortalNetworkCallback(wifiNetwork, pref);         mConnectivityManager.registerNetworkCallback(                 new NetworkRequest.Builder()                         .clearCapabilities()                         .addTransportType(TRANSPORT_WIFI)                         .build(),                 mCaptivePortalNetworkCallback,                 new Handler(Looper.getMainLooper()));     }
    private void unregisterCaptivePortalNetworkCallback() {         if (mCaptivePortalNetworkCallback != null) {             try {                 mConnectivityManager.unregisterNetworkCallback(mCaptivePortalNetworkCallback);             } catch (RuntimeException e) {                 Log.e(TAG, "Unregistering CaptivePortalNetworkCallback failed.", e);             }             mCaptivePortalNetworkCallback = null;         }     }
    private void launchAddNetworkFragment() {         new SubSettingLauncher(getContext())                 .setTitleRes(R.string.wifi_add_network)                 .setDestination(AddNetworkFragment.class.getName())                 .setSourceMetricsCategory(getMetricsCategory())                 .setResultListener(this, ADD_NETWORK_REQUEST)                 .launch();     }
    private void launchNetworkDetailsFragment(ConnectedAccessPointPreference pref) {         final AccessPoint accessPoint = pref.getAccessPoint();         final Context context = getContext();         final CharSequence title =                 FeatureFlagUtils.isEnabled(context, FeatureFlags.WIFI_DETAILS_DATAUSAGE_HEADER)                         ? accessPoint.getTitle()                         : context.getText(R.string.pref_title_network_details);
        new SubSettingLauncher(getContext())                 .setTitleText(title)                 .setDestination(WifiNetworkDetailsFragment.class.getName())                 .setArguments(pref.getExtras())                 .setSourceMetricsCategory(getMetricsCategory())                 .launch();     }
    private Network getCurrentWifiNetwork() {         return mWifiManager != null ? mWifiManager.getCurrentNetwork() : null;     }
    /** Removes all preferences and hide the {@link #mConnectedAccessPointPreferenceCategory}. */     private void removeConnectedAccessPointPreference() {         mConnectedAccessPointPreferenceCategory.removeAll();         mConnectedAccessPointPreferenceCategory.setVisible(false);         unregisterCaptivePortalNetworkCallback();     }
    private void removeAccessPointPreference() {         mAccessPointsPreferenceCategory.removeAll();         mAccessPointsPreferenceCategory.setVisible(false);     }
    @VisibleForTesting     void setAdditionalSettingsSummaries() {         /// M: For CMCC and CT feature: add fresh button @{         mWifiSettingsExt.addRefreshPreference(getPreferenceScreen(),                 mWifiTracker, mIsRestricted);         /// @}
        mConfigureWifiSettingsPreference.setSummary(getString(                 isWifiWakeupEnabled()                         ? R.string.wifi_configure_settings_preference_summary_wakeup_on                         : R.string.wifi_configure_settings_preference_summary_wakeup_off));
        final List<AccessPoint> savedNetworks =                 WifiSavedConfigUtils.getAllConfigs(getContext(), mWifiManager);         final int numSavedNetworks = (savedNetworks != null) ? savedNetworks.size() : 0;         mSavedNetworksPreference.setVisible(numSavedNetworks > 0);         if (numSavedNetworks > 0) {             mSavedNetworksPreference.setSummary(                     getSavedNetworkSettingsSummaryText(savedNetworks, numSavedNetworks));         }     }
    private String getSavedNetworkSettingsSummaryText(             List<AccessPoint> savedNetworks, int numSavedNetworks) {         int numSavedPasspointNetworks = 0;         for (AccessPoint savedNetwork : savedNetworks) {             if (savedNetwork.isPasspointConfig() || savedNetwork.isPasspoint()) {                 numSavedPasspointNetworks++;             }         }         final int numSavedNormalNetworks = numSavedNetworks - numSavedPasspointNetworks;
        if (numSavedNetworks == numSavedNormalNetworks) {             return getResources().getQuantityString(R.plurals.wifi_saved_access_points_summary,                     numSavedNormalNetworks, numSavedNormalNetworks);         } else if (numSavedNetworks == numSavedPasspointNetworks) {             return getResources().getQuantityString(                     R.plurals.wifi_saved_passpoint_access_points_summary,                     numSavedPasspointNetworks, numSavedPasspointNetworks);         } else {             return getResources().getQuantityString(R.plurals.wifi_saved_all_access_points_summary,                     numSavedNetworks, numSavedNetworks);         }     }
    private boolean isWifiWakeupEnabled() {         final Context context = getContext();         final PowerManager powerManager = context.getSystemService(PowerManager.class);         final ContentResolver contentResolver = context.getContentResolver();         return Settings.Global.getInt(contentResolver,                 Settings.Global.WIFI_WAKEUP_ENABLED, 0) == 1                 && Settings.Global.getInt(contentResolver,                 Settings.Global.WIFI_SCAN_ALWAYS_AVAILABLE, 0) == 1                 && Settings.Global.getInt(contentResolver,                 Settings.Global.AIRPLANE_MODE_ON, 0) == 0                 && !powerManager.isPowerSaveMode();     }
    private void setOffMessage() {         final CharSequence title = getText(R.string.wifi_empty_list_wifi_off);         // Don't use WifiManager.isScanAlwaysAvailable() to check the Wi-Fi scanning mode. Instead,         // read the system settings directly. Because when the device is in Airplane mode, even if         // Wi-Fi scanning mode is on, WifiManager.isScanAlwaysAvailable() still returns "off".         final boolean wifiScanningMode = Settings.Global.getInt(getActivity().getContentResolver(),                 Settings.Global.WIFI_SCAN_ALWAYS_AVAILABLE, 0) == 1;         final CharSequence description = wifiScanningMode ? getText(R.string.wifi_scan_notify_text)                 : getText(R.string.wifi_scan_notify_text_scanning_off);         final LinkifyUtils.OnClickListener clickListener =                 () -> new SubSettingLauncher(getContext())                         .setDestination(ScanningSettings.class.getName())                         .setTitleRes(R.string.location_scanning_screen_title)                         .setSourceMetricsCategory(getMetricsCategory())                         .launch();         mStatusMessagePreference.setText(title, description, clickListener);         removeConnectedAccessPointPreference();         removeAccessPointPreference();         mStatusMessagePreference.setVisible(true);     }
    private void addMessagePreference(int messageId) {         mStatusMessagePreference.setTitle(messageId);         mStatusMessagePreference.setVisible(true);     }
    protected void setProgressBarVisible(boolean visible) {         if (mProgressHeader != null) {             mProgressHeader.setVisibility(visible ? View.VISIBLE : View.GONE);         }     }
    /**      * Renames/replaces "Next" button when appropriate. "Next" button usually exists in      * Wifi setup screens, not in usual wifi settings screen.      *      * @param enabled true when the device is connected to a wifi network.      */     private void changeNextButtonState(boolean enabled) {         if (mEnableNextOnConnection && hasNextButton()) {             getNextButton().setEnabled(enabled);         }     }
    @Override     public void onForget(WifiDialog dialog) {         forget();     }
    @Override     public void onSubmit(WifiDialog dialog) {         if (mDialog != null) {             submit(mDialog.getController());         }     }
    @Override     public void onScan(WifiDialog dialog, String ssid) {         // Launch QR code scanner to join a network.         startActivityForResult(WifiDppUtils.getEnrolleeQrCodeScannerIntent(ssid),                 REQUEST_CODE_WIFI_DPP_ENROLLEE_QR_CODE_SCANNER);     }
    /* package */ void submit(WifiConfigController configController) {
        final WifiConfiguration config = configController.getConfig();
        if (config == null) {             if (mSelectedAccessPoint != null                     && mSelectedAccessPoint.isSaved()) {                 connect(mSelectedAccessPoint.getConfig(), true /* isSavedNetwork */);             }         } else if (configController.getMode() == WifiConfigUiBase.MODE_MODIFY) {             mWifiManager.save(config, mSaveListener);         } else {             mWifiManager.save(config, mSaveListener);             if (mSelectedAccessPoint != null) { // Not an "Add network"                 connect(config, false /* isSavedNetwork */);             }         }
        mWifiTracker.resumeScanning();     }
    /* package */ void forget() {         mMetricsFeatureProvider.action(getActivity(), SettingsEnums.ACTION_WIFI_FORGET);         if (!mSelectedAccessPoint.isSaved()) {             if (mSelectedAccessPoint.getNetworkInfo() != null &&                     mSelectedAccessPoint.getNetworkInfo().getState() != State.DISCONNECTED) {                 // Network is active but has no network ID - must be ephemeral.                 mWifiManager.disableEphemeralNetwork(                         AccessPoint.convertToQuotedString(mSelectedAccessPoint.getSsidStr()));             } else {                 // Should not happen, but a monkey seems to trigger it                 Log.e(TAG, "Failed to forget invalid network " + mSelectedAccessPoint.getConfig());                 return;             }         } else if (mSelectedAccessPoint.getConfig().isPasspoint()) {             try {                 mWifiManager.removePasspointConfiguration(mSelectedAccessPoint.getConfig().FQDN);             } catch (IllegalArgumentException e) {                 Log.e(TAG, "Failed to remove Passpoint configuration with error: " + e);                 return;             }         } else {             mWifiManager.forget(mSelectedAccessPoint.getConfig().networkId, mForgetListener);         }
        mWifiTracker.resumeScanning();
        // We need to rename/replace "Next" button in wifi setup context.         changeNextButtonState(false);     }
    protected void connect(final WifiConfiguration config, boolean isSavedNetwork) {         // Log subtype if configuration is a saved network.         mMetricsFeatureProvider.action(getContext(), SettingsEnums.ACTION_WIFI_CONNECT,                 isSavedNetwork);         mWifiManager.connect(config, mConnectListener);         mClickedConnect = true;     }
    protected void connect(final int networkId, boolean isSavedNetwork) {         // Log subtype if configuration is a saved network.         mMetricsFeatureProvider.action(getActivity(), SettingsEnums.ACTION_WIFI_CONNECT,                 isSavedNetwork);         mWifiManager.connect(networkId, mConnectListener);     }
    @VisibleForTesting     void handleAddNetworkRequest(int result, Intent data) {         if (result == Activity.RESULT_OK) {             handleAddNetworkSubmitEvent(data);         }         mWifiTracker.resumeScanning();     }
    private void handleAddNetworkSubmitEvent(Intent data) {         final WifiConfiguration wifiConfiguration = data.getParcelableExtra(                 AddNetworkFragment.WIFI_CONFIG_KEY);         if (wifiConfiguration != null) {             mWifiManager.save(wifiConfiguration, mSaveListener);         }     }
    /**      * Called when "add network" button is pressed.      */     private void onAddNetworkPressed() {         // No exact access point is selected.         mSelectedAccessPoint = null;         launchAddNetworkFragment();     }
    @Override     public int getHelpResource() {         return R.string.help_url_wifi;     }
    @Override     public void onAccessPointChanged(final AccessPoint accessPoint) {         Log.d(TAG, "onAccessPointChanged (singular) callback initiated");         View view = getView();         if (view != null) {             view.post(new Runnable() {                 @Override                 public void run() {                     Object tag = accessPoint.getTag();                     if (tag != null) {                         ((AccessPointPreference) tag).refresh();                     }                 }             });         }     }
    @Override     public void onLevelChanged(AccessPoint accessPoint) {         ((AccessPointPreference) accessPoint.getTag()).onLevelChanged();     }
    public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =             new BaseSearchIndexProvider() {                 @Override                 public List<SearchIndexableRaw> getRawDataToIndex(Context context,                         boolean enabled) {                     final List<SearchIndexableRaw> result = new ArrayList<>();                     final Resources res = context.getResources();
                    // Add fragment title if we are showing this fragment                     if (res.getBoolean(R.bool.config_show_wifi_settings)) {                         SearchIndexableRaw data = new SearchIndexableRaw(context);                         data.title = res.getString(R.string.wifi_settings);                         data.screenTitle = res.getString(R.string.wifi_settings);                         data.keywords = res.getString(R.string.keywords_wifi);                         data.key = DATA_KEY_REFERENCE;                         result.add(data);                     }
                    return result;                 }             };
    private static class SummaryProvider             implements SummaryLoader.SummaryProvider, OnSummaryChangeListener {
        private final Context mContext;         private final SummaryLoader mSummaryLoader;
        @VisibleForTesting         WifiSummaryUpdater mSummaryHelper;
        public SummaryProvider(Context context, SummaryLoader summaryLoader) {             mContext = context;             mSummaryLoader = summaryLoader;             mSummaryHelper = new WifiSummaryUpdater(mContext, this);         }

        @Override         public void setListening(boolean listening) {             mSummaryHelper.register(listening);         }
        @Override         public void onSummaryChanged(String summary) {             mSummaryLoader.setSummary(this, summary);         }     }
    public static final SummaryLoader.SummaryProviderFactory SUMMARY_PROVIDER_FACTORY             = new SummaryLoader.SummaryProviderFactory() {         @Override         public SummaryLoader.SummaryProvider createSummaryProvider(Activity activity,                 SummaryLoader summaryLoader) {             return new SummaryProvider(activity, summaryLoader);         }     };         //XCSW wenjie.gu add for tooltip start     public void setNotificationValue(){         SystemProperties.set("persist.sys.wifi.notification.value", "true");     }     //XCSW wenjie.gu add for tooltip end }

标签:10,return,void,WiFi,private,final,import,Android,android
From: https://www.cnblogs.com/gwj0424/p/16980735.html

相关文章

  • Android11 实现侧键打印走纸
    /frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.javaelseif(keyCode==KeyEvent.KEYCODE_F12){      //XCSWw......
  • Android11 双击亮屏 上层修改
    packagecom.android.systemui.qs.tiles;importandroid.content.BroadcastReceiver;importandroid.content.ComponentName;importandroid.content.Context;import......
  • 伙伴福利,100个项目彻底精通Java!【开源】
    为了帮助更多的小伙伴,快速成长进步,冲进大厂中厂,我分享了很多的项目哟,例如:java项目精品实战案例|JavaSwing实战项目但很多小伙伴,还觉得不够,好吧!今天就拿出压箱底的项目......
  • Dart 3 将成为 100% 健全的空安全语言
    Dart3将成为100%健全的空安全语言来源:OSCHINA编辑: Alias_Travis2022-12-1008:07:38 9根据Dart的开发进度,Dart编程语言的第三个主要版本(Dart3......
  • LeetCode HOT 100:组合总和
    题目:39.组合总和题目描述:给你一个没有重复元素的数组,和一个target目标值,返回数组中可以使数字和为目标数target的所有不同组合。什么叫组合?组合就是数组中任意数字组成......
  • 伙伴福利,100个项目彻底精通Java!【开源】
    为了帮助更多的小伙伴,快速成长进步,冲进大厂中厂,我分享了很多的项目哟,例如:java项目精品实战案例|JavaSwing实战项目但很多小伙伴,还觉得不够,好吧!今天就拿出压箱底的项......
  • Android 移动应用性能优化 之 友盟
    移动应用性能优化之友盟​​前言​​​​正文​​​​一、问题​​​​1.ANR​​​​2.NullPointerException​​​​二、友盟使用​​​​1.创建平台应用​​​​2.使......
  • Android 天气APP(七)城市切换 之 城市数据源
    9.城市选择既然是城市切换,那么首先得有城市的数据,数据来源有两种,本地和网络,但是网络数据对手机的网络要求比较高,看起来会延迟很大,所以这里我用本地的数据。也是从网络上找......
  • error: RPC failed; curl 28 OpenSSL SSL_read: Connection was reset, errno 10054 f
    有时从Github上clone项目的时候会出现error:RPCfailed;curl28OpenSSLSSL_read:Connectionwasreset,errno10054fatal:expectedflushafterreflisting错误......
  • P108一个函数返回本地变量的地址是有风险的,
    代码如下 全局变量和static对多线程来讲是不安全的#include<stdio.h>int*f(void);voidg(void);intmain(intargc,charconst*argv[]){int*p=f();......