Search in sources :

Example 71 with WifiP2pDevice

use of android.net.wifi.p2p.WifiP2pDevice in project android_frameworks_base by ResurrectionRemix.

the class WifiDisplayController method handleConnectionFailure.

private void handleConnectionFailure(boolean timeoutOccurred) {
    Slog.i(TAG, "Wifi display connection failed!");
    if (mDesiredDevice != null) {
        if (mConnectionRetriesLeft > 0) {
            final WifiP2pDevice oldDevice = mDesiredDevice;
            mHandler.postDelayed(new Runnable() {

                @Override
                public void run() {
                    if (mDesiredDevice == oldDevice && mConnectionRetriesLeft > 0) {
                        mConnectionRetriesLeft -= 1;
                        Slog.i(TAG, "Retrying Wifi display connection.  Retries left: " + mConnectionRetriesLeft);
                        retryConnection();
                    }
                }
            }, timeoutOccurred ? 0 : CONNECT_RETRY_DELAY_MILLIS);
        } else {
            disconnect();
        }
    }
}
Also used : WifiP2pDevice(android.net.wifi.p2p.WifiP2pDevice)

Example 72 with WifiP2pDevice

use of android.net.wifi.p2p.WifiP2pDevice in project android_frameworks_base by ResurrectionRemix.

the class WifiDisplayController method dump.

@Override
public void dump(PrintWriter pw, String prefix) {
    pw.println("mWifiDisplayOnSetting=" + mWifiDisplayOnSetting);
    pw.println("mWifiP2pEnabled=" + mWifiP2pEnabled);
    pw.println("mWfdEnabled=" + mWfdEnabled);
    pw.println("mWfdEnabling=" + mWfdEnabling);
    pw.println("mNetworkInfo=" + mNetworkInfo);
    pw.println("mScanRequested=" + mScanRequested);
    pw.println("mDiscoverPeersInProgress=" + mDiscoverPeersInProgress);
    pw.println("mDesiredDevice=" + describeWifiP2pDevice(mDesiredDevice));
    pw.println("mConnectingDisplay=" + describeWifiP2pDevice(mConnectingDevice));
    pw.println("mDisconnectingDisplay=" + describeWifiP2pDevice(mDisconnectingDevice));
    pw.println("mCancelingDisplay=" + describeWifiP2pDevice(mCancelingDevice));
    pw.println("mConnectedDevice=" + describeWifiP2pDevice(mConnectedDevice));
    pw.println("mConnectionRetriesLeft=" + mConnectionRetriesLeft);
    pw.println("mRemoteDisplay=" + mRemoteDisplay);
    pw.println("mRemoteDisplayInterface=" + mRemoteDisplayInterface);
    pw.println("mRemoteDisplayConnected=" + mRemoteDisplayConnected);
    pw.println("mAdvertisedDisplay=" + mAdvertisedDisplay);
    pw.println("mAdvertisedDisplaySurface=" + mAdvertisedDisplaySurface);
    pw.println("mAdvertisedDisplayWidth=" + mAdvertisedDisplayWidth);
    pw.println("mAdvertisedDisplayHeight=" + mAdvertisedDisplayHeight);
    pw.println("mAdvertisedDisplayFlags=" + mAdvertisedDisplayFlags);
    pw.println("mAvailableWifiDisplayPeers: size=" + mAvailableWifiDisplayPeers.size());
    for (WifiP2pDevice device : mAvailableWifiDisplayPeers) {
        pw.println("  " + describeWifiP2pDevice(device));
    }
}
Also used : WifiP2pDevice(android.net.wifi.p2p.WifiP2pDevice)

Example 73 with WifiP2pDevice

use of android.net.wifi.p2p.WifiP2pDevice in project android_frameworks_base by ResurrectionRemix.

the class WifiDisplayController method dump.

