跳过主要内容

Capacitor在不使用插件的情况下实现全屏显示

了解如何使用官方的adjustMarginsForEdgeToEdge配置选项在Capacitor应用中正确配置全屏显示 - 不需要任何插件或hack。

马丁·多纳迪厄

马丁·多纳迪厄

内容营销

Capacitor在不使用插件的情况下实现全屏显示

您正在尝试在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 该选项接受三个值:

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, 在以下设备上测试您的应用:

  1. Android 15+ 设备 - 检查内容是否正确遵循系统栏
  2. 较旧的 Android 版本 - 确保向后兼容
  3. 不同屏幕尺寸 - 验证布局在不同设备上工作
  4. 浅色和深色主题 - 测试两种主题模式

常见错误

避免使用此类插件

您不需要像这样的第三方插件 capacitor-edge-to-edge __CAPGO_KEEP_0__

避免与手动实现混淆

如果您正在使用 adjustMarginsForEdgeToEdge,请移除任何手动窗口边距处理或CSS黑客。

不要忘记安全区域CSS

配置文件处理了边距调整,但您仍需要使用CSS安全区域边距来获得正确的内容填充。

迁移指南

如果您当前正在使用边缘到边缘的插件或黑客:

  1. 从您的依赖项中移除任何边缘到边缘的插件 添加配置选项
  2. 到您的 __CAPGO_KEEP_1__ capacitor.config.ts
  3. 清洁和重建 您的 Android 项目
  4. 在目标设备上进行彻底测试 为未来的需求做好准备
# 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" 在测试中

  1. 现在 "auto" 尽早捕捉任何问题 更新您的 CSS
  2. 以正确处理安全区域 适当地
  3. Review your layouts 在启用边缘到边缘的设备上

额外资源

结论

在Capacitor中,边缘到边缘显示不需要插件、hack或复杂的工作-around。配置选项提供了一个干净、原生的解决方案,得到官方支持并且是未来可行的。 adjustMarginsForEdgeToEdge 对于大多数应用程序,

在多个设备上进行彻底测试,并添加适当的安全区域CSS。您的应用程序将在Android 15和以后版本中以最小的努力准备就绪。 "auto" 有任何问题或遇到问题?

__CAPGO_KEEP_0__ The Capacitor community and 是获取额外帮助的绝佳资源。

Capacitor 应用的实时更新

当 web 层面的 bug 在实时更新时,通过 Capgo 来修复 bug,而不是等待几天的 app store 审核。用户在后台接收更新,而原生变化仍然在正常的审查路径中。

立即开始

最新博客

Capgo 为您提供了创建真正专业的移动应用所需的最佳见解。