自制 Magisk 模块,让 Pixel 4 也能用上 Daydream VR|一日一技

你永远不知道 Google 的「大刀」什么时候落下以及它究竟会落在哪里:比如上一秒你还望着刚刚发布的 Pixel 4 流口水,下一秒就发现 Daydream 平台直接被「砍」,作为 Google 发布的最新款旗舰机型,Pixel 4 将不再支持与 Daydream View 设备配对使用。

Pixel 4 无法使用 Daydream VR

当年花了好几百元买的 Daydream View 设备和 Daydream VR 游戏就此作废,把 Daydream View 挂上闲鱼还得提防买家带着「Google 放弃 Daydream VR 平台」的资讯过来漫天砍价。转念一想还是不卖了——好歹我还有 Magisk。

厂商能给但不愿意给的,不代表我们就一定用不上。

前期先做了一番资料搜集,发现 Daydream 这个 VR 平台一直以来都有「认证设备」这一说,只有通过 Google 认证的 Android 设备才能使用 Daydream View 游玩 Daydream 的应用和游戏。早年玩机社区已经有过不少尝试绕过这一限制的尝试,而对系统安全性和完整性验证尤为苛刻的 Pixel 设备而言,简单、无痛的 Magisk 模块自然是最理想的选择。

Google 官方给出的认证设备

遗憾的是目前网络上能够找到的用于添加 Daydream VR 设备支持的 Magisk 模块封装方式早已过时,随着 Magisk 框架的迭代更新,这些模块在最新版 Magisk 中已经无法成功刷入。

能找到的模块都已过期失效

不过综合 XDA-Developers 早年的教程和对这些模块的拆包分析,我倒是基本摸清了获得 Daydream VR 平台认证的主要方法:不需要模拟机型,也不需要更改设备标识,在符合条件的 Android 设备上, /system/etc/permissions 目录下有一个名为 android.hardware.vr.high_performance.xml 的文件,向这个文件中添加如下代码即可让手机变身成为一台支持 Daydream VR 的设备(如果没有该文件则需要手动创建):



接下来要做的就是向 Pixel 4 添加这个文件,上面提到早前的 Magisk 模块已经过时时效, 所以我们需要自己动手做一个

首先,我们需要下载一个通用的 Magisk 模块模板。这里最好使用 Magisk 框架开发者 @topjohnwu 提供的 最新版本

模块模板的下载方法

下载完成后解压,然后删除这几个对本教程而言没有实际作用的文件:

  • .gitattibutes
  • README.md
  • /system 目录下的 placeholder 文件
需要修改的三处

因为是自制模块,我们还需要使用 Magisk 框架开发者提供的 module_installer.sh 脚本来保证刷入成功:点击  页面 中的「Raw」按钮,然后复制页面中打开的所有内容粘贴并替换 META-INF\com\google\android 目录中 update-binary 文件的所有内容。

用这里的内容替换 update-binary 的内容

完成后的 update-binary 文件内容如下:

#!/sbin/sh

TMPDIR=/dev/tmp
MOUNTPATH=/dev/magisk_img

# Default permissions
umask 022

# Initial cleanup
rm -rf $TMPDIR 2>/dev/null
mkdir -p $TMPDIR

# echo before loading util_functions
ui_print() { echo "$1"; }

require_new_magisk() {
ui_print "***********************************"
ui_print " Please install the latest Magisk! "
ui_print "***********************************"
exit 1
}

imageless_magisk() {
[ $MAGISK_VER_CODE -gt 18100 ]
return $?
}

##########################################################################################
# Environment
##########################################################################################

OUTFD=$2
ZIPFILE=$3

mount /data 2>/dev/null

# Load utility functions
if [ -f /data/adb/magisk/util_functions.sh ]; then
. /data/adb/magisk/util_functions.sh
NVBASE=/data/adb
else
require_new_magisk
fi

# Preperation for flashable zips
setup_flashable

# Mount partitions
mount_partitions

# Detect version and architecture
api_level_arch_detect

# Setup busybox and binaries
$BOOTMODE && boot_actions || recovery_actions

##########################################################################################
# Preparation
##########################################################################################

# Extract common files
unzip -oj "$ZIPFILE" module.prop install.sh uninstall.sh 'common/*' -d $TMPDIR >&2

[ ! -f $TMPDIR/install.sh ] && abort "! Unable to extract zip file!"
# Load install script
. $TMPDIR/install.sh

