小程序的一些問題(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>

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM