你永远不知道 Google 的「大刀」什么时候落下以及它究竟会落在哪里:比如上一秒你还望着刚刚发布的 Pixel 4 流口水,下一秒就发现 Daydream 平台直接被「砍」,作为 Google 发布的最新款旗舰机型,Pixel 4 将不再支持与 Daydream View 设备配对使用。
当年花了好几百元买的 Daydream View 设备和 Daydream VR 游戏就此作废,把 Daydream View 挂上闲鱼还得提防买家带着「Google 放弃 Daydream VR 平台」的资讯过来漫天砍价。转念一想还是不卖了——好歹我还有 Magisk。
厂商能给但不愿意给的,不代表我们就一定用不上。
前期先做了一番资料搜集,发现 Daydream 这个 VR 平台一直以来都有「认证设备」这一说,只有通过 Google 认证的 Android 设备才能使用 Daydream View 游玩 Daydream 的应用和游戏。早年玩机社区已经有过不少尝试绕过这一限制的尝试,而对系统安全性和完整性验证尤为苛刻的 Pixel 设备而言,简单、无痛的 Magisk 模块自然是最理想的选择。
遗憾的是目前网络上能够找到的用于添加 Daydream VR 设备支持的 Magisk 模块封装方式早已过时,随着 Magisk 框架的迭代更新,这些模块在最新版 Magisk 中已经无法成功刷入。
不过综合 XDA-Developers 早年的教程和对这些模块的拆包分析,我倒是基本摸清了获得 Daydream VR 平台认证的主要方法:不需要模拟机型,也不需要更改设备标识,在符合条件的 Android 设备上,/system/etc/permissions
目录下有一个名为 android.hardware.vr.high_performance.xml 的文件,向这个文件中添加如下代码即可让手机变身成为一台支持 Daydream VR 的设备(如果没有该文件则需要手动创建):
<permissions>
<feature name="android.software.vr.mode" />
<feature name="android.hardware.vr.high_performance" />
</permissions>
接下来要做的就是向 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 文件内容如下:
#!/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/permissions
目录(如果没有则需要新建文件夹)下放入一个入 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 Services、Daydream 和 Daydream Keyboard 这三款应用。
启用我们的自制模块然后安装好必需应用,你就可以拿起手里的 Daydream View 然后把 Pixel 4 放进去正常使用了。本模块理论上来说也适用于其它 Android 设备,但我这里并没有那么多机型来验证兼容性,如果你想在其他手机上尝试,请自负风险。
最后,你也可以用同样的思路制作一些可以实现其它功能的 Magisk 模块,具体的教程后续会由我们的作者进行更新。如果你觉得手动制作比较麻烦,也可以直接刷入使用我做好的模块。
Daydream Enabler for FLORAL:
百度网盘(提取码:d22s)| Google Drive | Dropbox | OneDrive
> 下载少数派 客户端、关注 少数派公众号,发现更多 Android 玩机技巧 🚀
> 特惠、好用的硬件产品,尽在 少数派 sspai 官方店铺 🛒