if imageless_magisk; then
$BOOTMODE && MODDIRNAME=modules_update || MODDIRNAME=modules
MODULEROOT=$NVBASE/$MODDIRNAME
else
$BOOTMODE && IMGNAME=magisk_merge.img || IMGNAME=magisk.img
IMG=$NVBASE/$IMGNAME
request_zip_size_check "$ZIPFILE"
mount_magisk_img
MODULEROOT=$MOUNTPATH
fi

MODID=`grep_prop id $TMPDIR/module.prop`
MODPATH=$MODULEROOT/$MODID

print_modname

ui_print "******************************"
ui_print "Powered by Magisk (@topjohnwu)"
ui_print "******************************"

##########################################################################################
# Install
##########################################################################################

# Create mod paths
rm -rf $MODPATH 2>/dev/null
mkdir -p $MODPATH

on_install

# Remove placeholder
rm -f $MODPATH/system/placeholder 2>/dev/null

# Custom uninstaller
[ -f $TMPDIR/uninstall.sh ] && cp -af $TMPDIR/uninstall.sh $MODPATH/uninstall.sh

# Auto Mount
if imageless_magisk; then
$SKIPMOUNT && touch $MODPATH/skip_mount
else
$SKIPMOUNT || touch $MODPATH/auto_mount
fi

# prop files
$PROPFILE && cp -af $TMPDIR/system.prop $MODPATH/system.prop

# Module info
cp -af $TMPDIR/module.prop $MODPATH/module.prop
if $BOOTMODE; then
# Update info for Magisk Manager
if imageless_magisk; then
mktouch $NVBASE/modules/$MODID/update
cp -af $TMPDIR/module.prop $NVBASE/modules/$MODID/module.prop
else
mktouch /sbin/.magisk/img/$MODID/update
cp -af $TMPDIR/module.prop /sbin/.magisk/img/$MODID/module.prop
fi
fi

# post-fs-data mode scripts
$POSTFSDATA && cp -af $TMPDIR/post-fs-data.sh $MODPATH/post-fs-data.sh

# service mode scripts
$LATESTARTSERVICE && cp -af $TMPDIR/service.sh $MODPATH/service.sh

# Handle replace folders
for TARGET in $REPLACE; do
mktouch $MODPATH$TARGET/.replace
done

ui_print "- Setting permissions"
set_permissions

##########################################################################################
# Finalizing
##########################################################################################

cd /
imageless_magisk || unmount_magisk_img
$BOOTMODE || recovery_cleanup
rm -rf $TMPDIR $MOUNTPATH

ui_print "- Done"
exit 0

至此我们完成了对这个自制模块的基础修饰工作,接下来就是向模块添加我们所需要的功能。

具体到这篇文章,我们需要在 /system 目录下新建一个 etc 文件夹,然后在 etc 文件夹中放入 android.hardware.vr.high_performance.xml 文件,文件内容参考上文。添加完成后将整个 magisk-module-installer-master 文件夹重新打包压缩,一个自制的 Daydream 支持模块就做好了。

刷入后的效果

如果你想这个自制模块完美一点,还可以适当修改 module.prop 文件中的内容,包括刷入后在 Magisk Manager 中显示的模块名称(name)、模块作者(author)和模块描述(description)。

接下你就可以打开 Magisk Manager,然后刷入我们制作的模块来为 Pixel 4 开启 Daydream VR 支持了。需要注意的是这个模块的作用仅仅是绕过 Daydream VR 的机型限制,如果你想在 Pixel 4 上使用 Daydream View,还需要额外安装 Google VR ServicesDaydreamDaydream Keyboard 这三款应用。

启用我们的自制模块然后安装好必需应用,你就可以拿起手里的 Daydream View 然后把 Pixel 4 放进去正常使用了。本模块理论上来说也适用于其它 Android 设备,但我这里并没有那么多机型来验证兼容性, 如果你想在其他手机上尝试,请自负风险

最后,你也可以用同样的思路制作一些可以实现其它功能的 Magisk 模块,具体的教程后续会由我们的作者进行更新。如果你觉得手动制作比较麻烦,也可以直接刷入使用我做好的模块。

Daydream Enabler for FLORAL

百度网盘 (提取码:d22s)|  Google DriveDropboxOneDrive

> 下载少数派客户端、关注少数派公众号,发现更多 Android 玩机技巧 :rocket:

> 特惠、好用的硬件产品,尽在 少数派 sspai 官方店铺