【HarmonyOS NEXT应用开发】案例37:基于measure实现的文本测量

场景描述

场景一:当文本的内容超过指定的行数时显示 ...展开,当所有文本展开后,最后面跟着收起。

场景二:搜索框展示历史记录,单个子组件超过固定长度后展示省略号,固定只展示两行,超出的文字被截断,通过点击按钮展示后续文本内容

方案描述

场景一:

当文本的内容超过指定的行数时显示 ...展开,当所有文本展开后,最后面跟着收起。

方案

1、文本默认超过两行时,直接截断,在截断文本后添加...展开

2、测量两行文本和全部文本的高度,当全部文本的高度超过两行文本的高度时进行展开的逻辑

3、文本全部展开后,点击收起,所有文本全部收齐变成固定的两行

核心代码

文本收起态(即展开逻辑)


collapseText(): void {

//判断文本是否需要展开

if (!this.needProcess) {

return;

}

let titleSize : SizeOptions = measure.measureTextSize({

textContent: this.rawTitle,

constraintWidth: this.titleWidth,

fontSize: 20

})

//测量最大行数(两行)限制的高度,

let twoLineSize : SizeOptions = measure.measureTextSize({

textContent: this.rawTitle,

constraintWidth: this.titleWidth,

fontSize: 20,

maxLines: this.MAX_LINES

})

//文本未超过限制行数,不进行展开、收起处理

if (Number(titleSize.height) == Number(twoLineSize.height)) {

this.needProcess = false;

return;

}



console.log('test row height:' + titleSize.height)

console.log('test twoLineSize height:' + twoLineSize.height)

//clipTitle被截取的文本,rawtitle只全部的文本

let clipTitle: string = this.rawTitle

//EXPAND_STR将展开这个文本赋值给最后一个span

this.lastSpan = this.EXPAND_STR;

while (Number(titleSize.height) > Number(twoLineSize.height)) {

//判断是否展开

this.expanded = true;

clipTitle = clipTitle.substring(0, clipTitle.length - 1);

titleSize = measure.measureTextSize({

//文本总共被分成三段,展示的则是被截取的文本+省略号+最后的展开或收起的文字

textContent: clipTitle + this.ellipsis + this.lastSpan,

constraintWidth: this.titleWidth,

fontSize: 20

})

console.log("test while clipTitle:" + clipTitle)

console.log("test while clipTitle height:" + titleSize.height)

}

console.log("test clipTitle:" + clipTitle)

this.title = clipTitle + this.ellipsis

this.expanded = false;

}


// 文本展开态(即收起逻辑)

expandText(): void {

console.log('testTag: ' + this.needProcess);

if (this.needProcess) {

//文本已经展开了,就需要将最后一个文本替换成收起的样式

this.lastSpan = this.COLLAPSE_STR;

this.expanded = true;

this.title = this.rawTitle;

}

}复制

场景二:

搜索框展示历史记录,单个子组件超过固定长度后展示省略号,固定只展示两行,超出的文字被截断,通过点击按钮展示后续文本内容。

方案

1.历史记录固定只展示两行,超出的均被截断

2.单个文本有固定尺寸,超长后会展示省略号

3.通过点击按钮可以展示出所有的历史记录

核心代码

获取屏幕的宽度


//子组件的最大宽度,目前是定死的

const childMaxWidth:number = 325 //为了方便后续计算,这里的宽度数值为px

let displayClass: display.Display | null = null;

let componentWidth:number = 0;

try {

//获取屏幕宽度

displayClass = display.getDefaultDisplaySync();

componentWidth = displayClass.width

console.log('---这是componentWidth',componentWidth)

} catch (exception) {

console.error('Failed to obtain the default display object. Code: ' + JSON.stringify(exception));

}




// 监听下标和单个文字的改变

IndexChange(){

if(this.AllWidth >= (this.restrictWidth - childMaxWidth) && this.AllWidth <= (this.restrictWidth)){

this.newIndex = this.index

console.log('---这是newIndex',this.newIndex)

}

}



textChange(){

let content:string = this.message

this.textWidth = measure.measureText({

textContent: content,

fontSize: this.fontSizeData

})

if(this.textWidth > childMaxWidth){

this.AllWidth += childMaxWidth

console.log('---这是AllWidth1',this.AllWidth)



}else{

this.AllWidth += this.textWidth

console.log('---这是AllWidth2',this.AllWidth)

console.log('---textWidth',this.textWidth)

}

}


// 对超出的文本进行判断

aboutToAppear(): void {

// this.process();

if(componentWidth != 0){

this.restrictWidth = Math.floor((parseFloat(this.FlexWidth) * componentWidth) * 0.01 )

console.log('---这是restrictWidth',this.restrictWidth)

console.log('---FlexWidth',(this.FlexWidth))

}

for(let i = 0;i < this.AllData.length;i++){

this.message = this.AllData[i]

this.index = i

console.log('---index',this.index)

}

this.SomeData = this.AllData.slice(0,this.newIndex+1)

this.ShowData = this.SomeData

}
  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

青少年编程作品集

你的赞赏将带来极佳的运气

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值