收藏
回答

canvas动态设置高度

框架类型 问题类型 API/组件名称 终端类型 微信版本 基础库版本
小程序 Bug canvas 客户端 6.5.3 2.0.0

- 当前 Bug 的表现(可附上截图)

我在js中的data里设置  height: "650px" 这个是最大的高度,而在onshow中读取图片,设置文字,这些高度都是变化的,所以我用dynamic_height来指示实际也就是最后的canvas高度,而在有些情况下,canvas的高度是650px而不是在onshow中动态设置的高度

- 预期表现


这个是正常的图片。bug后的图片会比这个高,但是下面有一部分是空白。

我在onload中设置了这个canvas要显示什么文字,在onshow中用wx.getImageInfo获取了图片的高度,在success方法中,通过res来获取图片的高度,并得到整个图片的高度,最后用this.setdata设置高度

- 提供一个最简复现 Demo

<!--这里是wxml-->

<canvas
canvas-id="shareCanvas"
style="width:400px;height:{{height}};"
></canvas>

//这里是onshow函数,可以看到有dynamic_height = dynamic_height + const这种的语句,用来增加图片高度

//在onshow中我还用了fillrect来绘制一个大的矩形作为背景,其高度也是固定的

onShow: function () {

    let self = this
    console.log(this.data.stuffname.length)
    wx.getImageInfo({
      src: self.data.src,
      success(res) {
        const ctx = wx.createCanvasContext('shareCanvas')

        const stuffnamewidth = ctx.measureText(self.data.stuffname)

ctx.setFillStyle('#FFFFFF')

ctx.fillRect(0, 0, 400, 700)

        ctx.setTextBaseline('top')
        var dynamic_height = pic_name + 17
        var stuffname = self.data.stuffname
        var chr = stuffname.split("");
        var temp = "";
        var row = [];
        ctx.setFontSize(33)
        ctx.setFillStyle('black')
        for (var b = 0; b < row.length; b++) {
          ctx.setFontSize(33)
          ctx.setFillStyle('black')
          ctx.fillText(row[b], 20, pic_name + 10 + b * 40);
          dynamic_height = dynamic_height + 40
        }
 
        ctx.setFontSize(27)
        ctx.setFillStyle('black')
        if (self.data.qq != null && self.data.qq != "null" && self.data.qq != "") {
          ctx.setFontSize(27)
          ctx.setFillStyle('black')
          ctx.fillText("请联系QQ: " + self.data.qq, 20, dynamic_height)
          dynamic_height = dynamic_height + 40
        } else if (self.data.phone != null && self.data.phone != "null" && self.data.phone != "") {
          ctx.setFontSize(27)
          ctx.setFillStyle('black')
          ctx.fillText("请联系手机:" + self.data.phone, 20, dynamic_height)
          dynamic_height = dynamic_height + 40
        }
 
        ctx.setFontSize(17)
        ctx.setFillStyle('gray')
        ctx.fillText(self.data.time + "发布", 20, dynamic_height - 3)
        dynamic_height = dynamic_height + 25
 
        ctx.moveTo(20, dynamic_height)
        ctx.lineTo(380, dynamic_height)
        ctx.setStrokeStyle('gray')
        ctx.stroke()
        dynamic_height = dynamic_height + 15
 
        ctx.drawImage('/icon/code.jpg', 20, dynamic_height, 100, 100)
        dynamic_height += 115
 
        self.setData({
          height: dynamic_height + "px"
        })
 
        ctx.draw(false, function () {
          // 3. canvas画布转成图片
          wx.canvasToTempFilePath({
            canvasId: 'shareCanvas',
            quality: 1,
            success(res) {
              self.setData({
                filePath: res.tempFilePath,
              })
              // self.save()
            }
          })
        })
        console.log(self.data.filePath)
 
      }
    })
  },




回答关注问题邀请回答
收藏

3 个回答

登录 后发表内容