Remote debug Android devices
image credit to: https://raygun.com/blog

Remote debug Android devices

Remote debug live content on an Android device from your Windows, Mac, or Linux computer. This tutorial teaches you how to:

  • Set up your Android device for remote debugging, and discover it from your development machine.
  • Inspect and debug live content on your Android device from your development machine.
  • Screencast content from your Android device onto a DevTools instance on your development machine.

No alt text provided for this image

image credit: https://developer.chrome.com/docs/devtools/remote-debugging/

Figure 1. Remote Debugging lets you inspect a page running on an Android device from your development machine.

Step 1: Discover your Android device

The workflow below works for most users. See Troubleshooting: DevTools is not detecting the Android device for more help.

  1. Open the Developer Options screen on your Android. See Configure On-Device Developer Options.
  2. Select Enable USB Debugging.
  3. On your development machine, open Chrome.
  4. Go to chrome://inspect#devices.
  5. Make sure that the Discover USB devices checkbox is enabled.

No alt text provided for this image

  1. Figure 2. The Discover USB Devices checkbox is enabled
  2. Connect your Android device directly to your development machine using a USB cable. Your Android device may ask you to confirm that you trust this computer. The first time you do this, you usually see that DevTools has detected an offline device. If you see the model name of your Android device, then DevTools has successfully established the connection to your device. Continue to Step 2.

No alt text provided for this image

  1. Figure 3. The Remote Target has successfully detected an offline device that is pending authorization
  2. If your device is showing up as Offline, accept the Allow USB Debugging permission prompt on your Android device.

Troubleshooting: DevTools is not detecting the Android device

Make sure that your hardware is set up correctly:

  • If you're using a USB hub, try connecting your Android device directly to your development machine instead.
  • Try unplugging the USB cable between your Android device and development machine, and then plugging it back in. Do it while your Android and development machine screens are unlocked.
  • Make sure that your USB cable works. You should be able to inspect files on your Android device from your development machine.

Make sure that your software is set up correctly:

If you don't see the Allow USB Debugging prompt on your Android device try:

  • Disconnecting and then re-connecting the USB cable while DevTools is in focus on your development machine and your Android homescreen is showing. In other words, sometimes the prompt doesn't show up when your Android or development machine screens are locked.
  • Updating the display settings for your Android device and development machine so that they never go to sleep.
  • Setting Android's USB mode to PTP. See Galaxy S4 does not show Authorize USB debugging dialog box.
  • Select Revoke USB Debugging Authorizations from the Developer Options screen on your Android device to reset it to a fresh state.

If you find a solution that is not mentioned in this section or in Chrome DevTools Devices does not detect device when plugged in, please add an answer to that Stack Overflow question, or open an issue in the webfundamentals repository!

Step 2: Debug content on your Android device from your development machine

  1. Open Chrome on your Android device.
  2. In the chrome://inspect/#devices, you see your Android device's model name, followed by its serial number. Below that, you can see the version of Chrome that's running on the device, with the version number in parentheses. Each open Chrome tab gets its own section. You can interact with that tab from this section. If there are any apps using WebView, you see a section for each of those apps, too. In Figure 5 there are no tabs or WebViews open.

No alt text provided for this image

  1. Figure 4. A connected remote device
  2. In the Open tab with url text box, enter a URL and then click Open. The page opens in a new tab on your Android device.
  3. Click Inspect next to the URL that you just opened. A new DevTools instance opens. The version of Chrome running on your Android device determines the version of DevTools that opens on your development machine. So, if your Android device is running a very old version of Chrome, the DevTools instance may look very different than what you're used to.

More actions: pause, focus, reload or close a tab

Below the URL you can find a menu to pause, focus, reload or close a tab.

No alt text provided for this image

Fgure 5. The menu for pausing, reloading, focusing, or closing a tab

Inspect elements

Go to the Elements panel of your DevTools instance, and hover over an element to highlight it in the viewport of your Android device.

You can also tap an element on your Android device screen to select it in the Elements panel. Click Select Element on your DevTools instance, and then tap the element on your Android device screen. Note that Select Element is disabled after the first touch, so you need to re-enable it every time you want to use this feature.

Screencast your Android screen to your development machine

Click Toggle Screencast to view the content of your Android device in your DevTools instance.

You can interact with the screencast in multiple ways:

  • Clicks are translated into taps, firing proper touch events on the device.
  • Keystrokes on your computer are sent to the device.
  • To simulate a pinch gesture, hold Shift while dragging.
  • To scroll, use your trackpad or mouse wheel, or fling with your mouse pointer.

Some notes on screencasts:

  • Screencasts only display page content. Transparent portions of the screencast represent device interfaces, such as the Chrome address bar, the Android status bar, or the Android keyboard.
  • Screencasts negatively affect frame rates. Disable screencasting while measuring scrolls or animations to get a more accurate picture of your page's performance.
  • If your Android device screen locks, the content of your screencast disappears. Unlock your Android device screen to automatically resume the screencast.

Post Credits: Click Here


To view or add a comment, sign in

More articles by Atul Bhalerao

  • Stop iframe video playback - YouTube using jQuery

    Hi All In day to day life most of the frontend develop are always fighting to stop video which is in the modal popup…

  • Bootstrap 5 Navigation Menu Solutions

    The was one of the major issue for mega menu development which is been resolved not have a look Looking for old…

  • How to cast Android screen in Ubuntu

    - For designers and developers only Prerequisites An Android device with at least a 5.0 version It is necessary to…

    4 Comments
  • console.log(); vs window.alert();

    console.log() All modern web browsers, Node.

  • Variable in CSS, seriously?

    When it comes to style guide from designer, we need sass/scss or less to write it, but here we can do it as we did…

  • Get rid of 404 page not found Page

    If you have a domain name but no space, which shows up with 404 PAGE NOT FOUND - Then what is the solution Here is the…

  • How can I modify or disable the HUD's use of the Alt key?

    Yes this is what I want, The HUD is really annoying. Here are the steps for the same.

  • Change the order of DIV (Structure) using CSS flex

    We have many things to do as a frontend developer but the very hated part is to change the structure of the HTML with…

    1 Comment
  • On Click Loader using CSS and Js

    When we think about the request and the response on clicking the button it looks pretty simple but to show the user the…

  • How to use calc in CSS

    Summary: People who know and don't know about it, CSS calc() is used for simple calculations to regulate CSS property…

    1 Comment

Explore content categories