Skip to content
This repository has been archived by the owner on Jun 7, 2024. It is now read-only.

Latest commit

 

History

History
194 lines (167 loc) · 14.4 KB

readme_en.md

File metadata and controls

194 lines (167 loc) · 14.4 KB

🌐中文
🌐English
🌐Русский

About

After adding some small functions to exagear (3.0.2) (mainly through modifying dex), I found it is too troublesome to manually change smali after all.
Even if a tutorial telling the modified location and codes is provided, it is not suitable for most people who have no experience of apk modification.
So I'm wondering if I can make an application. The user only needs to click a button and wait for the automatic modification to complete, then install the new apk. So this application was born. Due to my limited knowledge, 100% modification success or compatibility with all versions of exagear is not guaranteed.

Usage

Steps

  1. Select exagear apk from installed apks list or local files. Wait until decoded session completes.
  2. Check the function you want to add. Function descriptions are described below.
  3. Click the "start patch" button and wait patientlly until building completes. The building info can be found in the log info.
  4. After building the apk, click the "install patched apk" button to install it.

Attention

  1. This apk is an experimental project, and it is not guaranteed that the function will be added successfully
  2. After clicking"start patch" button, please don't click or move to other view, otherwise problems may occur.
  3. The patched apk is located in /storage/emulated/0/Android/data/com.ewt45.patchapp/files/patchtmp/tmp/dist/signed/tmp_sign.apk. You can check it manually with third-party file manager app.
  4. If the option " use default signature" in Settings is unchecked, after patching you need to uninstall the existing apks which use the same package name or sharedUserId (nornally the exagear and virgl overlay) first. If you need virgl overlay, please resign them with the same signature manually.

Available Functions

Third-party project dependencies

Change Log

v1.0.0

  • EDPatch brand new UI
    • The three steps are divided into separate screens, tap FAB in the upper right corner to go to the next step, and press the phone's back button to return to the previous step.
    • The log interface can be displayed by scrolling down from the title position.
    • Use RecyclerView to display function list, add split line, items will be in two columns on wide screen, tap an item to see function introduction, functions now support displaying function version number.
    • When selecting apk from Installed Apps, results sorting ignores upper/lower case and displays app icon.
    • Guide - function introduction layout scrolls more smoothly.
  • Old functions updated:
    1. FAB - PulseAudio: work directory and log directory changed to z:/opt/edpatch/pulseaudio-xsdl
    2. Container Settings - Renderer: txt location changed to /opt/edpatch/renderers.txt
    3. Custom Controls:
      • Absolute position click: 1st finger long press, 2nd finger press = mouse right button long press
      • Relative position click: 2nd finger = right click now can be triggered more easily.
  • New functions available:
    1. FAB - Virgl Overlay: this feature is only enabled for apk with old VO view(OverlayBuildUI) added. It will remove the old view inserted at the top of content view.
    2. Container Settings - Extra Launching Arguments
      • These params will be inserted into the original command when launching the container. Full command can be found at /sdcard/x86-stderr.txt.
      • If the parameter is already included in the original command, the insertion may fail. The actual result can be viewed by clicking "Preview" button to enter the test command or viewed in the txt after starting the container.
      • All available params are stored at z:/opt/edpatch/contArgs.txt, and the parameters enabled for each container are stored at z:/home/xdroid_n/contArgs.txt. However, it is not recommended to modify the txt directly due to strict requirements on the storage format.
      • Argument type is either ENV or CMD.
        • Environment Variable: Used for the command to be executed. If the original cmd contains a env with the same name, this params will be overridden.
        • Cmd: If it's before/after the original cmd, this cmd and the original cmd are connected with one '&'.

