【每日学点HarmonyOS Next知识】类型判断、刘海高度、隐私弹窗、滑动下一页效果、清楚缓存

ops/2025/3/14 22:17:51/
1、HarmonyOS instanceof判断错误?

ArkTS部分支持instanceof,可参考文档:https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/typescript-to-arkts-migration-guide-V5

instanceof运算符在传递的过程中可能会发生以下情况:对象的属性在传递的过程中被修改。对象的引用在传递的过程中被改变。对象的构造函数可能尚未完成执行,导致对象状态不完整。以上情况都可能导致在接收线程中使用instanceof进行类型判断时出现错误。因此,直接依赖instanceof进行类型判断不够安全。

2、HarmonyOS 下刘海的高宽获取不到?

通过 window.getWindowAvoidArea(window.AvoidAreaType.TYPE_CUTOUT) 获取刘海的高宽的时候,没有取到下刘海的数据。

获取导航栏高度,设置window.AvoidAreaType.TYPE_NAVIGATION_INDICATOR

3、HarmonyOS 有没有隐私政策弹框的demo?

可以使用Stack组件模拟实现Dialog的效果,页面跳转之后返回 可以做到 Dialog依然显示的效果

import router from '@ohos.router';@Entry
@Component
struct First {@State textValue: string = 'Hello World'// 显隐控制设置为不占用@State visible: Visibility = Visibility.None@State path: string = "pages/Index"build() {// 使用stack可以实现假的dialog覆盖原页面上面Stack() {Row() {// 初始页面Column() {Text('Hello World').fontSize(50).fontWeight(FontWeight.Bold)// 触发dialog的地方Button('click').onClick(() => {//用于检测点击事件是否透传到原来的页面,我测了一下是没有透传的,符合dialog规范console.log("hit me!")if (this.visible == Visibility.Visible) {this.visible = Visibility.None} else {this.visible = Visibility.Visible}}).backgroundColor(0x777474).fontColor(0x000000)}.width('100%')}.height('100%').backgroundColor(0x885555)//这里开始是构造弹窗效果主要需要修改的地方,首先是加了一个半透明灰色的蒙层效果Text('').onClick(() => {if (this.visible == Visibility.Visible) {this.visible = Visibility.None} else {this.visible = Visibility.Visible}}).width('100%').height('100%')// 透明度可以自己调节一下.opacity(0.16).backgroundColor(0x000000).visibility(this.visible)Column() {// 这个可以调节对话框效果,栅格布局,xs,sm,md,lg分别为四种规格// 下面的breakpoints是用来区别当前属于哪个类型的断点// gridRow里的栅格数量为总数,gridCol里的就是偏移和假Dialog所占据的栅格数GridRow({columns: {xs: 1,sm: 4,md: 8,lg: 12},breakpoints: {value: ["400vp", "600vp", "800vp"],reference: BreakpointsReference.WindowSize},}) {GridCol({span: {xs: 1,sm: 2,md: 4,lg: 8},offset: {xs: 0,sm: 1,md: 2,lg: 2}}) {// 这里放的就是原Dialog里的column里的东西,稍微改改应该就可以用了Column() {Text('Change text').fontSize(20).margin({ top: 10, bottom: 10 })TextInput({ placeholder: '', text: this.textValue }).height(60).width('90%').onChange((value: string) => {this.textValue = value})Text('Whether to change a text?').fontSize(16).margin({ bottom: 10 })Flex({ justifyContent: FlexAlign.SpaceAround }) {Button('cancel').onClick(() => {if (this.visible == Visibility.Visible) {this.visible = Visibility.None} else {this.visible = Visibility.Visible}}).backgroundColor(0xffffff).fontColor(Color.Black)Button('jump').onClick(() => {router.pushUrl({//url: 'pages/Index'url: this.path})}).backgroundColor(0xffffff).fontColor(Color.Red)}.margin({ bottom: 10 })}.backgroundColor(0xffffff).visibility(this.visible).clip(true).borderRadius(20)}}}.width('95%') //设置弹窗宽度}}
}
4、HarmonyOS 滑动下一页效果应该如何做?

参考代码:

