HarmonyOS 开发实践——基于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.restrictWidthMath.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
}
阅读全文
下载说明:
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.1024c.cn/archives/21935,转载请注明出处。
0

评论0

显示验证码
没有账号?注册  忘记密码?