新春之际,做个祝福接力的贺卡(玩爆你的盆友圈)

发布于2017年12月09日 11:11:34

已经12月了,公元两千零一七年也快结束了,不由得感叹时间过的真快,还没开始做些什么,一年就又晃过去了,mdzz。

在年底,各种节日,年会等活动慢慢开始闹腾起来。最近为了迎(zou)接(kai)2018,上面打算让我们做一个互动活动。经过几天折腾,选了一个h5小游戏和h5贺卡的形式。而最终经过讨论,放弃了贺卡,原因是在国庆时做过类似的(qishichabiehendadehaome),选择了小游戏。相信还有很多小伙伴们最近也在筹划这些,所有干脆做个分享,有需要的可以参考下。

本项目想实现的功能及模式:

1、主要环境在微信端,所以基于微信接口开发;

2、用户进入活动页面,自动获取到用户信息,包括头像,昵称,地区(注:接口权限需要认证的服务号或者用户已关注公众号)

3、地区,昵称 用户也可按自己想法更改,写一段祝福语后,即可生成贺卡;

4、根据微信分享端口,引导用户分享至微信好友或朋友圈。

实现后的效果图如下(UI有点丑,还望见谅<_>):

   

实现方式:主要通过canvas绘图及其其他属性完成

贴上主要代码:

