VirtualDeviceManager
  public
  
  final
  
  class
  VirtualDeviceManager
  
    extends Object
  
  
  
  
  
  
| java.lang.Object | |
| ↳ | android.companion.virtual.VirtualDeviceManager | 
System level service for creation and management of virtual devices.
VirtualDeviceManager enables interactive sharing of capabilities between the host Android device and a remote device.
Not to be confused with the Android Studio's Virtual Device Manager, which allows
 for device emulation.
 
 Restricted for SDK Runtime environment in API level 34.
Summary
| Nested classes | |
|---|---|
| 
        
        
        
        
        interface | VirtualDeviceManager.VirtualDeviceListenerListener for changes in the available virtual devices. | 
| Public methods | |
|---|---|
| 
        
        
        
        
        
        VirtualDevice | 
      getVirtualDevice(int deviceId)
      Returns the details of the virtual device with the given ID, if any. | 
| 
        
        
        
        
        
        List<VirtualDevice> | 
      getVirtualDevices()
      Returns the details of all available virtual devices. | 
| 
        
        
        
        
        
        void | 
      registerVirtualDeviceListener(Executor executor, VirtualDeviceManager.VirtualDeviceListener listener)
      Registers a virtual device listener to receive notifications when virtual devices are created or closed. | 
| 
        
        
        
        
        
        void | 
      unregisterVirtualDeviceListener(VirtualDeviceManager.VirtualDeviceListener listener)
      Unregisters a virtual device listener previously registered with
  | 
| Inherited methods | |
|---|---|
Public methods
getVirtualDevice
public VirtualDevice getVirtualDevice (int deviceId)
Returns the details of the virtual device with the given ID, if any.
The returned object is a read-only representation of the virtual device that expose its properties.
Note that if the virtual device is closed and becomes invalid, the returned object will
 not be updated and may contain stale values. Use a VirtualDeviceListener for real
 time updates of the availability of virtual devices.
| Parameters | |
|---|---|
| deviceId | int | 
| Returns | |
|---|---|
| VirtualDevice | the virtual device with the requested ID, or nullif no such device exists or
   it has already been closed. | 
getVirtualDevices
public List<VirtualDevice> getVirtualDevices ()
Returns the details of all available virtual devices.
The returned objects are read-only representations that expose the properties of all existing virtual devices.
Note that if a virtual device is closed and becomes invalid, the returned objects will
 not be updated and may contain stale values. Use a VirtualDeviceListener for real
 time updates of the availability  of virtual devices.
| Returns | |
|---|---|
| List<VirtualDevice> | This value cannot be null. | 
registerVirtualDeviceListener
public void registerVirtualDeviceListener (Executor executor, VirtualDeviceManager.VirtualDeviceListener listener)
Registers a virtual device listener to receive notifications when virtual devices are created or closed.
| Parameters | |
|---|---|
| executor | Executor: The executor where the listener is executed on.
 This value cannot benull.
 Callback and listener events are dispatched through thisExecutor, providing an easy way to control which thread is
 used. To dispatch events through the main thread of your
 application, you can useContext.getMainExecutor().
 Otherwise, provide anExecutorthat dispatches to an appropriate thread. | 
| listener | VirtualDeviceManager.VirtualDeviceListener: The listener to add.
 This value cannot benull. | 
unregisterVirtualDeviceListener
public void unregisterVirtualDeviceListener (VirtualDeviceManager.VirtualDeviceListener listener)
Unregisters a virtual device listener previously registered with
 registerVirtualDeviceListener(Executor, VirtualDeviceListener).
| Parameters | |
|---|---|
| listener | VirtualDeviceManager.VirtualDeviceListener: The listener to unregister.
 This value cannot benull. | 
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2025-08-20 UTC.
