再看看闪耀效果:
1、先将文字画在canvas;
2、利用getImageData()获取图像数据;
3、将图像数据中黑色(你可以用其他颜色)按一定间隔取值(获取坐标);
4、在获取的坐标画矩形(你画其他形状也是可以的);
5、使用requestAnimationFrame,变换矩形颜色。
这样就闪烁起来了~~
var i = 0
Page({
/*** 页面的初始数据*/data: {hideNav: false,colors: ["#fff", "#FF6E40", "#FFAB40", "#FFFF00", "#EEFF41", "#B2FF59", "#69F0AE", "#64FFDA", "#18FFFF", "#40C4FF", "#E040FB", "#FF4081", "#ff5252"],
text: '肖战',scroll: false,setting: false},
/*** 生命周期函数--监听页面加载*/onLoad: function (options) {let that = this, text = wx.getStorageSync('blinkText') || this.data.textthis.setData({text})this.init()},
init() {wx.createSelectorQuery().select('#canvas').fields({node: true,size: true,}).exec((res) =>{let that = this,text = this.data.textconst width = res[0].widthconst height = res[0].height
const canvas = res[0].nodeconst ctx = canvas.getContext('2d')const dpr = 1 //wx.getSystemInfoSync().pixelRatiocanvas.width = width * dprcanvas.height = height * dprctx.scale(dpr, dpr)i = (canvas.width - that.getByteLen(text) * 100) / 2ctx.fillStyle = "#ffffff"ctx.fillRect(0, 0, canvas.width, canvas.height)ctx.font = "bolder 200px Arial"ctx.fillStyle = 'black'ctx.textBaseline = 'top'ctx.fillText(text, 0, 100)// ctx.lineWidth = 5// ctx.strokeText(text, 0, 100)let imageData = ctx.getImageData(0, 0, canvas.width, canvas.height).data// console.log(imageData)
ctx.fillStyle = "#ffffff"ctx.fillRect(0, 0, canvas.width, canvas.height)
this.data.canvas = canvasthis.data.ctx = ctxthis.data.imageData = imageDataconsole.log(canvas.width, canvas.height)// this.drawText()const renderLoop = () =>{this.drawText()
canvas.requestAnimationFrame(renderLoop)}// canvas.cancelAnimationFrame(renderLoop)canvas.requestAnimationFrame(renderLoop)})},drawText() {var gap = 7,{imageData,canvas,ctx,text,scroll} = this.dataif (scroll) {if (i >= canvas.width) {i = -canvas.width}i += 2}
ctx.clearRect(0, 0, canvas.width, canvas.height)for (var h = 0h <canvas.heighth += gap) {for (var w = 0w <canvas.widthw += gap) {var position = (canvas.width * h + w) * 4var r = imageData[position],g = imageData[position + 1],b = imageData[position + 2]
if (r + g + b == 0) {ctx.fillStyle = this.data.colors[Math.floor(Math.random() * this.data.colors.length)]ctx.fillRect(w + i, h, 5, 5)}}}
},toggleSetting() {this.setData({setting: this.data.setting ? false : true})},setText(e) {
let that = thiswx.cloud.callFunction({name: 'msgSecCheck',data: {op: 'textCheck',content: e.detail.value},success(res) {console.log('ContentCheck-res', res)if (res.result.code == 300) {console.log(res.result.msg)wx.showToast({icon: 'none',title: res.result.msg,})that.setData({'text': ''})} else {that.setData({setting: false,'text': e.detail.value})that.init()}},fail(err) {console.log('ContentCheck-errxxxx', err)
}})
},getByteLen(str) {var len = 0for (var i = 0i <str.lengthi++) {var length = str.charCodeAt(i)if (length >= 0 &&length <= 128) {len += 1} else {len += 2}}console.log('文字长度',len)return len},donothing() {
},/*** 生命周期函数--监听页面初次渲染完成*/onReady: function () {
},
/*** 生命周期函数--监听页面显示*/onShow: function () {
},
/*** 生命周期函数--监听页面隐藏*/onHide: function () {
},
/*** 生命周期函数--监听页面卸载*/onUnload: function () {wx.setStorage({data: this.data.text,key: 'blinkText',})},
/*** 页面相关事件处理函数--监听用户下拉动作*/onPullDownRefresh: function () {
},
/*** 页面上拉触底事件的处理函数*/onReachBottom: function () {
},
/*** 用户点击右上角分享*/onShareAppMessage: function () {
}})
可以使用系统自带的造字程序。
1、打开win7系统中的开始菜单→所有程序→附件→系统工具;
2、然后选择打开专用字符编辑程序;
3、在运行中输入:eudcedit.exe 点击确定(或按回车键)也能打开专用字符编辑程序;
4、打开专用字符编辑程序,会d出选择编码的提示框,首次使用,点击确定即可;
5、d出编辑框之后,再点击工具栏上的窗口→参照;
6、尽量利用现成的偏旁,这样造出来的文字比较规范好看;
7、比如石字偏旁加一个太字,这个字的拼音是:dài ,地名用字。
8、首先找到右边是太字的文字。借用文字是:呔,代码是:5454;
9、在找到左边是石的文字,例如“硕”。
10、制作好之后,保存一下自造字;
11、并及在拼音短语中输入:dai=石太(此字只能在已经编辑过的电脑中显示)。
平时看见别人使用了很好看的文字,以为是字体却发现是图片?这是因为别人在手机上用了这款好用的小程序,如果你还不知道,那就赶紧来看看吧。
01首先打开微信,找到【发现】,点击【小程序】。
02打开后在搜索框搜索【文字快转图片】。
03可以看到第一个小程序就是我们要找的。
04直接点开【文字快转图片】,选择下方的【文字转图片】功能。
05然后在输入框写好自己想要转换的文字。
06写好后选择自己想要的背景图片。
07背景图片可以是自己使用手机相册上传也可以使用系统本身自带的背景,这个根据个人实际情况选择即可。
08做好以后点击【保存】。
09这是一个收费的小程序,想要通过这个是制作文字的小伙伴自己开通会员就可以了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)