本示例中主要介绍开发者如何使用Native Rawfile接口操作Rawfile目录和文件。功能包括文件列表遍历、文件打开、搜索、读取和关闭Rawfile。
主页 |
---|
使用说明
应用界面中展示了Rawfile相关的接口调用,包括获取resources/rawfile目录下的文件及目录结构、对应的rawfile文件内容、对应rawfile文件的descriptor。其中使用到的功能包括文件列表遍历、文件打开、搜索、读取和关闭Rawfile。
entry/src/main/
|---cpp
| |---types
| | |---libentry
| | | |---index.d.ts // 接口导出
| | | |---oh-package.json5
| |---CMakeLists.txt // 编译脚本
| |---rawfile_demo.cpp // 调用native接口
|---ets
| |---entryability
| | |---EntryAbility.ets
| |---pages
| | |---Index.ets // 首页
| |---utils
| | |---Logger.ets // 日志工具
|---resources
| |---rawfile // rawfile资源
| | |---subrawfile
| | | |---rawfile2.txt
| | |---rawfile.txt
| | |---rawfile1.txt
通过在IDE中创建Native c++ 工程,在cpp目录下的index.d.ts中定义对外js接口,同时在c++中实现接口,映射关系如下:
index.d.ts中的接口名 | rawfile_demo.cpp对应的实现函数 |
---|---|
getFileList | GetFileList |
getRawFileContent | GetRawFileContent |
getRawFileContent64 | GetRawFileContent64 |
getRawFileDescriptor | GetRawFileDescriptor |
getRawFileDescriptor64 | GetRawFileDescriptor64 |
releaseRawFileDescriptor | ReleaseRawFileDescriptor |
releaseRawFileDescriptor64 | ReleaseRawFileDescriptor64 |
通过获取Js的资源对象,并转为Native的资源对象,即可调用资源的Native接口,获取rawfile列表、rawfile文件内容以及rawfile描述符{fd, offset, length}。 在Js侧导入"libentry.so",通过getContext().resourceManager获取资源管理对象。调用src/main/cpp/types/libentry/index.d.ts中声明的接口,传入js的资源对象和相关参数获取对于rawfile相关资源信息。 源码参考:rawfile_demo.cpp 。 涉及到的native rawfile相关接口:
接口名 | 描述 |
---|---|
初始化native resource manager。 | NativeResourceManager *OH_ResourceManager_InitNativeResourceManager(napi_env env, napi_value jsResMgr) |
打开指定rawfile目录。 | RawDir *OH_ResourceManager_OpenRawDir(const NativeResourceManager *mgr, const char *dirName) |
获取指定rawfile目录下的rawfile文件数量。 | int OH_ResourceManager_GetRawFileCount(RawDir *rawDir) |
获取rawfile名字。 | const char *OH_ResourceManager_GetRawFileName(RawDir *rawDir, int index) |
打开指定rawfile文件。 | RawFile *OH_ResourceManager_OpenRawFile(const NativeResourceManager *mgr, const char *fileName) |
获取rawfile文件大小。 | long OH_ResourceManager_GetRawFileSize(RawFile *rawFile) |
读取rawfile文件内容。 | int OH_ResourceManager_ReadRawFile(const RawFile *rawFile, void *buf, size_t length) |
指定rawfile文件的偏移量。 | int OH_ResourceManager_SeekRawFile(const RawFile *rawFile, long offset, int whence) |
获取rawfile文件的偏移量。 | long OH_ResourceManager_GetRawFileOffset(const RawFile *rawFile) |
释放rawfile文件相关资源。 | void OH_ResourceManager_CloseRawFile(RawFile *rawFile) |
释放rawfile目录相关资源。 | void OH_ResourceManager_CloseRawDir(RawDir *rawDir) |
获取rawfile的fd。 | bool OH_ResourceManager_GetRawFileDescriptor(const RawFile *rawFile, RawFileDescriptor &descriptor) |
关闭rawfile的fd。 | bool OH_ResourceManager_ReleaseRawFileDescriptor(const RawFileDescriptor &descriptor) |
释放native resource manager相关资源。 | void OH_ResourceManager_ReleaseNativeResourceManager(NativeResourceManager *resMgr) |
不涉及。
不涉及。
本示例仅支持标准系统上运行,支持设备:RK3568。
本示例为Stage模型,支持API Version 15版本SDK,版本号:5.0.3.135,最低兼容API Version 11,镜像版本号:OpenHarmony-5.0.3.137 Release
本示例需要使用DevEco Studio NEXT Developer Beta1(5.0.3.404)及以上版本才可编译运行。
如需单独下载本工程,执行如下命令:
git init
git config core.sparsecheckout true
echo code/BasicFeature/Native/NdkRawfile/ > .git/info/sparse-checkout
git remote add origin https://gitee.com/openharmony/applications_app_samples.git
git pull origin master
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。