v0.1.1

  • Old functions updated:
  1. select obb manually
  • fix: clicking the blank space leads to an error of tmp.obb not found.
  • support bundled obb file (place it at apk/assets/obb/*.obb or apk/lib/armeabi-v7a/libres.so)
  1. Custom location of drive D
  • Name changed: Change Locations of Drives
  • able to add multiple drives. All containers use the same config, config file saved at z:/opt/drives.txt
  • able to display more that one external device, named as "other storage device - (1,2...)". The old name "Sd card" is not accurate. Root folder is now added as an option for external devices.
  1. Custom Control
  • fix: When editing one column of Left&Right side layout, reselect keys result in reset of key's order.

  • Others: fix: custom resolution function doesn't read the installed version number correctly.

v0.1.0

  • Old functions updated:
  1. container settings - renderers
  • fix: if lines start with # appears in the middle of txt, the lines below will not be read correctly.
  • txt supports adding undefined renderers.(copy a renderer lines, change its key, name and env) after added it will be shown in the options.
  1. app shortcut
  • support icons. (if any)
  1. show cursor
  • fix: in the last version(v0.0.6) assets/mouse.png is missing

v0.0.6

  • New functions available:
  1. Xegw: In the gear button. Provide -legacy-drawing param to solve the problem of only a black screen with an arrow mouse displaying.
  • Old functions updated:
  1. pulseaudio: keep .config/pulse/deamon.conf while deleting other cache files.
  2. Custom Control
  • First-person viewport movement: Renamed to Restrict mouse movement. Two options are shown when checked: Position-update interval and Limited distance. New mouse movement option for joystick buttons. Touchpad mode is also adjusted to limit or not the movement distance according to the settings.
  • Fix the problem of transparency lost when button is in long-press mode.
  1. container settings - renderers:In renderer.txt, 'path' lines are changed to 'env' lines, so that more custom env params can be added by user,After upgrading this function, it is recommended to delete /opt/renderers.txt and then open the container settings once to see the formatting in the automatically generated txt.
  • Others:
  1. Disable Install button if there's no patched apk.

v0.0.5

  • New functions available:
  1. PulseAudio (XSDL): PulseAudio is used to play audio, reducing sound problems. This function uses PulseAudio server extracted from Xserver XSDL. It requires 64-bit support on your device.
  • Old functions updated:
  1. float action button:
    • Long press to hide.
    • export logcat logs: If there's a folder named logcat in drive d, the logs will be saved inside this folder. Helpful when debugging.
  2. container settings - renderer:
    • Multiwine v1 used to be combined with this function internally, but v2 no more. If v2 is patched, you have to patch this manually if you want to continue to use it.
    • Set diffrent LD_LIBRARY_PATH for different renderers. libGL.so.1 will be loaded from this path with higher priority. You can edit paths in z:/opt/renderers.txt.
    • Some renderer options have additional operations:
      • None turnip renderers: Redirect VK_ICD_FILENAMES to a non-exist file, in case these renderers won't work.
      • virgl built-in: Launch libvirgl_test_server.so in a new java process. Only works in xegw apk. No need of Mcat or /opt/start.sh. Log is outputed at Android/data/packageName/logs/virglLog.txt.
      • virtio-gpu: start Mcat. Before Xegw, mcat is used to start proot environment for this renderer, but in xegw it is rewriten to launch /opt/start.sh and won't launch proot automatically.
  • Others:
  1. apk size shrunk.

v0.0.4

  • MultiWIne v2 :Added a download icon on the left-top of "containers manager" page, click to enter the "add/remove wines" page.
    • Local: Edit the downloaded or bundled Wines. After Clicking Install (extract) option, it will be displayed as 'active', which can be selected when creating a new container. Use Uninstall (delete extracted folder) option to reduce local storage. Wines are stored at z:/opt/WineCollection.
    • Downloadable: Download all kinds of Wines from the Internet. Available sources are WineHQ(Official build, only ubuntu18-builds are listed) and Kron4ek(shrinked size, staging versions are not included). Downloaded Wines appear at 'Local' page.
    • how to add bundled Wines into caches: wine binary file should appear at /opt/WineCollection/custom/$TagFolder/$WineFolder/bin/wine
      • $TagFolder : the folder's name represents this wine's name. it shows when creating containers, should be unique.
      • $WineFolder : it should contains the ./bin/wine binary file.
      • also in $TagFolder there should be a .tar.xz archive file, from which $WineFolder will be extracted.
  • container settings - renderer :
    • the renderer option is separated from multiwine now. multiwine v2 alone doesn't have the ability to set environment variables by renderer options in container settings. you need to add the function separately from edpatch.
    • what render options do:
      • each renderer has a diffrent path for libraries e.g.libGL.so.1, this path will be added as LD_LIBRARY_PATH=xxx so that you don't need to replace it at /usr/lib/i386-linux-gnu everytime. If you want to change this path, go to apk's dex -> ContainerSettingsFragment$renderEntries.smali
      • virgl overlay: add VTEST_WIN=1 VTEST_SOCK=
      • VirGL_built_in: run libvirgl_test_server.so from java process (without need of Mcat and /opt/start.sh) , logs output at /sdcard/virglLog.txt
      • virtio-gpu: try to start Mcat, which used to launch a proot environment for this renderer, but xegw replaces the old mcat so it won't work unless you put the old mcat.so back.
      • turnip dxvk: add GALLIUM_DRIVER=zink MESA_VK_WSI_DEBUG=sw

v0.0.3

  • Now Sign apks with default signature. No need to uninstall original one or resign the patched apk manually , but it may be recognized as virus.
  • New functions available: launch exe shortcut directly
    • Long press the app icon, select an exe shortcut, and click to run it.
    • How to add an app shortcut: Click the menu of an exe shortcut on the "Desktop" page, and select "Add as app shortcut".
    • Note: A maximum of four shortcuts can be added. Before launching from shortcut, ensure that the app is not running at background. After deleting the exe shortcut ( .desktop file), the app shortcut will be automatically deleted the next time launching the app . This feature requires Android 7 and above.
  • Old functions updated:
    • show cursor: now try to read the image from z:/opt/mouse.png first, then apk/assets/mouse.png.

v0.0.2

  • EDPatch interface and available functions support Russian now, thanks to Ēlochnik.
  • New functions available: Custom Control
    • Most of the options have descriptions that show up when long pressing. Select "default" of Control in container's properties. After entering the container, three-finger click to edit.
    • Mouse: Toggle visibility of mouse cursor. Switch gesture modes (default mode and touchpad mode) . Set mouse move speed.
    • Buttons: Customize buttons ( keys, text and position) . Switch layout mode (sidebar and free position) . Mouse button keys and joystick style buttons are available.
    • Style: Customize button color, transparency, size, sidebar background color.
  • Old functions updated:
    • android 11+ soft-input no-crashing: Android 11 and above show/hide logic fix, use toggleSoftInput() method (In this way the input method can't hide by clicking from the popup menu, not a big problem, the android back key will be able to hide it). Change the time delay of calling out the input method from 1 second to 0.2 seconds.
    • select obb manually: The position of the text prompt is changed. Now after selecting the file, the text will be replaced by obb selected, decompressing or the selected file is not obb, in case the user selects the right obb without the correct prompt and selects something again. Display the selected file name as a toast. Disable the select button when unpacking.
    • Custom location of drive D: After the app starts, if there is no preset folder (default is Exagear), it will try to create it automatically.
    • custom resolution: Added multi-language support, probably fix the issue that crashing when container_prefs.xml contains a preferenceScreen of an external keyboard link.

v0.0.1

  • First release. Available functions:
    • float action button (Custom location of drive D)
    • show cursor
    • custom resolution
    • android 11+ soft-input no-crashing
    • select obb manually