DOM 和 Canvas 如何实现文字竖向排列的效果

栏目: Html5 · 发布时间: 6年前

内容简介:想通过限定HTML 的
  1. 输入框样式需做成竖排样式;
  2. 使用 Canvas 生成图片供用户保存,图片中的文字方向为竖排;
  3. 非汉字需与汉字垂直。
DOM 和 Canvas 如何实现文字竖向排列的效果

项目地址

DOM 实现文字竖排

<input> 标签没有竖排的属性,最先尝试修改 <input> 的样式来实现效果,但是效果不理想。最后使用 HTML 的 contenteditable 属性。

尝试修改 input 样式(失败)

想通过限定 输入框的宽度文字的大小 ,让文字自动换行。

关键代码

input{
    width: 30px;
    height: 250px;
    font-size: 30px;
}
复制代码

放弃原因

  • 英文字符宽度小,会出现换行失败的情况

使用 HTML 的 contenteditable 属性代替 <input> (推荐)

HTML 的 contenteditable 属性规定元素内容是否可编辑。

关键代码

<div contenteditable="true" style="writing-mode: vertical-lr; writing-mode: tb-lr; "></div>
复制代码
contenteditable
writing-mode

使用原因

  • 非中文自动旋转,排版更好看(实现了需求中的第三点)

Canvas 实现文字竖排

Canvas 同样没有竖排文字的属性,我通过遍历文字的方式进行绘制。

关键代码

let name; // 文本内容
let x = 657,y=170; // 文字开始的坐标
let letterSpacing = 10; // 设置字间距
for(let i = 0; i < this.name.length; i++){
    const str = this.name.slice(i,i+1).toString();
    if(str.match(/[A-Za-z0-9]/)&&(y<576)){ // 非汉字 旋转
        ctx.save();
        ctx.translate(x,y);
        ctx.rotate(Math.PI/180*90);
        ctx.textBaseline = 'bottom';
        ctx.fillText(str,0,0);
        ctx.restore();
        y+=ctx.measureText(str).width+letterSpacing; // 计算文字宽度
    }else if(str.match(/[\u4E00-\u9FA5]/)&&(y<576)){
        ctx.save();
        ctx.textBaseline = 'top';
        ctx.fillText(str,x,y);
        ctx.restore();
        y+=ctx.measureText(str).width+letterSpacing; // 计算文字宽度
    }
}

复制代码

以上所述就是小编给大家介绍的《DOM 和 Canvas 如何实现文字竖向排列的效果》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

产品心经:产品经理应该知道的60件事(第2版)

产品心经:产品经理应该知道的60件事(第2版)

闫荣 / 机械工业出版社 / 2016-4 / 69.00

本书第一版出版后广获好评,应广大读者要求,作者把自己在实践中新近总结的10个关于产品的最佳实践融入到了这本新书中。这"10件事"侧重于深挖产品需求和产品疯传背后的秘密,配合之前的"50件事",不仅能帮产品经理打造出让用户尖叫并疯传的产品,还能帮助产品经理迅速全方位提升自己的能力。 本书作者有超过10年的产品工作经验,在互联网产品领域公认的大咖,这本书从产品经理核心素养、产品认知、战略与规划、......一起来看看 《产品心经:产品经理应该知道的60件事(第2版)》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具