当前位置:   article > 正文

小程序使用Canvas设置文字竖向排列_canvas怎么改成竖版文字

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

 

传入参数

 

页面显示

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/682638
推荐阅读
相关标签
  

闽ICP备14008679号