@Entry
@Component
struct NovelPage {@Provide('fontSize') @Watch('onFontSizeChange') fontSize: number = Constants.INIT_FONT_SIZE;@Provide('bgColorIndex') @Watch('onBgColorChanged') bgColorIndex: BGColorType = BGColorType.WHITE;@Provide('bgColor') bgColor: string = BG_COLOR_ARRAY[BGColorType.WHITE];@Provide('offsetX') offsetX: number = 0@Provide('offsetY') offsetY: number = 0;@Provide('screenH') screenH: number = 0;@Provide('screenW') screenW: number = 0;@Provide('sumRow') sumRow: number = 0;@Provide('rowWord') rowWord: number = 0;@Provide('rotateAngleOne') rotateAngleOne: number = Constants.INIT_ROTATE_ANGLE_ONE;@Provide('rotateAngleTwo') rotateAngleTwo: number = 0.0;@Provide('curPosition') curPosition: number = 0;@Provide('turnStyle') turnStyle: FlipPageType = FlipPageType.SLIDE_FLIP_PAGE;@Provide('currentPageNum') @Watch('onFlush') currentPageNum: number = 1;@Provide('pageWordSum') pageWordSum: number = 0;@Provide('light') light: number = Constants.INIT_SCREEN_LIGHT;@Provide('isSystemLight') isSystemLight: boolean = false;@Provide('rowGap') rowGap: number = Constants.INIT_ROW_GAP;@State currentStartIndex: number = 0;@State isShow: boolean = false;@State isFontChanged: boolean = false;aboutToAppear(): void {this.screenW = px2vp(display.getDefaultDisplaySync().width);this.screenH = px2vp(display.getDefaultDisplaySync().height - (AppStorage.get('avoidHeight') as number));this.sumRow = Math.floor((this.screenH) / (this.fontSize + this.rowGap));this.rowWord = Math.floor((this.screenW - Constants.SCREEN_MARGIN_LEFT * 2) / this.fontSize);this.simulatePageContent();this.changeSystemBarStatue();}onFontSizeChange() {this.sumRow = Math.floor((this.screenH) / (this.fontSize + this.rowGap));this.rowWord = Math.floor((this.screenW - Constants.SCREEN_MARGIN_LEFT * 2) / this.fontSize);let pageWordSum = this.sumRow * this.rowWord;if (this.currentStartIndex > pageWordSum) {this.currentPageNum = Math.floor(this.currentStartIndex / (pageWordSum)) +(this.currentStartIndex > 1 && this.currentStartIndex % pageWordSum > 0 ? 2 : 1);} else if (this.currentStartIndex > 0) {this.currentPageNum = 2;} else {Logger.info('currentStartIndex = ' + this.currentStartIndex);}this.isFontChanged = true;this.simulatePageContent();}changeSystemBarStatue(): void {window.getLastWindow(getContext(this), (err, data) => {const errCode = err.code;if (errCode) {return;}let SystemBarProperties: window.SystemBarProperties = {statusBarColor: BG_COLOR_ARRAY[this.bgColorIndex],navigationBarColor: BG_COLOR_ARRAY[this.bgColorIndex],navigationBarContentColor: Constants.TRANSPARENT};try {data.setWindowSystemBarProperties(SystemBarProperties, (err: BusinessError) => {const errCode: number = err.code;if (errCode) {Logger.error('Failed to set the system bar properties. Cause: ' + JSON.stringify(err));return;}data.setWindowBackgroundColor(BG_COLOR_ARRAY[this.bgColorIndex]);});} catch (exception) {Logger.error('Failed to set the system bar properties. Cause: ' + JSON.stringify(exception));}});}onBgColorChanged() {this.changeSystemBarStatue();}onFlush() {Logger.info('currentPageNum=' + this.currentPageNum + ', isFontChanged=' + this.isFontChanged);if (this.isFontChanged && this.currentPageNum === 1) {this.isFontChanged = false;this.currentStartIndex = 0;}}simulatePageContent() {this.offsetY = 0;this.rotateAngleTwo = 0.0;this.rotateAngleOne = Constants.INIT_ROTATE_ANGLE_ONE;}private clickAnimateTo(isLeft: Boolean) {if (this.turnStyle === FlipPageType.SLIDE_FLIP_PAGE) {animateTo({duration: Constants.SLIDE_DURATION,curve: Curve.EaseOut,onFinish: () => {if (this.offsetX > 0) {this.currentPageNum > 0 ? this.currentPageNum - 1 : this.currentPageNum;this.currentStartIndex -= this.sumRow * this.rowWord;}if (this.offsetX < 0) {this.currentPageNum += 1;this.currentStartIndex += this.sumRow * this.rowWord;}Logger.info(this.currentStartIndex.toString());this.offsetX = 0;this.simulatePageContent();}}, () => {if (isLeft) {this.offsetX = this.screenW;} else {this.offsetX = -this.screenW;}})}}build() {Row() {if (this.turnStyle === FlipPageType.SLIDE_FLIP_PAGE) {SlideFlipView({currentStartIndex: this.currentStartIndex})}}.width(Constants.FULL_PERCENT).height(Constants.FULL_PERCENT).bindSheet($$this.isShow,this.myBuilder(),{height: SheetSize.FIT_CONTENT,detents: [Constants.SHEET_HEIGHT, Constants.SHEET_HEIGHT + 1],showClose: true,dragBar: true,title: { title: Constants.SHEET_TITLE },backgroundColor: Constants.SHEET_BACKGROUND_COLOR}).backgroundColor(this.bgColor)}@BuildermyBuilder() {}
}@Component
export default struct Reader {@Consume('bgColor') @Watch('onPageChange') bgColor: string;@Consume('fontSize') @Watch('onPageChange') fontSize: number;@Consume('turnStyle') turnStyle: FlipPageType;@Consume('screenW') screenW: number;@Consume('screenH') screenH: number;@Consume('rowGap') rowGap: number;@Consume('sumRow') sumRow: number@Consume('rowWord') rowWord: number;@Prop @Watch('onPageChange') startIndex: number = 0;private settings: RenderingContextSettings = new RenderingContextSettings(true);private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings);private wordWidth: number = 0;private wordHeight: number = 0;aboutToAppear(): void {this.drawText(this.startIndex);}onPageChange() {this.drawText(this.startIndex);}drawText(startIndex: number) {this.wordWidth = this.fontSize;this.wordHeight = this.fontSize;this.context.fillStyle = this.bgColor;this.context.fillRect(0, 0, this.screenW, this.screenH);this.context.fillStyle = Color.Black;this.context.font = vp2px(this.fontSize) + Constants.CANVAS_FONT_SET;if (startIndex < 0) {startIndex = 0;}let gap = ((this.screenW - Constants.SCREEN_MARGIN_LEFT * 2) - this.wordWidth * this.rowWord) / (this.rowWord - 1);let realRowGap = (this.screenH - this.sumRow * (this.wordHeight + this.rowGap)) / (this.sumRow - 1);let currentX = Constants.SCREEN_MARGIN_LEFT;let currentY = this.wordHeight;for (let i = startIndex;; i++) {if (currentX + this.wordWidth > this.screenW - (Constants.SCREEN_MARGIN_LEFT - 1)) {currentX = Constants.SCREEN_MARGIN_LEFT;currentY = currentY + this.rowGap + this.wordHeight + realRowGap;if (currentY > this.screenH) {break;}}this.context.fillText(Constants.TEXT.charAt(i % Constants.TEXT.length), currentX, currentY);currentX += this.wordWidth + gap;}}build() {Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Start, justifyContent: FlexAlign.Start }) {Column() {Canvas(this.context).width(Constants.FULL_PERCENT).height(Constants.FULL_PERCENT).onReady(() => {this.drawText(this.startIndex);})}.width(Constants.FULL_PERCENT)}.height(Constants.FULL_PERCENT)}
}@Component
export struct SlideFlipView {@Consume('offsetX') offsetX: number;@Consume('sumRow') sumRow: number;@Consume('rowWord') rowWord: number;@Consume('screenW') screenW: number;@Consume('currentPageNum') currentPageNum: number;@Link currentStartIndex: number;private isFirst: boolean = false;build() {Stack() {Reader({ startIndex: this.currentStartIndex + this.sumRow * this.rowWord }).translate({ x: this.offsetX >= 0 ? this.screenW : this.screenW + this.offsetX, y: 0, z: 0 })Reader({ startIndex: this.currentStartIndex }).translate({ x: this.offsetX, y: 0, z: 0 }).width(this.screenW)Reader({ startIndex: this.currentStartIndex - this.sumRow * this.rowWord }).translate({ x: this.offsetX >= 0 ? -this.screenW + this.offsetX : -this.screenW, y: 0, z: 0 })}.gesture(PanGesture().onActionUpdate((event?: GestureEvent) => {if (!event) {return;}if (this.currentPageNum <= 1 && event.offsetX > 0) {this.isFirst = true;return;}this.offsetX = event.offsetX;}).onActionEnd(() => {animateTo({duration: Constants.FLIP_DURATION,curve: Curve.EaseOut,onFinish: () => {if (this.offsetX > 0) {this.currentPageNum -= 1;if (this.currentStartIndex !== 0) {this.currentStartIndex -= this.sumRow * this.rowWord;}}if (this.offsetX < 0) {this.currentPageNum += 1;this.currentStartIndex += this.sumRow * this.rowWord;}if (this.isFirst) {promptAction.showToast({message: Constants.MSG_FLIP_OVER,duration: Constants.PROMPT_DURATION});this.isFirst = false;}this.offsetX = 0;}}, () => {if (this.offsetX > 0) {this.offsetX = this.screenW;}if (this.offsetX < 0) {this.offsetX = -this.screenW;}})}))}
}
5、HarmonyOS 清除缓存功能?

