Kể từ ngày 27 tháng 3 năm 2025, bạn nên sử dụng android-latest-release
thay vì aosp-main
để xây dựng và đóng góp cho AOSP. Để biết thêm thông tin, hãy xem phần Thay đổi đối với AOSP.
ModuleMetadata
Sử dụng bộ sưu tập để sắp xếp ngăn nắp các trang
Lưu và phân loại nội dung dựa trên lựa chọn ưu tiên của bạn.
Mô-đun ModuleMetadata chứa siêu dữ liệu về danh sách mô-đun trên một thiết bị nhất định. Siêu dữ liệu được phân tích cú pháp và lưu vào bộ nhớ đệm ngay khi máy chủ hệ thống khởi động.
APK ModuleMetadata chứa ModuleInfoProvider
, triển khai các phương thức getModuleInfo
và getInstalledModules
từ API của PackageManager. Các phương thức này được hỗ trợ bằng siêu dữ liệu XML được phân tích cú pháp từ gói nhà cung cấp siêu dữ liệu mô-đun. Tên gói cho gói siêu dữ liệu mô-đun được lưu trữ trong giá trị cấu hình config_defaultModuleMetadataProvider
.
Nhà cung cấp siêu dữ liệu mô-đun phải chứa mục nhập <metadata>
cho thẻ <application>
. Mục siêu dữ liệu phải chứa một khoá duy nhất (android.content.pm.MODULE_METADATA
) có giá trị là tham chiếu đến một tài nguyên XML chứa siêu dữ liệu về danh sách các mô-đun trên một thiết bị nhất định.
Mô-đun ModuleMetadata (com.android.modulemetadata
) được phân phối dưới dạng tệp APK.
Tài liệu XML phải bao gồm một phần tử <module-metadata>
cấp cao nhất với một hoặc nhiều phần tử con. Mỗi phần tử con là một phần tử <module>
chứa các thuộc tính sau:
name
là một tệp tham chiếu tài nguyên đến tên gói mà người dùng nhìn thấy.
Ánh xạ đến ModuleInfo#getName
.
packageName
là tên gói của mô-đun. Ánh xạ đến ModuleInfo#getPackageName
.
isHidden
cho biết liệu mô-đun có bị ẩn hay không. Ánh xạ đến ModuleInfo#isHidden</code>.
Ví dụ:
<module-metadata>
<module name="@string/resource" packageName="package_name" isHidden="false|true">
<module .... >
</module-metadata>
Nội dung và mã mẫu trên trang này phải tuân thủ các giấy phép như mô tả trong phần Giấy phép nội dung. Java và OpenJDK là nhãn hiệu hoặc nhãn hiệu đã đăng ký của Oracle và/hoặc đơn vị liên kết của Oracle.
Cập nhật lần gần đây nhất: 2025-07-27 UTC.
[[["Dễ hiểu","easyToUnderstand","thumb-up"],["Giúp tôi giải quyết được vấn đề","solvedMyProblem","thumb-up"],["Khác","otherUp","thumb-up"]],[["Thiếu thông tin tôi cần","missingTheInformationINeed","thumb-down"],["Quá phức tạp/quá nhiều bước","tooComplicatedTooManySteps","thumb-down"],["Đã lỗi thời","outOfDate","thumb-down"],["Vấn đề về bản dịch","translationIssue","thumb-down"],["Vấn đề về mẫu/mã","samplesCodeIssue","thumb-down"],["Khác","otherDown","thumb-down"]],["Cập nhật lần gần đây nhất: 2025-07-27 UTC."],[],[],null,["# ModuleMetadata\n\nThe ModuleMetadata module contains metadata about the list of modules on a\ngiven device. The metadata is parsed and cached as soon as the system server\nstarts.\n\nChanges in Android 10\n---------------------\n\nThe ModuleMetadata APK contains `ModuleInfoProvider`, which\nimplements the `getModuleInfo` and `getInstalledModules`\nmethods from the PackageManager's API. These methods are backed\nby XML metadata parsed from a module metadata provider package. The package\nname for the module metadata package is stored in the\n`config_defaultModuleMetadataProvider` config value.\n\nThe module metadata provider must contain a `\u003cmetadata\u003e`\nentry for its `\u003capplication\u003e` tag. The metadata entry must\ncontain a single key (`android.content.pm.MODULE_METADATA`) whose\nvalue is a reference to an XML resource that contains metadata about the list\nof modules on a given device.\n\nPackage format\n--------------\n\nThe ModuleMetadata module (`com.android.modulemetadata`) is delivered\nas an APK file.\n\nMetadata elements\n-----------------\n\nThe XML document must consist of a single top level `\u003cmodule-metadata\u003e`\nelement with one or more children. Each child is a `\u003cmodule\u003e`\nelement that contains the following attributes:\n\n- `name` is a resource reference to a user-visible package name. Maps to `ModuleInfo#getName`.\n- `packageName` is the package name of the module. Maps to `ModuleInfo#getPackageName`.\n- `isHidden` indicates whether the module is hidden. Maps to `ModuleInfo#isHidden\u003c/code\u003e.`\n\nExample: \n\n \u003cmodule-metadata\u003e\n \u003cmodule name=\"@string/resource\" packageName=\"package_name\" isHidden=\"false|true\"\u003e\n \u003cmodule .... \u003e\n \u003c/module-metadata\u003e"]]