Skip to content
/ duo-de Public

Surface Duo Desktop Experience (Android 14 | 🍰 AOSP | Custom ROM | Treble GSI | Stable | Duo1 | Duo2)

License

Notifications You must be signed in to change notification settings

Archfx/duo-de

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

duo-de [surface-duo desktop experience]

This is a GSI variant ROM build targetted for Microsoft Surface Duo with the intention of using the Surface Duo as a desktop environment using experimental floating window features. This build combines gapps/vanila variants of the GSI ROM from ponces with desktop mode enabled + various tweaks to make it nice and smooth with the help of thain tweaks. All credits go to respective developers. Desktop mode can be disabled from the home settings, if required. The latest version is stable and secure for daily usage.

Before you proceed, please take a moment to read this announcement regarding this project. By using this ROM, you are agreeing to the DISCLAIMER.

GitHub Downloads (all assets, all releases) GitHub Actions Workflow Status

drawing

Posture Engine

With the posture processor engine, both duo1 and duo2 react to various postures. Specifically, the touch configurations and display settings will toggle between left-screen phone mode, right-screen phone mode, and tablet mode based on the hinge position. The hinge gaps can be enabled/disabled through the treble app.

drawing drawing

This ROM switches between tablet mode (first image) and phone mode (second image) when you change the postures. These modes are optimized (both visually and utility-wise) for each of the situations and the screen's real state.

drawing drawing

Note: In case your device does not react to tent or ramp mode (landscaped phone mode) by default, you have to enable it from the home settings. When you are in Phone mode, click and hold on the display, click Home settings on the popup menu, and enable the Allow home screen rotation feature. This will enable the launcher to serve the Tent mode and Ramp modes.

Benchmarks

These results are just for reference (for people who enjoy numbers) to compare the CPU and GPU performance of this ROM (latest build) with other operating system options. The best case numbers of each operating system are included in the graphs.

Comparison duo-de Results
Duo1 CPU duo-de cpu
Duo1 GPU duo-de gpu

Flashing steps

Try this at your own risk and proceed with caution!

Following are the steps to flash this image to your surface duo.

  1. Download the release.
wget https://github.com/Archfx/duo-de/releases/download/[[version]]/aosp-arm64-ab-gapps-14.0-[[version]].img.xz
  1. Extract the compressed *.xz file to obtain the *.img. (Windows users can use something like 7-zip, Linux and Mac users can use either of following commands with respective commandline utilities).
tar -xf aosp-arm64-ab-gapps-14.0-[[version]].img.xz #tar utility
gunzip aosp-arm64-ab-gapps-14.0-[[version]].img.xz #gunzip utility
  1. If you are migrating from Android 12L (stock) follow this step. You need to unlock the bootloader before proceeding. Please pay attention to commands, do not copy and execute the commands blindly.
adb reboot fastboot
fastboot delete-logical-partition system_ext
fastboot delete-logical-partition product

#get the current slot
fastboot getvar current-slot
# if current slot is a, delete the system_b
fastboot delete-logical-partition system_b
# if current slot is b, delete the system_a
fastboot delete-logical-partition system_a

fastboot flash system aosp-arm64-ab-gapps-14.0-[[version]].img
fastboot reboot 
  1. Migrating from 13/14 pixel experience, follow the below steps
adb reboot fastboot
fastboot flash system aosp-arm64-ab-gapps-14.0-[[version]].img
fastboot reboot 
  1. Enable the following settings from the developer options and perform a manual reboot.
  • Force activities to be resizable
  • Enable freeform windows
  • Enable non-resizable in multi-window
  1. Once you flash a duo-de version using the above steps, subsequent updates will be received using OTA. You can check updates using settings -> system -> system updates.

  2. If you wish to see future updates and feature improvements, consider starring (★) the project—it motivates the development of new releases!

Issues

Any issues, please open an issue with a detailed description. Please use the discussion section for any questions regarding flashing and similar stuff.

Credits

These people have helped this project in some way or another, so they should be the ones who receive all the credit:

phhusson AndyYan eremitein kdrag0n Peter Cai haridhayal11 sooti Iceows ChonDoit ponces thai-ng Axel

Disclaimer

THIS REPOSITORY CONTAINS A CUSTOM ANDROID GENERIC SYSTEM IMAGE (GSI) ROM PROVIDED "AS IS," WITHOUT WARRANTY OF ANY KIND. USE, DOWNLOAD, OR INSTALLATION OF THIS SOFTWARE IS AT YOUR OWN RISK. THE AUTHORS ARE NOT LIABLE FOR ANY DAMAGES, INCLUDING BUT NOT LIMITED TO DEVICE DAMAGE, DATA LOSS, OR OTHER ISSUES RESULTING FROM THE USE OR INSTALLATION OF THIS ROM. INSTALLING CUSTOM ROMS MAY VOID YOUR DEVICE'S WARRANTY AND COULD BRICK YOUR DEVICE, RENDERING IT UNUSABLE. VERIFY COMPATIBILITY WITH YOUR DEVICE BEFORE INSTALLATION. NO GUARANTEE OF UPDATES, FIXES, OR SUPPORT IS PROVIDED. THIRD-PARTY SOFTWARE INCLUDED IS SUBJECT TO ITS OWN TERMS. MODIFICATION AND REDISTRIBUTION ARE PERMITTED UNDER THE PROVIDED LICENSE, BUT AUTHORS DISCLAIM LIABILITY FOR ISSUES ARISING FROM SUCH ACTIONS. BY PROCEEDING, YOU ACCEPT THESE TERMS. IF YOU DO NOT AGREE, DO NOT USE THIS FIRMWARE IMAGE.