SPaintEngine.ts 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283
  1. import { SLine, SPaintEngineType, SPath2D, SPoint, SRect } from "..";
  2. import { SPaintState } from "./SPaintState";
  3. /**
  4. * 绘制引擎基类
  5. *
  6. * @author 庞利祥(sybotan@126.com)
  7. */
  8. export abstract class SPaintEngine {
  9. /** 当关状态 */
  10. private _state = new SPaintState();
  11. get state(): SPaintState {
  12. return this._state;
  13. } // Function state()
  14. set state(value: SPaintState) {
  15. this._state = value;
  16. } // Function state()
  17. /** 状态栈 */
  18. private stateStack = new Array<SPaintState>();
  19. /** 绘制引擎类型 */
  20. abstract get type(): SPaintEngineType;
  21. /**
  22. * 保存painter状态
  23. */
  24. save(): void {
  25. let state = new SPaintState(this.state);
  26. this.stateStack.push(state);
  27. } // Function save()
  28. /**
  29. * 恢复painter状态
  30. */
  31. restore(): void {
  32. if (this.stateStack.length > 0) {
  33. this.state = this.stateStack.pop() as SPaintState;
  34. }
  35. } // Function restore()
  36. // =================================================================================================================
  37. // 变换相关
  38. /**
  39. * 平移变换
  40. *
  41. * @param x X轴方向平移
  42. * @param y Y辆方向平移
  43. */
  44. translate(x: number, y: number): void {
  45. this.state.matrix.translateSelf(x, y);
  46. } // Function translate()
  47. /**
  48. * 缩放
  49. *
  50. * @param x X轴方向缩放
  51. * @param y Y辆方向缩放
  52. */
  53. scale(x: number, y: number): void {
  54. this.state.matrix.scaleSelf(x, y);
  55. } // Function scale()
  56. /**
  57. * 旋转
  58. *
  59. * @param angle 旋转角度(单位弧度)
  60. */
  61. rotate(angle: number): void {
  62. this.state.matrix.rotateSelf(0, 0, angle);
  63. } // Function rotate()
  64. /**
  65. * 将当前的变形矩阵乘上一个基于自身参数的矩阵
  66. *
  67. * @param m11 水平方向的缩放
  68. * @param m12 水平方向的倾斜偏移
  69. * @param m21 竖直方向的倾斜偏移
  70. * @param m22 竖直方向的缩放
  71. * @param dx 水平方向的移动
  72. * @param dy 竖直方向的移动
  73. */
  74. transform(
  75. m11: number,
  76. m12: number,
  77. m21: number,
  78. m22: number,
  79. dx: number,
  80. dy: number
  81. ): void {} // Function transform()
  82. /**
  83. * 将当前的变形矩阵重置为单位矩阵,再将当前的变形矩阵乘上一个基于自身参数的矩阵
  84. *
  85. * @param m11 水平方向的缩放
  86. * @param m12 水平方向的倾斜偏移
  87. * @param m21 竖直方向的倾斜偏移
  88. * @param m22 竖直方向的缩放
  89. * @param dx 水平方向的移动
  90. * @param dy 竖直方向的移动
  91. */
  92. setTransform(
  93. m11: number,
  94. m12: number,
  95. m21: number,
  96. m22: number,
  97. dx: number,
  98. dy: number
  99. ): void {} // Function transform()
  100. /**
  101. * 重置当前变形为单位矩阵。等价于调用setTransform(1, 0, 0, 1, 0, 0)
  102. */
  103. resetTransform(): void {
  104. this.state.matrix = new DOMMatrix();
  105. } // Function resetTransform()
  106. // =================================================================================================================
  107. // 绘制图形
  108. /**
  109. * 设置裁剪路径
  110. *
  111. * @param path 裁剪路径
  112. */
  113. abstract setClip(path: Path2D): void;
  114. /**
  115. * 清空矩形区域
  116. *
  117. * @param rect 矩形
  118. */
  119. abstract clearRect(rect: SRect): void;
  120. /**
  121. * 绘制空心矩形
  122. *
  123. * @param rect 矩形
  124. */
  125. abstract drawRect(rect: SRect): void;
  126. /**
  127. * 绘制圆形
  128. *
  129. * @param cx 圆心X坐标
  130. * @param cy 圆心X坐标
  131. * @param r 圆半径
  132. */
  133. abstract drawCircle(cx: number, cy: number, r: number): void;
  134. /**
  135. * 绘制椭圆
  136. *
  137. * @param cx 圆点X坐标
  138. * @param cy 圆点Y坐标
  139. * @param rx 水平半径
  140. * @param ry 垂直半径
  141. */
  142. abstract drawEllipse(cx: number, cy: number, rx: number, ry: number): void;
  143. /**
  144. * 绘制椭圆弧
  145. *
  146. * @param x 椭圆所在矩形X坐标
  147. * @param y 椭圆所在矩形Y坐标
  148. * @param width 椭圆所在矩形宽度
  149. * @param height 椭圆所在矩形高度
  150. * @param startRadian 开始角度(单位弧度)
  151. * @param endRadian 结束角度(单位弧度)
  152. */
  153. abstract drawArc(
  154. x: number,
  155. y: number,
  156. width: number,
  157. height: number,
  158. startRadian: number,
  159. endRadian: number
  160. ): void;
  161. /**
  162. * 绘制椭圆弦弧
  163. *
  164. * @param x 椭圆所在矩形X坐标
  165. * @param y 椭圆所在矩形Y坐标
  166. * @param width 椭圆所在矩形宽度
  167. * @param height 椭圆所在矩形高度
  168. * @param startRadian 开始角度(单位弧度)
  169. * @param endRadian 结束角度(单位弧度)
  170. */
  171. abstract drawChord(
  172. x: number,
  173. y: number,
  174. width: number,
  175. height: number,
  176. startRadian: number,
  177. endRadian: number
  178. ): void;
  179. /**
  180. * 绘制椭圆饼
  181. *
  182. * @param x 椭圆所在矩形X坐标
  183. * @param y 椭圆所在矩形Y坐标
  184. * @param width 椭圆所在矩形宽度
  185. * @param height 椭圆所在矩形高度
  186. * @param startAngle 开始角度(单位弧度)
  187. * @param endAngle 结束角度(单位弧度)
  188. */
  189. abstract drawPie(
  190. x: number,
  191. y: number,
  192. width: number,
  193. height: number,
  194. startAngle: number,
  195. endAngle: number
  196. ): void;
  197. /**
  198. * 绘制线段
  199. *
  200. * @param line 线段
  201. */
  202. abstract drawLine(line: SLine): void;
  203. /**
  204. * 绘制折线
  205. *
  206. * @param points 折线折点
  207. */
  208. abstract drawPolyline(points: SPoint[]): void;
  209. /**
  210. * 绘制多边形
  211. *
  212. * @param points 多边形顶点
  213. */
  214. abstract drawPolygon(points: SPoint[]): void;
  215. /**
  216. * 绘制路径
  217. *
  218. * @param path 路径
  219. */
  220. abstract drawPath(path: SPath2D): void;
  221. /**
  222. * 绘制文本
  223. *
  224. * @param text 文本内容
  225. * @param x X坐标
  226. * @param y Y坐标
  227. * @param maxWidth 最大宽度
  228. */
  229. abstract drawText(
  230. text: string,
  231. x: number,
  232. y: number,
  233. maxWidth?: number
  234. ): void;
  235. /**
  236. * 绘制图片
  237. *
  238. * @param img 图片
  239. * @param x X坐标
  240. * @param y Y坐标
  241. * @param width 宽度
  242. * @param height 高度
  243. */
  244. abstract drawImage(
  245. img: CanvasImageSource,
  246. x: number,
  247. y: number,
  248. width?: number,
  249. height?: number
  250. ): void;
  251. /**
  252. * 预测量文本宽度
  253. *
  254. * @param text 预测的文本
  255. * */
  256. abstract textWidth(text: string): number;
  257. } // class SPaintEngine