zoukankan      html  css  js  c++  java
  • 小程序的一些问题(canvas写文字,富文本功能)

    前沿

    做小程序遇到一些问题:

    1.canvas的 稳住写的的时候需要很多行换行并且需要居中,写入代码

    let canvas = document.getElementById('canvas')
    let ctx = canvas.getContext('2d')
     
    ctx.fillStyle = '#fff' #设置字体颜色
    ctx.font = 'bold 34px/40px 幼圆' #设置文字粗体 字号 行高 字体
    ctx.textBaseline = 'middle' #垂直居中
    ctx.textAlign='center' #水平居中
     
    #遇到长文本实现换行
    let name = '很长很长很长很长很长很长很长很长很长很长很长很长的的字',
    temp='',row=[],maxwidth = 50
    for (var a = 0; a < name.length; a++) {#将文本按最大宽度换行
        #判断文本是否超出,是则换行
        (ctx.measureText(temp).width >= maxwidth)&&(row.push(temp),temp = "")
        temp += name[a];
    }
    row.push(temp);
    for (var b = 0; b < row.length; b++) {#按行写入文本
        ctx.fillText(row[b], 0, -200 + (b-row.length/2) * 40,maxwidth);#40是行高
    

    2.小程序富文本 换行问题

    user-select="true" 因为这个属性 加入 导致font渲染的时候都是换行,并且导致 文字的下划线和中华线还有换行都被影响了
    user-select="true" 这个属性是长按复制的功能,去除就可以了
    这样就不能长按复制了
      <!-- 判断是否为文本节点 -->
      <block wx:elif="{{item.node == 'text'}}">
        <view class="WxEmojiView wxParse-inline" style="{{item.styleStr}}" style="user-select:text !important;-webkit-user-select">
          <block wx:for="{{item.textArray}}" wx:key="index" wx:for-index="index" wx:for-item="textItem">
            <block class="{{textItem.text == '\n' ? 'wxParse-hide':''}}" wx:if="{{textItem.node == 'text'}}">
              {{textItem.text}}
              <!-- selectable="{{true}}" -->
              <!-- <text  selectable="true" user-select="true">
                <text class="wxParse-txt">{{textItem.text}}</text>
              </text> -->
            </block>
            <block wx:elif="{{textItem.node == 'element'}}">
              <image class="wxEmoji" src="{{textItem.baseSrc}}{{textItem.text}}" />
            </block>
          </block>
        </view>
      </block>
    

      

  • 相关阅读:
    利用cookie实现iframe刷新时停留在当前页面
    css定位学习经验记录
    用div加css做表格去掉外围边框
    利用css中的background-position定位图片
    css3实现圆形逐渐减少动画
    The Best Path
    3998
    YAPTCHA(hdu2973)
    1556 计算
    1808: 地铁
  • 原文地址:https://www.cnblogs.com/yf-html/p/14719219.html
Copyright © 2011-2022 走看看