private void dump() {
    Slog.d(TAG, "mWifiDisplayOnSetting=" + mWifiDisplayOnSetting);
    Slog.d(TAG, "mWifiP2pEnabled=" + mWifiP2pEnabled);
    Slog.d(TAG, "mWfdEnabled=" + mWfdEnabled);
    Slog.d(TAG, "mWfdEnabling=" + mWfdEnabling);
    Slog.d(TAG, "mNetworkInfo=" + mNetworkInfo);
    Slog.d(TAG, "mScanRequested=" + mScanRequested);
    Slog.d(TAG, "mDiscoverPeersInProgress=" + mDiscoverPeersInProgress);
    Slog.d(TAG, "mDesiredDevice=" + describeWifiP2pDevice(mDesiredDevice));
    Slog.d(TAG, "mConnectingDisplay=" + describeWifiP2pDevice(mConnectingDevice));
    Slog.d(TAG, "mDisconnectingDisplay=" + describeWifiP2pDevice(mDisconnectingDevice));
    Slog.d(TAG, "mCancelingDisplay=" + describeWifiP2pDevice(mCancelingDevice));
    Slog.d(TAG, "mConnectedDevice=" + describeWifiP2pDevice(mConnectedDevice));
    Slog.d(TAG, "mConnectionRetriesLeft=" + mConnectionRetriesLeft);
    Slog.d(TAG, "mRemoteDisplay=" + mRemoteDisplay);
    Slog.d(TAG, "mRemoteDisplayInterface=" + mRemoteDisplayInterface);
    Slog.d(TAG, "mRemoteDisplayConnected=" + mRemoteDisplayConnected);
    Slog.d(TAG, "mAdvertisedDisplay=" + mAdvertisedDisplay);
    Slog.d(TAG, "mAdvertisedDisplaySurface=" + mAdvertisedDisplaySurface);
    Slog.d(TAG, "mAdvertisedDisplayWidth=" + mAdvertisedDisplayWidth);
    Slog.d(TAG, "mAdvertisedDisplayHeight=" + mAdvertisedDisplayHeight);
    Slog.d(TAG, "mAdvertisedDisplayFlags=" + mAdvertisedDisplayFlags);
    Slog.d(TAG, "mAvailableWifiDisplayPeers: size=" + mAvailableWifiDisplayPeers.size());
    for (WifiP2pDevice device : mAvailableWifiDisplayPeers) {
        Slog.d(TAG, "  " + describeWifiP2pDevice(device));
    }
}
Also used : WifiP2pDevice(android.net.wifi.p2p.WifiP2pDevice)

Example 74 with WifiP2pDevice

use of android.net.wifi.p2p.WifiP2pDevice in project android_frameworks_base by ResurrectionRemix.

the class WifiDisplayController method retryConnection.

private void retryConnection() {
    // Cheap hack.  Make a new instance of the device object so that we
    // can distinguish it from the previous connection attempt.
    // This will cause us to tear everything down before we try again.
    mDesiredDevice = new WifiP2pDevice(mDesiredDevice);
    updateConnection();
}
Also used : WifiP2pDevice(android.net.wifi.p2p.WifiP2pDevice)

Example 75 with WifiP2pDevice

use of android.net.wifi.p2p.WifiP2pDevice in project android_frameworks_base by crdroidandroid.

the class WifiDisplayController method updateConnection.

/**
     * This function is called repeatedly after each asynchronous operation
     * until all preconditions for the connection have been satisfied and the
     * connection is established (or not).
     */