var canvas = document.getElementById("myCanvas");
varctx=canvas.getContext("2d");
canvas.width=_width;
canvas.height=_height;
varimgUrl=newImage,
qrCodeUrl=newImage,
point=newImage,
avatar=newImage;
imgUrl.src=imgbox.src;
avatar.src='images/avatar.jpg';
qrCodeUrl.src="images/qrcode.png";
point.src="images/point.png";
varbless_text="白山羊送福接力";
//var btm = document.getElementById("bottom");
imgUrl.onload=function(){
this.height=_height;
ctx.fillStyle="#fff";
ctx.fillRect(0,0,_width,_height);
varerWeiMaY=this.height-qrCodeUrl.height-90;
varwyDyY=this.height-80;
if(ctx.drawImage(imgUrl,0,0,_width,this.height),ctx.beginPath(),ctx.beginPath(),ctx.font="normal 18px sans-serif",ctx.textAlign="start",ctx.textBaseline="hanging",""!=pointMsg&&""!=luck&&""!=author&&void0!=pointMsg&&null!=pointMsg&&null!=luck&&null!=author){
varpTxt="我在:"+pointMsg;
varfromTxt='我是:'+author;
ctx.fillText(pTxt,_width/8,_height/2);
ctx.fillText(fromTxt,_width/2.75,_height/2.3);
ctx.drawImage(point,0,0,42,55,_width/14.5,_height/2,42,55);
ctx.drawImage(qrCodeUrl,0,0,100,100,(_width-100)/2,erWeiMaY,100,100);
circleImg(ctx,avatar,50);
}elseif(luck.length>150){
alert('祝福语字数超过限制');
returnfalse;
}
else{
alert('请先输入祝福语吧');
return false;
}
我们通过接口拿到的用户头像原本是正方形的,而在本项目中采取圆形头像,所以我们还得对原头像进行处理,为此,看其他大神有封装过这样一个函数:
function circleImg(ctx, img, r) {
ctx.save();
x=(_width-100)/2;
y=_height/3.6;
vard=2*r;
varcx=x+r;
varcy=y+r;
ctx.arc(cx,cy,r,0,2*Math.PI);
ctx.clip();
ctx.drawImage(img,x,y,d,d);
ctx.restore();
}
注意:在canvas中没有换行的属性,所以在textarea中祝福语多行的话,需自己写方法去解决,如下:
function getTrueLength(str){//获取字符串的真实长度(字节长度)
varlen=str.length,truelen=0;
for(varx=0;x<len;x++){
if(str.charCodeAt(x)>128){
truelen+=2;
}else{
truelen+=1;
}
}
returntruelen;
}
function cutString(str, leng){//按字节长度截取字符串,返回substr截取位置
varlen=str.length,tlen=len,nlen=0;
for(varx=0;x<len;x++){
if(str.charCodeAt(x)>128){
if(nlen+2<leng){
nlen+=2;
}else{
tlen=x;
break;
}
}else{
if(nlen+1<leng){
nlen+=1;
}else{
tlen=x;
break;
}
}
}
return tlen;
}
if(ctx.beginPath(),ctx.font="normal 20px PingFangSC-Medium"){
for(vari=1;getTrueLength(luck)>0;i+=0.1){
vartl=cutString(luck,_width/13);
ctx.fillText(luck.substr(0,tl).replace(/^\s+|\s+$/,""),(_width-(0.8*_width))/2,i*_height/1.8);
luck=luck.substr(tl);
}
}

因为时间关系,最近都在赶项目,本文介绍的也比较粗糙,不过基本可以表达项目完整意思,所以老铁如有需要源码的可以在评论区留下邮箱索取。

本文共 29 个回复

  • homepage 2024/08/10 05:36

    Really fantastic information can be found on web blog.Expand blog

  • eco bij 2024/11/14 17:07

    Hey! Do you know if they make any plugins to help with Search Engine Optimization? I'm trying to get my site to rank for some targeted keywords but I'm not seeing very good success. If you know of any please share. Kudos! You can read similar text here: Wool product

  • flower dress art 2024/11/16 00:57

    An alternate to a masonry firepit is a freestanding, metallic woodburner.

  • Honey 2024/12/04 07:39

    I love it when folks get together and share ideas. Great website, continue the good work.

  • Japanese dragon tattoos 2024/12/04 09:54

    A fascinating discussion is worth comment. I think that you need to publish more on this topic, it might not be a taboo matter but typically people do not speak about these topics. To the next! Best wishes.

  • poocoin 2024/12/04 12:32

    It’s hard to come by knowledgeable people about this topic, but you sound like you know what you’re talking about! Thanks

  • Harlem Cleaner 2025/08/22 08:16

    High-end service excellence, treats our penthouse with proper care. Exceeds luxury expectations. Executive thanks.

  • Valentine Kersting 2025/08/22 11:39

    Our free written estimates stay locked for a whole year, giving you breathing room to plan without worrying about surprise price jumps in materials. Our team uses hidden screw‑in hangers that lock gutters to the rafter tails, outclassing the rusty spike-and-ferrule setups you still see on too many older homes. Tacoma's notoriously unpredictable rain makes high-capacity seamless gutters an absolute must for any homeowner who wants long‑term protection and peace of mind.

  • Primera order buy 2025/08/24 13:09

    Primera is a modern supplement designed to support pelvic health. It uses selected natural ingredients to improve bladder control and help urinary tract health while focusing on overall pelvic wellness.

  • Laure Ducey 2025/08/25 13:43

    https://gutterinstallation.blob.core.windows.net/gutters/tacoma-wa/2025-gutter-insights-for-tacoma-residents.html

  • site google 2025/08/27 04:17

    Welcome to NanoDefense Pro is the official website of a powerful supplement that is an advanced skincare and nail support formula that uses cutting-edge nanotechnology to rejuvenate and restore health from within.

  • Guy Hernandes 2025/08/27 05:43

    Beaufort's notoriously unpredictable rain makes high-capacity seamless gutters an absolute must for any homeowner who wants long‑term protection and peace of mind. With rain coming sideways across Commencement Bay, hidden drip‑edge flashing stops water from sneaking behind the fascia and into your attic insulation. Proper downspout extensions send runoff well past your flowerbeds so you spend weekends gardening instead of dealing with muddy erosion trenches.

  • Emiko Esquivel 2025/08/29 03:27

    powerful supplement that is an advanced skincare and nail support formula that uses cutting-edge nanotechnology to rejuvenate and restore health from within.

  • Kris Vanboerum 2025/08/30 11:19

    Because we're veteran‑owned we show up on time, measure twice, and treat every property with the kind of respect we learned back in basic training. Homeowners across Proctor District rave that our color‑matched downspouts actually enhance curb appeal instead of looking like cheap after‑thoughts. Investing in quality gutters is like buying the good umbrella—it costs a bit more up front but saves you from soaking through your socks every single storm.

  • Bibi Coppess 2025/08/31 08:49

    nail support formula that uses cutting-edge nanotechnology to rejuvenate and restore health from within.

  • semenax review 2025/09/01 05:51

    Hello! I've been reading your blog for a while now and finally got the courage to go ahead and give you a shout out from Lubbock Texas! Just wanted to tell you keep up the fantastic work!

  • 母の日 ギフト アプリ 2025/09/04 03:00

    You are so interesting! I don't think I've truly read through anything like that before. So great to find someone with unique thoughts on this issue. Seriously.. thanks for starting this up. This website is something that is required on the internet, someone with some originality.

  • Chet Peralez 2025/09/06 19:15

    Annual tune‑ups are available; we flush, reseal corners and adjust hangers so your system keeps working even after the roughest winter freeze–thaw cycles. Home inspectors agree that a clean, seamless gutter line is a small upgrade that prevents thousand‑dollar foundation repairs down the road. Because we're veteran‑owned we show up on time, measure twice, and treat every property with the kind of respect we learned back in basic training.

  • นรxxx 2025/09/09 15:00

    I blog often and I really thank you for your content. Your article has really peaked my interest. I'm going to book mark your blog and keep checking for new details about once a week. I subscribed to your RSS feed as well.

  • Residents in Berkeley, Richmond, and San Leandro can now enjoy 2 months free Sonic Fiber internet 2025/09/11 03:10

    Good post. I learn something new and challenging on websites I stumbleupon on a daily basis. It will always be helpful to read articles from other authors and use a little something from their websites.

  • beetles gel polish 2025/09/11 20:46

    I’ve learn some just right stuff here. Certainly worth bookmarking for revisiting. I surprise how much effort you set to create this kind of fantastic informative site.

  • audifort 2025/09/12 19:48

    Hi, I do think this is an excellent website. I stumbledupon it 😉 I am going to come back once again since I bookmarked it. Money and freedom is the greatest way to change, may you be rich and continue to guide others.

  • quietum plus 2025/09/13 00:15

    You're so awesome! I don't suppose I have read something like that before. So great to discover somebody with some original thoughts on this subject matter. Seriously.. thanks for starting this up. This website is one thing that's needed on the internet, someone with a bit of originality.

  • Nagelolja 2025/09/13 02:35

    I’m not positive the place you are getting your information, however great topic. I must spend some time learning much more or understanding more. Thank you for fantastic info I was looking for this information for my mission.

  • débarras cave 2025/09/13 08:25

    There is certainly a great deal to learn about this issue. I love all the points you've made.

  • usdt wallet address generator 2025/09/13 18:52

    Having read this I believed it was really enlightening. I appreciate you taking the time and effort to put this informative article together. I once again find myself personally spending a significant amount of time both reading and posting comments. But so what, it was still worth it.

  • Skonsam borttagning av naglar 2025/09/15 10:34

    I precisely desired to thank you very much once again. I am not sure what I could possibly have created without the advice shown by you directly on such subject. It was before the frustrating scenario in my opinion, however , considering your expert form you dealt with it forced me to jump with contentment. Now i'm happier for the support and thus expect you are aware of an amazing job you were doing teaching some other people by way of your site. Probably you haven't come across any of us.

  • Darell 2025/09/16 01:31

    native united statesn casinobonus2 zar casino; Darell, rights, gambling in ontario australia and poker rooms in canada, or pokies no deposit bonus codes canada 2021

  • หนังโป๊ 2025/09/16 05:29

    You're so interesting! I don't believe I've truly read through anything like that before. So great to find somebody with genuine thoughts on this subject. Seriously.. many thanks for starting this up. This web site is something that is needed on the web, someone with a bit of originality.

回复 Nagelolja 取消