app中有清除缓存的需求功能,清除缓存和计算app内缓存大小需要怎么实现。

查询缓存用storageStatistics.getCurrentBundleStats()接口,清除文件缓存,需要调用context的cacheDir获取缓存,然后调用系统文件fs接口,判断是文件或者文件夹,再分别消除缓存https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-file-storage-statistics-V5#storagestatisticsgetcurrentbundlestats9 清理:

import fs from ‘@ohos.file.fs’;
let cacheDir = context.cacheDir;
@Entry
@Component
struct Clear_cache {clearCache() {// let cacheDir = getContext(this).cacheDir// fs.rmdirSync(cacheDir)// console.log(“delete !!!”)fs.listFile(cacheDir).then((filenames) => {for (let i = 0;i < filenames.length; i++) {// let dirPath = cacheDir+filenames[i]let dirPath = ${cacheDir}/${filenames[i]}// 判断是否文件夹let isDirectorytry {isDirectory = fs.statSync(dirPath).isDirectory()}catch (e) {console.log(e)}if (isDirectory) {fs.rmdirSync(dirPath)} else {fs.unlink(dirPath).then(() => {console.info(“remove file succeed”);}).catch((err) => {console.info("remove file failed with error message: " + err.message + ", error code: " + err.code);});}}})}
}

http://www.ppmy.cn/ops/165772.html

相关文章

大数据学习(66)- CDH管理平台

&#x1f34b;&#x1f34b;大数据学习&#x1f34b;&#x1f34b; &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 用力所能及&#xff0c;改变世界。 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一…

Tomcat 安装

一、Tomcat 下载 官网&#xff1a;Apache Tomcat - Welcome! 1.1.下载安装包 下载安装包&#xff1a; wget https://dlcdn.apache.org/tomcat/tomcat-9/v9.0.102/bin/apache-tomcat-9.0.102.tar.gz 安装 javajdk。 yum install java-1.8.0-openjdk.x86_64 -y /etc/altern…

Appium高级操作--ActionChains类、Toast元素识别、Hybrid App操作、手机系统API的操作

书接上回Appium高级操作--从源码角度解析--模拟复杂手势操作-CSDN博客文章浏览阅读712次&#xff0c;点赞24次&#xff0c;收藏6次。下面总结Appium模拟复杂手势整体流程创建类实例action时&#xff0c;一定要传入WebDriver实例参数&#xff0c;创建实例成功后&#xff0c;调用…

LINUX 指令大全

Linux服务器上有许多常用的命令&#xff0c;可以帮助你管理文件、目录、进程、网络和系统配置等。以下是一些常用的Linux命令&#xff1a; 文件和目录管理 ls&#xff1a;列出当前目录中的文件和子目录 bash lspwd&#xff1a;显示当前工作目录的路径 bash pwdcd&#xff1a;切…

MySQL数据库复制

文章目录 MySQL数据库复制一、复制的原理二、复制的搭建1.编辑配置文件2.在主库上创建复制的用户3.获取主库的备份4.基于从库的恢复5.建立主从复制6.开启主从复制7.查看主从复制状态 MySQL数据库复制 MySQL作为非常流行的数据库&#xff0c;支撑它如此出彩的因素主要有两个&am…

Stable Diffusion/DALL-E 3图像生成优化策略

Stable Diffusion的最新版本或社区开发的插件&#xff0c;可以补充这些信息以保持内容的时效性。 云端源想 1. 硬件与部署优化&#xff08;进阶&#xff09; 显存压缩技术 使用--medvram或--lowvram启动参数&#xff08;Stable Diffusion WebUI&#xff09;&#xff0c;通过分…

cesium地图设置3d,2d,2.5d动态切换

通过修改cesium实例vw的scene的显示模式&#xff0c;来切换最终的显示模式。 Cesium.SceneMode总共有四个变量值&#xff0c;分别如下&#xff1a;NameTypeDescriptionMORPHINGnumber在3d与2d之间切换变体 between mode, e.g., 3D to 2D.COLUMBUS_VIEWnumber2.5d模式&#xff0…

# RAG 框架 # 一文入门 全链路RAG系统构建与优化 —— 架构、策略与实践

本文全面阐述了RAG系统从数据收集、数据清洗&#xff08;包括领域专有名词处理&#xff09;、智能数据分块与QA对生成&#xff0c;到向量化、向量数据库选择与配置&#xff0c;再到检索方式及重排序&#xff0c;直至整合输出、监控反馈和安全保障的全流程。通过这一完整方案&am…