private void updateConnection() {
    if (DEBUGV) {
        //new Throwable("WFD_DBG").printStackTrace();
        StackTraceElement[] st = Thread.currentThread().getStackTrace();
        for (int i = 2; i < st.length && i < 5; i++) {
            Slog.i(TAG, st[i].toString());
        }
        dump();
    }
    // Step 0. Stop scans if necessary to prevent interference while connected.
    // Resume scans later when no longer attempting to connect.
    updateScanState();
    // have disconnected from the old one.
    if ((mRemoteDisplay != null || mExtRemoteDisplay != null) && (mConnectedDevice != mDesiredDevice) || (mRemoteDisplayInterface != null && mConnectedDevice == null)) {
        Slog.i(TAG, "Stopped listening for RTSP connection on " + mRemoteDisplayInterface);
        if (mRemoteDisplay != null) {
            mRemoteDisplay.dispose();
        } else if (mExtRemoteDisplay != null) {
            ExtendedRemoteDisplayHelper.dispose(mExtRemoteDisplay);
        }
        mExtRemoteDisplay = null;
        mRemoteDisplay = null;
        mRemoteDisplayInterface = null;
        mHandler.removeCallbacks(mRtspTimeout);
        mWifiP2pManager.setMiracastMode(WifiP2pManager.MIRACAST_DISABLED);
        unadvertiseDisplay();
    // continue to next step
    }
    // Step 2. Before we try to connect to a new device, disconnect from the old one.
    if (mRemoteDisplayConnected || mDisconnectingDevice != null) {
        // wait for asynchronous callback
        return;
    }
    if (mConnectedDevice != null && mConnectedDevice != mDesiredDevice) {
        Slog.i(TAG, "Disconnecting from Wifi display: " + mConnectedDevice.deviceName);
        mDisconnectingDevice = mConnectedDevice;
        mConnectedDevice = null;
        mConnectedDeviceGroupInfo = null;
        unadvertiseDisplay();
        final WifiP2pDevice oldDevice = mDisconnectingDevice;
        mWifiP2pManager.removeGroup(mWifiP2pChannel, new ActionListener() {

            @Override
            public void onSuccess() {
                Slog.i(TAG, "Disconnected from Wifi display: " + oldDevice.deviceName);
                next();
            }

            @Override
            public void onFailure(int reason) {
                Slog.i(TAG, "Failed to disconnect from Wifi display: " + oldDevice.deviceName + ", reason=" + reason);
                next();
            }

            private void next() {
                if (mDisconnectingDevice == oldDevice) {
                    mDisconnectingDevice = null;
                    updateConnection();
                }
            }
        });
        // wait for asynchronous callback
        return;
    }
    // to the old one.
    if (mCancelingDevice != null) {
        // wait for asynchronous callback
        return;
    }
    if (mConnectingDevice != null && mConnectingDevice != mDesiredDevice) {
        Slog.i(TAG, "Canceling connection to Wifi display: " + mConnectingDevice.deviceName);
        mCancelingDevice = mConnectingDevice;
        mConnectingDevice = null;
        unadvertiseDisplay();
        mHandler.removeCallbacks(mConnectionTimeout);
        final WifiP2pDevice oldDevice = mCancelingDevice;
        mWifiP2pManager.cancelConnect(mWifiP2pChannel, new ActionListener() {

            @Override
            public void onSuccess() {
                Slog.i(TAG, "Canceled connection to Wifi display: " + oldDevice.deviceName);
                next();
            }

            @Override
            public void onFailure(int reason) {
                Slog.i(TAG, "Failed to cancel connection to Wifi display: " + oldDevice.deviceName + ", reason=" + reason);
                next();
            }

            private void next() {
                if (mCancelingDevice == oldDevice) {
                    mCancelingDevice = null;
                    updateConnection();
                }
            }
        });
        // wait for asynchronous callback
        return;
    }
    // autonomous GO, then mission accomplished.
    if (mDesiredDevice == null) {
        if (mWifiDisplayCertMode) {
            mListener.onDisplaySessionInfo(getSessionInfo(mConnectedDeviceGroupInfo, 0));
        }
        unadvertiseDisplay();
        // done
        return;
    }
    //Before we connect, we need to set the oldDevice to the desiredDevice to check
    //the device on receiving callbacks from the Remote display modules
    final WifiP2pDevice oldDevice = mDesiredDevice;
    RemoteDisplay.Listener listener = new RemoteDisplay.Listener() {

        @Override
        public void onDisplayConnected(Surface surface, int width, int height, int flags, int session) {
            if (mConnectedDevice == oldDevice && !mRemoteDisplayConnected) {
                Slog.i(TAG, "Opened RTSP connection with Wifi display: " + mConnectedDevice.deviceName);
                mRemoteDisplayConnected = true;
                mHandler.removeCallbacks(mRtspTimeout);
                if (mWifiDisplayCertMode) {
                    mListener.onDisplaySessionInfo(getSessionInfo(mConnectedDeviceGroupInfo, session));
                }
                final WifiDisplay display = createWifiDisplay(mConnectedDevice);
                advertiseDisplay(display, surface, width, height, flags);
            }
        }

        @Override
        public void onDisplayDisconnected() {
            if (mConnectedDevice == oldDevice) {
                Slog.i(TAG, "Closed RTSP connection with Wifi display: " + mConnectedDevice.deviceName);
                mHandler.removeCallbacks(mRtspTimeout);
                mRemoteDisplayConnected = false;
                disconnect();
            }
        }

        @Override
        public void onDisplayError(int error) {
            if (mConnectedDevice == oldDevice) {
                Slog.i(TAG, "Lost RTSP connection with Wifi display due to error " + error + ": " + mConnectedDevice.deviceName);
                mHandler.removeCallbacks(mRtspTimeout);
                handleConnectionFailure(false);
            }
        }
    };
    // Step 5. Try to connect.
    if (mConnectedDevice == null && mConnectingDevice == null) {
        Slog.i(TAG, "Connecting to Wifi display: " + mDesiredDevice.deviceName);
        mConnectingDevice = mDesiredDevice;
        WifiP2pConfig config = new WifiP2pConfig();
        WpsInfo wps = new WpsInfo();
        if (mWifiDisplayWpsConfig != WpsInfo.INVALID) {
            wps.setup = mWifiDisplayWpsConfig;
        } else if (mConnectingDevice.wpsPbcSupported()) {
            wps.setup = WpsInfo.PBC;
        } else if (mConnectingDevice.wpsDisplaySupported()) {
            // We do keypad if peer does display
            wps.setup = WpsInfo.KEYPAD;
        } else {
            wps.setup = WpsInfo.DISPLAY;
        }
        config.wps = wps;
        config.deviceAddress = mConnectingDevice.deviceAddress;
        // Helps with STA & P2P concurrency
        config.groupOwnerIntent = WifiP2pConfig.MIN_GROUP_OWNER_INTENT;
        WifiDisplay display = createWifiDisplay(mConnectingDevice);
        advertiseDisplay(display, null, 0, 0, 0);
        if (ExtendedRemoteDisplayHelper.isAvailable() && mExtRemoteDisplay == null) {
            final int port = getPortNumber(mDesiredDevice);
            //IP is superfluous for WFD source, and we don't have one at this stage anyway since
            //P2P connection hasn't been established yet
            final String iface = "255.255.255.255:" + port;
            mRemoteDisplayInterface = iface;
            Slog.i(TAG, "Listening for RTSP connection on " + iface + " from Wifi display: " + mDesiredDevice.deviceName);
            mExtRemoteDisplay = ExtendedRemoteDisplayHelper.listen(iface, listener, mHandler, mContext);
        }
        final WifiP2pDevice newDevice = mDesiredDevice;
        mWifiP2pManager.connect(mWifiP2pChannel, config, new ActionListener() {

            @Override
            public void onSuccess() {
                // The connection may not yet be established.  We still need to wait
                // for WIFI_P2P_CONNECTION_CHANGED_ACTION.  However, we might never
                // get that broadcast, so we register a timeout.
                Slog.i(TAG, "Initiated connection to Wifi display: " + newDevice.deviceName);
                mHandler.postDelayed(mConnectionTimeout, CONNECTION_TIMEOUT_SECONDS * 1000);
            }

            @Override
            public void onFailure(int reason) {
                if (mConnectingDevice == newDevice) {
                    Slog.i(TAG, "Failed to initiate connection to Wifi display: " + newDevice.deviceName + ", reason=" + reason);
                    mConnectingDevice = null;
                    handleConnectionFailure(false);
                }
            }
        });
        // wait for asynchronous callback
        return;
    }
    // Step 6. Listen for incoming RTSP connection.
    if (mConnectedDevice != null && mRemoteDisplay == null) {
        Inet4Address addr = getInterfaceAddress(mConnectedDeviceGroupInfo);
        if (addr == null) {
            Slog.i(TAG, "Failed to get local interface address for communicating " + "with Wifi display: " + mConnectedDevice.deviceName);
            handleConnectionFailure(false);
            // done
            return;
        }
        mWifiP2pManager.setMiracastMode(WifiP2pManager.MIRACAST_SOURCE);
        final int port = getPortNumber(mConnectedDevice);
        final String iface = addr.getHostAddress() + ":" + port;
        mRemoteDisplayInterface = iface;
        if (!ExtendedRemoteDisplayHelper.isAvailable()) {
            Slog.i(TAG, "Listening for RTSP connection on " + iface + " from Wifi display: " + mConnectedDevice.deviceName);
            mRemoteDisplay = RemoteDisplay.listen(iface, listener, mHandler, mContext.getOpPackageName());
        }
        // Use extended timeout value for certification, as some tests require user inputs
        int rtspTimeout = mWifiDisplayCertMode ? RTSP_TIMEOUT_SECONDS_CERT_MODE : RTSP_TIMEOUT_SECONDS;
        mHandler.postDelayed(mRtspTimeout, rtspTimeout * 1000);
    }
}
Also used : RemoteDisplay(android.media.RemoteDisplay) Inet4Address(java.net.Inet4Address) PeerListListener(android.net.wifi.p2p.WifiP2pManager.PeerListListener) GroupInfoListener(android.net.wifi.p2p.WifiP2pManager.GroupInfoListener) ActionListener(android.net.wifi.p2p.WifiP2pManager.ActionListener) WifiP2pDevice(android.net.wifi.p2p.WifiP2pDevice) WifiP2pConfig(android.net.wifi.p2p.WifiP2pConfig) StackTraceElement(java.lang.StackTraceElement) Surface(android.view.Surface) ActionListener(android.net.wifi.p2p.WifiP2pManager.ActionListener) WifiDisplay(android.hardware.display.WifiDisplay) WpsInfo(android.net.wifi.WpsInfo)

Aggregations

WifiP2pDevice (android.net.wifi.p2p.WifiP2pDevice)101 Test (org.junit.Test)18 WifiDisplay (android.hardware.display.WifiDisplay)12 ArrayList (java.util.ArrayList)8 Activity (android.app.Activity)7 DialogInterface (android.content.DialogInterface)7 OnClickListener (android.content.DialogInterface.OnClickListener)7 WpsInfo (android.net.wifi.WpsInfo)6 WifiP2pConfig (android.net.wifi.p2p.WifiP2pConfig)6 ActionListener (android.net.wifi.p2p.WifiP2pManager.ActionListener)6 GroupInfoListener (android.net.wifi.p2p.WifiP2pManager.GroupInfoListener)6 PeerListListener (android.net.wifi.p2p.WifiP2pManager.PeerListListener)6 Surface (android.view.Surface)6 ByteArrayInputStream (java.io.ByteArrayInputStream)6 DataInputStream (java.io.DataInputStream)6 IOException (java.io.IOException)6 Inet4Address (java.net.Inet4Address)6 RemoteDisplay (android.media.RemoteDisplay)3 StackTraceElement (java.lang.StackTraceElement)3 WifiP2pDeviceList (android.net.wifi.p2p.WifiP2pDeviceList)2