码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 小程序使用Canvas设置文字竖向排列


     在需要使用的js页面引入js文件,传入对应参数即可

    1. /**
    2. * 文本竖向排列
    3. */
    4. function drawTextVertical(context, text, x, y) {
    5. var arrText = text.split('');
    6. var arrWidth = arrText.map(function (letter) {
    7. return 26; // 字体间距,需要自定义可以自己加参数,根据传入参数进行设置
    8. });
    9. var align = context.textAlign;
    10. var baseline = context.textBaseline;
    11. if (align == 'left') {
    12. x = x + Math.max.apply(null, arrWidth) / 2;
    13. } else if (align == 'right') {
    14. x = x - Math.max.apply(null, arrWidth) / 2;
    15. }
    16. if (baseline == 'bottom' || baseline == 'alphabetic' || baseline == 'ideographic') {
    17. y = y - arrWidth[0] / 2;
    18. } else if (baseline == 'top' || baseline == 'hanging') {
    19. y = y + arrWidth[0] / 2;
    20. }
    21. context.textAlign = 'center';
    22. context.textBaseline = 'middle';
    23. // 开始逐字绘制
    24. arrText.forEach(function (letter, index) {
    25. // 确定下一个字符的纵坐标位置
    26. var letterWidth = arrWidth[index];
    27. // 是否需要旋转判断
    28. var code = letter.charCodeAt(0);
    29. if (code <= 256) {
    30. context.translate(x, y);
    31. // 英文字符,旋转90°
    32. context.rotate(90 * Math.PI / 180);
    33. context.translate(-x, -y);
    34. } else if (index > 0 && text.charCodeAt(index - 1) < 256) {
    35. // y修正
    36. y = y + arrWidth[index - 1] / 2;
    37. }
    38. context.fillText(letter, x, y);
    39. // 旋转坐标系还原成初始态
    40. context.setTransform(1, 0, 0, 1, 0, 0);
    41. // 确定下一个字符的纵坐标位置
    42. var letterWidth = arrWidth[index];
    43. y = y + letterWidth;
    44. });
    45. // 水平垂直对齐方式还原
    46. context.textAlign = align;
    47. context.textBaseline = baseline;
    48. }
    49. module.exports = {
    50. drawTextVertical: drawTextVertical
    51. }

    示例:

    引入js

     

    传入参数

     

    页面显示

  • 相关阅读:
    魔百和CM311-1A_YST、(YM)_安卓9_S905L3A_默认开启ADB_纯净精简语音_完美线刷包
    SolidJs节点级响应性
    GO微服务实战第二十八节 案例:如何保证微服务实例资源安全?
    民宿酒店订房房态商城小程序的作用是什么
    蓝桥杯前端Web赛道-新鲜的蔬菜
    基于莱维飞行扰动策略的麻雀搜索算法(ISSA)(Matlab代码实现)
    前后端分离(前端)
    批量插入通话记录
    Gin 基础
    HTML学习笔记 | 青训营笔记
  • 原文地址:https://blog.csdn.net/m0_74444744/article/details/139284696
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号