您正在尝试在Capacitor应用中实现全屏显示吗? 您不需要任何hack、插件或工作-around。Capacitor支持全屏显示,通过 adjustMarginsForEdgeToEdge 配置选项 - 它并不是广泛文档化的。
许多开发者在Capacitor应用中遇到边缘到边缘布局的问题,尤其是在针对Android 15+时。他们经常使用自定义插件或CSS技巧来实现现代边缘到边缘的外观。但是,有更好的、native的方法。
什么是边缘到边缘显示?
边缘到边缘显示允许您的应用内容延伸到系统栏(状态栏和导航栏)后面,创建一个更沉浸、更现代的UI体验。从Android 15开始,Google推动边缘到边缘成为所有应用的标准。
官方解决方案:调整边缘到边缘的边距
Capacitor提供了 adjustMarginsForEdgeToEdge 配置选项,专门用于此目的。这在__CAPGO_KEEP_0__的官方配置文档中有详细说明 official Capacitor config documentation如何配置它
将此添加到您的
或 capacitor.config.ts 配置文件中 capacitor.config.json:
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.example.app',
appName: 'My App',
webDir: 'dist',
android: {
adjustMarginsForEdgeToEdge: 'auto' // or 'force' or 'disable'
}
};
export default config;
或在 JSON 格式:
{
"appId": "com.example.app",
"appName": "My App",
"webDir": "dist",
"android": {
"adjustMarginsForEdgeToEdge": "auto"
}
}
配置选项
它 adjustMarginsForEdgeToEdge 该选项接受三个值:
1. "auto" (推荐)
adjustMarginsForEdgeToEdge: 'auto'
它做了什么: 自动检查 Android 15+ 和设置。根据设备和配置智能调整边距。 windowOptOutEdgeToEdgeEnforcement 适用于:
大多数希望在支持设备上实现全边缘且与旧版 Android 兼容的生产应用。 它做了什么:
2. "force"
adjustMarginsForEdgeToEdge: 'force'
无论 Android 版本或其他设置如何,都强制边缘调整。 它做了什么:
最佳适用场景: 需要在所有支持的 Android 版本上实现全边缘行为的应用。
3. "disable"
adjustMarginsForEdgeToEdge: 'disable'
它做了什么: 完全禁用自动边距调整。
最佳适用场景: 手动处理全边缘布局或不希望实现全边缘行为的应用。
注意: 目前是默认值,但将在 Capgo 8 中更改为 "disable" 为 Android 15+ 的 Android 设备带来影响 "auto" in Capacitor 8.
Currently
is the default, but this will change to
- 系统栏后面的内容
- 不协调的间距和填充
- 设备间不一致的外观
- 糟糕的用户体验
通过使用官方 adjustMarginsForEdgeToEdge 配置,您可以确保您的应用程序正确处理这些变化而无需自定义 code。
完整示例
以下是现代 Capacitor 应用程序的完整示例配置:
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.example.myapp',
appName: 'My Awesome App',
webDir: 'www',
server: {
androidScheme: 'https'
},
android: {
// Enable edge-to-edge automatically on supported devices
adjustMarginsForEdgeToEdge: 'auto',
// Other Android config options...
backgroundColor: '#ffffff'
}
};
export default config;
CSS注意事项
在使用无边框显示时,您可能需要添加一些CSS来处理安全区域:
/* Add padding for system bars */
body {
padding-top: env(safe-area-inset-top);
padding-bottom: env(safe-area-inset-bottom);
padding-left: env(safe-area-inset-left);
padding-right: env(safe-area-inset-right);
}
/* Or use viewport-fit */
meta[name="viewport"] {
content: "width=device-width, initial-scale=1, viewport-fit=cover";
}
测试您的配置
配置后 adjustMarginsForEdgeToEdge, 在以下设备上测试您的应用:
- Android 15+ 设备 - 检查内容是否正确遵循系统栏
- 较旧的 Android 版本 - 确保向后兼容
- 不同屏幕尺寸 - 验证布局在不同设备上工作
- 浅色和深色主题 - 测试两种主题模式
常见错误
避免使用此类插件
您不需要像这样的第三方插件 capacitor-edge-to-edge __CAPGO_KEEP_0__
避免与手动实现混淆
如果您正在使用 adjustMarginsForEdgeToEdge,请移除任何手动窗口边距处理或CSS黑客。
不要忘记安全区域CSS
配置文件处理了边距调整,但您仍需要使用CSS安全区域边距来获得正确的内容填充。
迁移指南
如果您当前正在使用边缘到边缘的插件或黑客:
- 从您的依赖项中移除任何边缘到边缘的插件 添加配置选项
- 到您的 __CAPGO_KEEP_1__
capacitor.config.ts - 清洁和重建 您的 Android 项目
- 在目标设备上进行彻底测试 为未来的需求做好准备
# Clean the Android project
npx cap sync android
cd android
./gradlew clean
cd ..
# Rebuild
npx cap copy android
npx cap open android
请记住 __CAPGO_KEEP_0__ 8 将会设置
Remember that Capacitor 8 will make "auto" 在测试中
- 现在
"auto"尽早捕捉任何问题 更新您的 CSS - 以正确处理安全区域 适当地
- Review your layouts 在启用边缘到边缘的设备上
额外资源
结论
在Capacitor中,边缘到边缘显示不需要插件、hack或复杂的工作-around。配置选项提供了一个干净、原生的解决方案,得到官方支持并且是未来可行的。 adjustMarginsForEdgeToEdge 对于大多数应用程序,
在多个设备上进行彻底测试,并添加适当的安全区域CSS。您的应用程序将在Android 15和以后版本中以最小的努力准备就绪。 "auto" 有任何问题或遇到问题?
__CAPGO_KEEP_0__ The Capacitor community and 是获取额外帮助的绝佳资源。 由