KMPrintPresenter.swift 47 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109
  1. //
  2. // KMPrintPresenter.swift
  3. // PDF Master
  4. //
  5. // Created by lizhe on 2022/12/21.
  6. //
  7. import Cocoa
  8. import PDFKit
  9. //MARK: CPDFKit page 方法无法使用 暂时使用系统方法
  10. class KMPrintPresenter: NSObject {
  11. lazy var printData: KMPrintModel = KMPrintModel() {
  12. didSet {
  13. self.reloadData()
  14. }
  15. }
  16. var document: CPDFDocument?
  17. fileprivate weak var delegate: KMPrintPresenterDeleage?
  18. /**
  19. 初始化presenter 绑定数据
  20. */
  21. func initPresenter(delegate: KMPrintPresenterDeleage, data: KMPrintModel, document: CPDFDocument) {
  22. self.delegate = delegate
  23. self.document = document
  24. self.printData = data
  25. // DispatchQueue.main.async {
  26. // let pdfDocument = self.updatePrintDocument(documentURL: document.documentURL, data: self.printData)
  27. // self.printData.url = pdfDocument.documentURL
  28. // }
  29. }
  30. /**
  31. 刷新数据
  32. */
  33. func reloadData() {
  34. guard let document = document else { return }
  35. let pdfDocument = self.updatePrintDocument(documentURL: document.documentURL, data: self.printData)
  36. self.printData.url = pdfDocument.documentURL
  37. }
  38. /**
  39. @abstract 解除绑定
  40. */
  41. func free() {
  42. delegate = nil
  43. }
  44. }
  45. protocol KMPrintPresenterDeleage: NSObject {
  46. func showData(presenter: KMPrintPresenter, document: CPDFDocument)
  47. }
  48. protocol KMPrintPresenterDocument: NSObject {}
  49. extension KMPrintPresenter: KMPrintPresenterDocument {
  50. /**
  51. @abstract 获取打印document
  52. @param url 源文件url
  53. @param data 数据
  54. @retrun document
  55. */
  56. func updatePrintDocument(documentURL: URL, data: KMPrintModel) -> CPDFDocument {
  57. // 获取基本参数
  58. let printModel: KMPrintModel = data
  59. //获取总page
  60. let pages = self.fetchPages(documentURL, printModel.page)
  61. //绘制PDF
  62. let filePath = self.drawPages(nil, printModel, pages)
  63. let result = CPDFDocument(url: URL(fileURLWithPath: filePath))!
  64. if self.delegate != nil {
  65. self.delegate?.showData(presenter: self, document: result)
  66. }
  67. KMPrint("保存地址" + filePath)
  68. return result
  69. }
  70. /**
  71. @abstract 插入page
  72. @param paperSet 纸张设置
  73. @param pageSet page设置
  74. @param pages page数组
  75. */
  76. func drawPages(_ toFilePath: String?,
  77. _ printModel: KMPrintModel,
  78. _ pages: [KMPrintDrawPage]) -> String {
  79. /**
  80. 参数
  81. */
  82. //纸张大小
  83. let paperSize: CGSize = self.fetchPaperSize(printModel.paper)
  84. //总页数
  85. let paperCount: Int = self.fetchTotalPaperCount(paperSize, pages, printModel.page)
  86. //每页page数
  87. let pageOfPaperCount: Int = self.fetchPageOfPaper(printModel.page)
  88. //获取每张纸的page
  89. let drawPages: [[KMPrintDrawPage]] = self.fetchDrawPages(paperSize, printModel.page, paperCount, pageOfPaperCount, pages)
  90. //导出地址
  91. let filePath = KMPrintPresenter.fetchSaveFilePath(toFilePath)
  92. /**
  93. 绘制每张纸的内容
  94. */
  95. //创建画布
  96. let context: CGContext = self.createContext(filePath, paperSize)
  97. for drawPage in drawPages {
  98. context.beginPDFPage(nil)
  99. self.drawPageToContext(context, drawPage, printModel)
  100. context.endPDFPage()
  101. }
  102. context.closePDF()
  103. return filePath
  104. }
  105. /**
  106. 获取绘制的pages
  107. @pageModel page参数
  108. @param paperCount 纸张数量
  109. @param pageOfPaperCount 每张纸的page数量
  110. @param pages 所有page数量
  111. */
  112. func fetchDrawPages(_ paperSize: CGSize, _ pageModel: KMPrintPageModel,_ paperCount: Int, _ pageOfPaperCount: Int, _ pages: [KMPrintDrawPage]) -> [[KMPrintDrawPage]] {
  113. guard pages.count != 0 else {
  114. return []
  115. }
  116. //一个page重复获取次数
  117. var pageRepetitionCount = 1
  118. if (pageModel.operation.type == .poster) {
  119. if (pageModel.operation.poster.type == .tile) {
  120. pageRepetitionCount = Int(pageModel.operation.poster.tilePoint.x * pageModel.operation.poster.tilePoint.y)
  121. } else if (pageModel.operation.poster.type == .breakUp) {
  122. pageRepetitionCount = Int(pageModel.operation.pageOfPaper.point.x * pageModel.operation.pageOfPaper.point.y)
  123. }
  124. }
  125. var drawPages:[[KMPrintDrawPage]] = []
  126. for i in 0..<paperCount {
  127. //获取多页page
  128. var tempPags: [KMPrintDrawPage] = []
  129. if pageModel.operation.type == .pamphlet {
  130. let count = paperCount * pageOfPaperCount
  131. let pagesCount = pages.count
  132. var page = KMPrintDrawPage()
  133. var page2 = KMPrintDrawPage()
  134. //第一页
  135. let index = count - (i + 1)
  136. if index < pagesCount {
  137. page = pages[index]
  138. }
  139. //第二页
  140. let index2 = i
  141. if index2 < pagesCount && index2 >= 0 {
  142. page2 = pages[index2]
  143. }
  144. if i % 2 != 0 {
  145. var temp = page2
  146. page2 = page
  147. page = temp
  148. }
  149. var pageCropRect = self.fetchPageCropRect(paperSize,i % pageRepetitionCount, pageModel, page)
  150. var pageShowRect = pageCropRect
  151. page.cropRect = pageCropRect
  152. page.showRect = pageShowRect
  153. tempPags.append(page)
  154. var pageCropRect2 = self.fetchPageCropRect(paperSize,i % pageRepetitionCount, pageModel, page2)
  155. var pageShowRect2 = pageCropRect
  156. page2.cropRect = pageCropRect2
  157. page2.showRect = pageShowRect2
  158. tempPags.append(page2)
  159. drawPages.append(tempPags)
  160. } else {
  161. for j in 0..<pageOfPaperCount {
  162. let pageIndex = i / pageRepetitionCount
  163. if (pageIndex * pageOfPaperCount + j < pages.count) {
  164. let originDrawPage = (pages[pageIndex * pageOfPaperCount + j])
  165. let drawPage = KMPrintDrawPage()
  166. drawPage.page = originDrawPage.page
  167. var pageCropRect = self.fetchPageCropRect(paperSize,i % pageRepetitionCount, pageModel, drawPage)
  168. var pageShowRect = pageCropRect
  169. if (pageModel.operation.type == .poster) {
  170. if (pageModel.operation.poster.type == .tile) {
  171. pageShowRect = self.fetchPageShowRect(paperSize, i % pageRepetitionCount, pageModel, drawPage)
  172. } else if (pageModel.operation.poster.type == .breakUp) {
  173. pageShowRect = pageCropRect
  174. }
  175. }
  176. drawPage.cropRect = pageCropRect
  177. drawPage.showRect = pageShowRect
  178. tempPags.append(drawPage)
  179. }
  180. }
  181. drawPages.append(tempPags)
  182. }
  183. }
  184. return drawPages
  185. }
  186. /**
  187. 获取pages
  188. @param type 页面类型
  189. @param contentType annoation类型
  190. @param selectPages 当type 为custom时 传入选中page的下标
  191. */
  192. static func fetchSaveFilePath(_ filePath: String?) -> String {
  193. var saveFilePath = filePath ?? ""
  194. if saveFilePath.count == 0 {
  195. saveFilePath = NSTemporaryDirectory() + "/PDFMasterTest/test2.pdf"
  196. }
  197. if !FileManager.default.fileExists(atPath: NSTemporaryDirectory() + "/PDFMasterTest") {
  198. try?FileManager.default.createDirectory(atPath: NSTemporaryDirectory() + "/PDFMasterTest", withIntermediateDirectories: true)
  199. }
  200. if FileManager.default.fileExists(atPath: saveFilePath) {
  201. try?FileManager.default.removeItem(atPath: saveFilePath)
  202. }
  203. return saveFilePath
  204. }
  205. /**
  206. 获取pages
  207. @param type 页面类型
  208. @param contentType annoation类型
  209. @param selectPages 当type 为custom时 传入选中page的下标
  210. */
  211. static func creatDocument(_ url: URL) -> CPDFDocument {
  212. if FileManager.default.fileExists(atPath: NSTemporaryDirectory() + "/PDFMasterTest") {
  213. try?FileManager.default.createDirectory(atPath: NSTemporaryDirectory() + "/PDFMasterTest", withIntermediateDirectories: true)
  214. }
  215. let document = CPDFDocument(url: url)!
  216. // document.importPages(IndexSet(integer: 0), from: document, at: 0)
  217. let count = document.pageCount
  218. for _ in 0...(count - 1) {
  219. document.removePage(at: 0)
  220. }
  221. return document
  222. }
  223. /**
  224. 获取pages
  225. @param type 页面类型
  226. @param contentType annoation类型
  227. @param selectPages 当type 为custom时 传入选中page的下标
  228. */
  229. func fetchPages(_ documentURL: URL, _ pageModel: KMPrintPageModel) -> [KMPrintDrawPage] {
  230. let document = PDFDocument.init(url: documentURL)!
  231. var pageIndexs: [Int] = []
  232. let range = pageModel.range
  233. let contentType = pageModel.contentType
  234. let reversePrintOrder = range.reversePrintOrder
  235. switch range.type {
  236. case .allPage:
  237. for index in 0...document.pageCount - 1 {
  238. pageIndexs.append(index)
  239. }
  240. case .evenPage:
  241. for index in 0...document.pageCount - 1 {
  242. if index % 2 == 0 {
  243. pageIndexs.append(index)
  244. }
  245. }
  246. case .oddPage:
  247. for index in 0...document.pageCount - 1 {
  248. if index % 2 != 0 {
  249. pageIndexs.append(index)
  250. }
  251. }
  252. case .currentPage:
  253. pageIndexs.append(0)
  254. case .custom:
  255. pageIndexs.append(0)
  256. default:
  257. pageIndexs.append(0)
  258. }
  259. var pagesArray: [KMPrintDrawPage] = []
  260. for index in pageIndexs {
  261. let page = document.page(at: index)!
  262. let drawPage = KMPrintDrawPage()
  263. drawPage.page = page
  264. self.dealPageContent(contentType, [drawPage])
  265. if reversePrintOrder {
  266. pagesArray.insert(drawPage, at: 0)
  267. } else {
  268. pagesArray.append(drawPage)
  269. }
  270. }
  271. return pagesArray
  272. }
  273. /**
  274. 处理page annoation 内容
  275. @param contentType annoation类型
  276. @param pages page
  277. */
  278. func dealPageContent (_ contentType: KMPrintContentType, _ pages: [KMPrintDrawPage]) -> Void {
  279. for page in pages {
  280. let annoations: [PDFAnnotation] = page.page.annotations
  281. //内容处理
  282. switch contentType {
  283. case .document:
  284. for annoation in annoations {
  285. annoation.page!.removeAnnotation(annoation)
  286. }
  287. case .documentAndStamp:
  288. for annoation in annoations {
  289. if !self.isAnnoationStamp(type: annoation.type!) {
  290. annoation.page!.removeAnnotation(annoation)
  291. }
  292. }
  293. case .documentAndMarkup:
  294. for annoation in annoations {
  295. if !self.isAnnoationMarkup(type: annoation.type!) {
  296. annoation.page!.removeAnnotation(annoation)
  297. }
  298. }
  299. case .documentAndForm:
  300. for annoation in annoations {
  301. if !self.isAnnoationForm(type: annoation.type!) {
  302. annoation.page!.removeAnnotation(annoation)
  303. }
  304. }
  305. default:
  306. KMPrint("未找到")
  307. break
  308. }
  309. }
  310. }
  311. /**
  312. @abstract 获取context
  313. @param size纸张大小
  314. */
  315. func createContext(_ saveFilePath: String, _ size: CGSize) -> CGContext {
  316. var mediaBox: CGRect = NSMakeRect(0, 0, size.width, size.height)
  317. let url = CFURLCreateWithFileSystemPath(nil, saveFilePath as CFString, .cfurlposixPathStyle, false)
  318. let content: CGContext = CGContext.init(url!, mediaBox: &mediaBox, nil)!
  319. return content
  320. }
  321. /**
  322. @abstract 绘制page
  323. @param context
  324. @pages page数组 [CPDFPage]
  325. */
  326. func drawPageToContext(_ context: CGContext, _ pages: [KMPrintDrawPage], _ data: KMPrintModel, _ drawPageRect: CGRect = NSZeroRect) {
  327. //左下角有坐标系原点
  328. /**
  329. paper
  330. */
  331. let paperSize: CGSize = self.fetchPaperSize(data.paper)//纸张大小
  332. let paperItemSize: CGSize = self.fetchPaperItemSize(data.paper) //页面paper大小(去除边框)
  333. let paperInset: NSEdgeInsets = data.paper.info.inset //绘制paper大小
  334. let border: Bool = data.page.operation.multipage.isBorder //是否存在边框
  335. /**
  336. page
  337. */
  338. let pageOrder: KMPrintPageOperation.Multipage.Order = .horizontal //页面顺序
  339. let pageSize: CGSize = self.fetchPageItemSize(data.page, paperItemSize) //page大小
  340. let showModel: KMPrintPageOperation.Size = self.fetchShowModel(data.page)
  341. let autoRotate = self.fetchAutoRotate(data.page)
  342. let autoSize: Bool = self.fetchAutoSize(data.page)
  343. //行列
  344. let columnAndRow = self.fetchPageColumnAndRow(data.page) //行 列数量
  345. let columnAndRowSpace = CGPoint(x: data.page.operation.multipage.lineSpacing, y: data.page.operation.multipage.columnsSpacing) //行 列之间的空间
  346. for i in 0..<Int(columnAndRow.x) {
  347. for j in 0..<(Int(columnAndRow.y)) {
  348. let index = j + i * Int(columnAndRow.y)
  349. if index < pages.count {
  350. //参数
  351. let page: KMPrintDrawPage = pages[index]
  352. let rect = page.showRect
  353. //裁剪当前Page
  354. page.page.setBounds(page.cropRect, for: .cropBox)
  355. let pageItemSize = rect.size
  356. let rotate = page.page.rotation
  357. var scale = self.fetchPageScale(page, pageSize, autoRotate, autoSize)
  358. if data.page.operation.type == .size {
  359. if showModel.model == .custom {
  360. scale *= showModel.scale
  361. } else if showModel.model == .full {
  362. scale = 1
  363. }
  364. } else if (data.page.operation.type == .poster) {
  365. if (data.page.operation.poster.type == .tile) {
  366. scale = data.page.operation.poster.scale
  367. }
  368. } else if (data.page.operation.type == .pamphlet) {
  369. let margin = data.page.operation.pamphlet.margin
  370. let tempSize = CGSizeMake((pageSize.width - margin) / 2, pageSize.height)
  371. scale = min(tempSize.width / pageSize.width, tempSize.height / pageSize.height)
  372. }
  373. //当前item的自身中心点
  374. let center = CGPoint(x: (pageSize.width - pageItemSize.width * scale) / 2.0 ,
  375. y: (pageSize.height - pageItemSize.height * scale) / 2.0)
  376. var origin = rect.origin
  377. //多页Page自动旋转
  378. // if autoSize {
  379. switch pageOrder {
  380. case .horizontal:
  381. origin.x = (pageSize.width + columnAndRowSpace.x) * CGFloat(i) + paperInset.left + center.x
  382. //页面内容高度 + 下边的行间距 - 第几个cell的高度 +居中
  383. origin.y = paperSize.height - (pageSize.height + columnAndRowSpace.y) * (CGFloat(j) + 1) + center.y + columnAndRowSpace.y
  384. case .horizontalReverseSequence:
  385. origin.x = paperSize.width - (pageSize.width + columnAndRowSpace.x) * (CGFloat(i) + 1) + center.x + columnAndRowSpace.x
  386. origin.y = paperSize.height - (pageSize.height + columnAndRowSpace.y) * (CGFloat(j) + 1) + center.y + paperInset.bottom + columnAndRowSpace.y
  387. case .vertical:
  388. origin.x = (pageSize.width + columnAndRowSpace.x) * CGFloat(i) + paperInset.left + center.x
  389. origin.y = paperSize.height - (pageSize.height + columnAndRowSpace.y) * (CGFloat(j) + 1) + center.y + paperInset.bottom + columnAndRowSpace.y
  390. case .verticalReverseSequence:
  391. origin.x = paperSize.width - (pageSize.width + columnAndRowSpace.x) * (CGFloat(i) + 1) + center.x + columnAndRowSpace.x
  392. origin.y = paperSize.height - (pageSize.height + columnAndRowSpace.y) * (CGFloat(j) + 1) + center.y + paperInset.bottom + columnAndRowSpace.y
  393. default:
  394. KMPrint("未找到")
  395. break
  396. }
  397. // }
  398. NSGraphicsContext.current = NSGraphicsContext(cgContext: context, flipped: false)
  399. NSGraphicsContext.saveGraphicsState()
  400. //平移
  401. context.translateBy(x: origin.x, y: origin.y)
  402. //缩放
  403. context.scaleBy(x: CGFloat(scale), y: CGFloat(scale))
  404. page.page.draw(with: PDFDisplayBox.cropBox, to: context)
  405. page.page.transform(context, for: PDFDisplayBox.cropBox)
  406. if border {
  407. var dirtyRect = rect
  408. //CGRectMake(origin.x, origin.y, 100, 100)
  409. if rotate == 90 ||
  410. rotate == 270 {
  411. dirtyRect = NSMakeRect(dirtyRect.origin.x, dirtyRect.origin.y, dirtyRect.size.height, dirtyRect.size.width)
  412. }
  413. context.addRect(dirtyRect)
  414. context.setStrokeColor(red: 0, green: 0, blue: 0, alpha: 1.0)
  415. context.strokePath()
  416. }
  417. NSGraphicsContext.restoreGraphicsState()
  418. // page.setBounds(NSRect(x: 0, y: 0, width: pageRect.size.width, height: pageRect.size.height), for: .cropBox)
  419. }
  420. }
  421. }
  422. }
  423. func drawLabelTextContextSize(context: CGContext) {
  424. let pageSize = CGSize(width: 0, height: 0)
  425. let KBlankA4W = pageSize.width
  426. let KBlankA4H = pageSize.height
  427. var contextString: String
  428. // if let labelString = PDFPrint.labelString, !labelString.isEmpty {
  429. // contextString = labelString
  430. // } else {
  431. let date = Date()
  432. let formatter = DateFormatter()
  433. formatter.dateFormat = "YYYY-MM-dd hh:mm:ss"
  434. contextString = "(\("1"),\("1")) \("filePath.lastPathComponent") \(formatter.string(from: date))"
  435. // }
  436. let fontSize = 12.0 * (max(KBlankA4W, KBlankA4H) / 842)
  437. let font = NSFont.systemFont(ofSize: fontSize)
  438. let color = NSColor.black
  439. var size = NSSize.zero
  440. var style = NSMutableParagraphStyle()
  441. style.alignment = .center
  442. style.lineBreakMode = .byCharWrapping
  443. var attributes = [NSAttributedString.Key: Any]()
  444. attributes[.paragraphStyle] = style
  445. attributes[.foregroundColor] = color
  446. attributes[.font] = font
  447. size = contextString.boundingRect(with: CGSize(width: CGFloat.greatestFiniteMagnitude, height: CGFloat.greatestFiniteMagnitude),
  448. options: [.usesLineFragmentOrigin, .usesFontLeading],
  449. attributes: attributes).size
  450. // if PDFPrint.splitType == .pageNumber {
  451. contextString.draw(in: CGRect(x: 10 + 10,
  452. y: KBlankA4H - 10 + size.height,
  453. width: size.width, height: size.height),
  454. withAttributes: attributes)
  455. // } else {
  456. // contextString.draw(in: CGRect(x: PDFPrint.edgeInsets.left + 10,
  457. // y: KBlankA4H - PDFPrint.edgeInsets.top + size.height,
  458. // width: size.width, height: size.height),
  459. // withAttributes: attributes)
  460. // }
  461. }
  462. }
  463. protocol KMPrintPresenterPage {}
  464. extension KMPrintPresenter: KMPrintPresenterPage {
  465. /**
  466. 获取pages
  467. @param type 页面类型
  468. @param contentType annoation类型
  469. @param selectPages 当type 为custom时 传入选中page的下标
  470. */
  471. func fetchPageCropRect(_ paperSize: CGSize, _ index: Int, _ pageModel: KMPrintPageModel, _ page: KMPrintDrawPage) -> CGRect {
  472. var newRect = page.page.bounds(for: .cropBox)
  473. if (pageModel.operation.type == .poster) {
  474. let originSize = newRect.size
  475. var cropPoint = CGPoint(x: 1, y: 1)
  476. var scale = 1.0
  477. if (pageModel.operation.poster.type == .tile) {
  478. cropPoint = pageModel.operation.poster.tilePoint
  479. // scale = pageModel.operation.poster.scale
  480. } else if (pageModel.operation.poster.type == .breakUp) {
  481. cropPoint = pageModel.operation.pageOfPaper.point
  482. }
  483. let width = originSize.width / cropPoint.x
  484. let height = originSize.height / cropPoint.y
  485. let column: Int = Int(cropPoint.x) //行
  486. let row: Int = Int(cropPoint.y) //列
  487. for i in 0...column - 1 {
  488. for j in 0...row - 1 {
  489. if i + j + i * (row - 1) == index {
  490. newRect.origin.x = CGFloat(i) * width * scale
  491. newRect.origin.y = ((originSize.height - CGFloat(j) * height - height)) * scale
  492. newRect.size.width = width * scale
  493. newRect.size.height = height * scale
  494. return newRect
  495. }
  496. }
  497. }
  498. }
  499. return newRect
  500. }
  501. func fetchPageShowRect(_ paperSize: CGSize, _ index: Int, _ pageModel: KMPrintPageModel, _ page: KMPrintDrawPage) -> CGRect {
  502. var newRect = NSZeroRect
  503. var pageRect = CGRect(x: 0, y: 0, width: paperSize.width, height: paperSize.height)
  504. if (pageModel.operation.type == .poster) {
  505. let pageSize = page.page.bounds(for: .cropBox)
  506. var cropPoint = CGPoint(x: 1, y: 1)
  507. var scale = 1.0
  508. if (pageModel.operation.poster.type == .tile) {
  509. cropPoint = pageModel.operation.poster.tilePoint
  510. scale = pageModel.operation.poster.scale
  511. } else if (pageModel.operation.poster.type == .breakUp) {
  512. cropPoint = pageModel.operation.pageOfPaper.point
  513. }
  514. if (cropPoint.x == 1 && cropPoint.y == 1) {
  515. } else {
  516. let originPaperSize = CGSize(width: paperSize.width * cropPoint.x, height: paperSize.height * cropPoint.y)
  517. let pageWidth = pageSize.width * scale
  518. let pageHeight = pageSize.height * scale
  519. let pageOrigin = CGPoint(x: (originPaperSize.width - pageWidth) / 2, y: (originPaperSize.height - pageHeight) / 2)
  520. let width = originPaperSize.width / cropPoint.x
  521. let height = originPaperSize.height / cropPoint.y
  522. let column: Int = Int(cropPoint.x) //行
  523. let row: Int = Int(cropPoint.y) //列
  524. for i in 0...column - 1 {
  525. for j in 0...row - 1 {
  526. if i + j + i * (row - 1) == index {
  527. newRect.origin.x = CGFloat(i) * width
  528. newRect.origin.y = ((originPaperSize.height - CGFloat(j) * height - height))
  529. newRect.size.width = width
  530. newRect.size.height = height
  531. if (pageOrigin.x > newRect.origin.x) {
  532. pageRect.origin.x = pageOrigin.x
  533. pageRect.size.width = newRect.size.width - pageOrigin.x
  534. } else if (originPaperSize.width - pageOrigin.x > newRect.origin.x) {
  535. pageRect.origin.x = 0
  536. pageRect.size.width = newRect.size.width - pageOrigin.x
  537. } else {
  538. pageRect.origin.x = 0
  539. pageRect.size.width = newRect.size.width
  540. }
  541. if (originPaperSize.height - pageOrigin.y < newRect.origin.y + newRect.size.height) {
  542. pageRect.origin.y = 0
  543. pageRect.size.height = newRect.size.height - pageOrigin.y
  544. } else if (pageOrigin.y > newRect.origin.y) {
  545. pageRect.origin.y = pageOrigin.y
  546. pageRect.size.height = newRect.size.height - pageOrigin.y
  547. } else {
  548. pageRect.origin.y = newRect.origin.y - pageOrigin.y
  549. pageRect.size.height = newRect.size.height
  550. }
  551. return pageRect
  552. }
  553. }
  554. }
  555. }
  556. }
  557. return pageRect
  558. }
  559. func fetchPageColumnAndRow(_ pageModel: KMPrintPageModel) -> CGPoint {
  560. var point = NSZeroPoint
  561. let pageOrder: KMPrintPageOperation.Multipage.Order = pageModel.operation.multipage.orderType //页面顺序
  562. switch pageModel.operation.type {
  563. case .multipage:
  564. point.x = pageModel.operation.pageOfPaper.point.x
  565. point.y = pageModel.operation.pageOfPaper.point.y
  566. case .pamphlet:
  567. point.x = 1
  568. point.y = 2
  569. default:
  570. point.x = 1
  571. point.y = 1
  572. }
  573. //如果是横向参数需切换
  574. if pageOrder == .horizontal ||
  575. pageOrder == .horizontalReverseSequence {
  576. let temp = point.x
  577. point.x = point.y
  578. point.y = temp
  579. }
  580. return point
  581. }
  582. func fetchAutoRotate(_ pageModel: KMPrintPageModel) -> Bool {
  583. var autoRotate = false
  584. switch pageModel.operation.type {
  585. case .multipage:
  586. autoRotate = pageModel.operation.isAutoRotate
  587. case .pamphlet:
  588. autoRotate = pageModel.operation.isAutoRotate
  589. default:
  590. autoRotate = false
  591. }
  592. return autoRotate
  593. }
  594. func fetchAutoSize(_ pageModel: KMPrintPageModel) -> Bool {
  595. var autoSize = false
  596. switch pageModel.operation.type {
  597. case .size:
  598. autoSize = true
  599. default:
  600. autoSize = false
  601. }
  602. return autoSize
  603. }
  604. func fetchShowModel(_ pageModel: KMPrintPageModel) -> KMPrintPageOperation.Size {
  605. var model = KMPrintPageOperation.Size()
  606. switch pageModel.operation.type {
  607. case .size:
  608. model = pageModel.operation.size
  609. default:
  610. model = KMPrintPageOperation.Size()
  611. }
  612. return model
  613. }
  614. func fetchPageItemSize(_ pageModel: KMPrintPageModel, _ paperSize: CGSize) -> CGSize {
  615. var size = NSZeroSize
  616. let columnAndRow = self.fetchPageColumnAndRow(pageModel) //行 列数量
  617. let lineSpacing = pageModel.operation.multipage.lineSpacing
  618. let columnsSpacing = pageModel.operation.multipage.columnsSpacing
  619. let columnAndRowSpace = CGPoint(x: lineSpacing, y: columnsSpacing) //行 列之间的空间
  620. //page大小
  621. if pageModel.operation.type == .multipage {
  622. size = CGSize(width: (paperSize.width - CGFloat((columnAndRow.x - 1)) * CGFloat(columnAndRowSpace.x)) / columnAndRow.x,
  623. height: (paperSize.height - CGFloat((columnAndRow.y - 1)) * CGFloat(columnAndRowSpace.y)) / columnAndRow.y)
  624. } else {
  625. size = CGSize(width: (paperSize.width - CGFloat((columnAndRow.x - 1)) * CGFloat(columnAndRowSpace.x)) / columnAndRow.x,
  626. height: (paperSize.height - CGFloat((columnAndRow.y - 1)) * CGFloat(columnAndRowSpace.y)) / columnAndRow.y)
  627. }
  628. return size
  629. }
  630. func fetchPageScale(_ page: KMPrintDrawPage, _ pageItemSize: CGSize, _ autoRotate: Bool, _ autoSize: Bool) -> CGFloat {
  631. var scale = 1.0
  632. let originSize = page.page.bounds(for: .cropBox)
  633. var rotate = page.page.rotation
  634. //取出page横竖时能显示的最大Rect
  635. if autoRotate {
  636. //page旋转度数为0度或者180度时,在指定的大小内,能显示的比例
  637. let scale1 = min(pageItemSize.width / originSize.width, pageItemSize.height / originSize.height)
  638. //page旋转度数为90度或者270度时,在指定的大小内,能显示的比例
  639. let scale2 = min(pageItemSize.width / originSize.height, pageItemSize.height / originSize.width)
  640. scale = max(scale1, scale2)
  641. if scale1 > scale2 {
  642. //高为竖直排列时,显示最大,则需将page时90度或者270度需要进行旋转
  643. if rotate == 90 || rotate == 270 {
  644. rotate = rotate - 90
  645. }
  646. } else {
  647. //宽为竖直排列时,显示最大,则需将page时0度或者180度需要进行旋转
  648. if rotate == 0 || rotate == 180 {
  649. rotate = rotate - 90
  650. }
  651. }
  652. } else {
  653. scale = min(pageItemSize.width / originSize.width, pageItemSize.height / originSize.height)
  654. }
  655. if (autoSize) {
  656. } else {
  657. scale = min(scale, 1)
  658. }
  659. return scale
  660. }
  661. func fetchPageRotate(_ page: KMPrintDrawPage, _ pageItemSize: CGSize, _ autoRotate: Bool) -> CGFloat {
  662. var scale = 1.0
  663. let originSize = page.page.bounds(for: .cropBox)
  664. var rotate = page.page.rotation
  665. //取出page横竖时能显示的最大Rect
  666. if autoRotate {
  667. //page旋转度数为0度或者180度时,在指定的大小内,能显示的比例
  668. let scale1 = min(pageItemSize.width / originSize.width, pageItemSize.height / originSize.height)
  669. //page旋转度数为90度或者270度时,在指定的大小内,能显示的比例
  670. let scale2 = min(pageItemSize.width / originSize.height, pageItemSize.height / originSize.width)
  671. scale = max(scale1, scale2)
  672. if scale1 > scale2 {
  673. //高为竖直排列时,显示最大,则需将page时90度或者270度需要进行旋转
  674. if rotate == 90 || rotate == 270 {
  675. rotate = rotate - 90
  676. }
  677. } else {
  678. //宽为竖直排列时,显示最大,则需将page时0度或者180度需要进行旋转
  679. if rotate == 0 || rotate == 180 {
  680. rotate = rotate - 90
  681. }
  682. }
  683. } else {
  684. scale = min(pageItemSize.width / originSize.width, pageItemSize.height / originSize.height)
  685. }
  686. return scale
  687. }
  688. func fetchPageLite(pageModel: KMPrintPageModel) {
  689. }
  690. }
  691. protocol KMPrintPresenterPaper {}
  692. extension KMPrintPresenter: KMPrintPresenterPaper {
  693. /**
  694. 获取每张纸的page
  695. @param type 页面类型
  696. @param contentType annoation类型
  697. @param selectPages 当type 为custom时 传入选中page的下标
  698. */
  699. func fetchPageOfPaper(_ pageModel: KMPrintPageModel) -> Int {
  700. var count = 1
  701. switch pageModel.operation.type {
  702. case .multipage:
  703. count = Int(pageModel.operation.pageOfPaper.point.x * pageModel.operation.pageOfPaper.point.y)
  704. case .poster:
  705. count = Int(pageModel.operation.pageOfPaper.point.x * pageModel.operation.pageOfPaper.point.y)
  706. case .pamphlet:
  707. count = 2
  708. default:
  709. count = 1
  710. }
  711. return count
  712. }
  713. /**
  714. 获取总纸张数
  715. @param pages page总数
  716. @param contentType annoation类型
  717. @param selectPages 当type 为custom时 传入选中page的下标
  718. */
  719. func fetchTotalPaperCount (_ paperSize: CGSize, _ pages: [KMPrintDrawPage], _ pageModel: KMPrintPageModel) -> Int {
  720. var count = 1
  721. let pageOfPaper = self.fetchPageOfPaper(pageModel)
  722. switch pageModel.operation.type {
  723. case .multipage:
  724. count = Int(ceilf(Float(pages.count / pageOfPaper)))
  725. case .poster:
  726. if (pageModel.operation.poster.type == .tile) {
  727. //1 2 4 9 16
  728. let scale = pageModel.operation.poster.scale
  729. let pageSize = pages.first?.page.bounds(for: .cropBox).size ?? paperSize
  730. let point = self.fetchPosterPageCount(paperSize: paperSize, pageSize: pageSize, scale: scale)
  731. pageModel.operation.poster.tilePoint = point
  732. count = Int((point.x * point.y)) * pages.count
  733. } else if (pageModel.operation.poster.type == .breakUp) {
  734. count = Int((pageModel.operation.pageOfPaper.point.x * pageModel.operation.pageOfPaper.point.y)) * pages.count
  735. } else {
  736. count = Int(ceilf(Float(pages.count / pageOfPaper)))
  737. }
  738. case .pamphlet: do {
  739. let temp = pages.count%4
  740. if temp == 0 {
  741. count = pages.count / 4
  742. } else {
  743. count = pages.count / 4 + 1
  744. }
  745. count = count * 2
  746. }
  747. default:
  748. count = Int(ceilf(Float(pages.count / pageOfPaper)))
  749. }
  750. return count
  751. }
  752. func fetchPosterPageCount(paperSize: CGSize, pageSize: CGSize, scale: CGFloat) -> CGPoint {
  753. var xCount: Int = 1
  754. var yCount: Int = 1
  755. var contain: Bool = true
  756. while (contain) {
  757. if (pageSize.width * scale < CGFloat(xCount) * paperSize.width &&
  758. pageSize.height * scale < CGFloat(yCount) * paperSize.height) {
  759. contain = false
  760. break
  761. }
  762. //增加行数 和 列数
  763. if xCount == yCount {
  764. xCount += 1
  765. } else {
  766. yCount += 1
  767. }
  768. }
  769. return CGPoint(x: xCount, y: yCount)
  770. }
  771. /**
  772. 获取pages
  773. @param type 页面类型
  774. @param contentType annoation类型
  775. @param selectPages 当type 为custom时 传入选中page的下标
  776. */
  777. func fetchPaperSize(_ paperModel: KMPrintPaperModel) -> CGSize {
  778. var paperSize = KMPrintPaperInfo.KMPaperType.paperSize(type: paperModel.info.type, unit: .px)
  779. let direction = paperModel.direction
  780. if direction == .vertical {
  781. paperSize = CGSize(width: paperSize.width, height: paperSize.height)
  782. } else if direction == .horizontal {
  783. paperSize = CGSize(width: paperSize.height, height: paperSize.width)
  784. }
  785. return paperSize
  786. }
  787. func fetchPaperItemSize(_ paperModel: KMPrintPaperModel) -> CGSize {
  788. var paperSize = self.fetchPaperSize(paperModel)
  789. let paperInset = paperModel.info.inset
  790. paperSize = CGSize(width: paperSize.width - paperInset.left - paperInset.right,
  791. height: paperSize.height - paperInset.bottom - paperInset.top)
  792. return paperSize
  793. }
  794. }
  795. protocol KMPrintPresenterDraw {}
  796. extension KMPrintPresenter: KMPrintPresenterDraw {
  797. // -(void)drawCutMarkContext:(CGContextRef)context contextSize:(CGSize)size
  798. // {
  799. // CGContextSetStrokeColorWithColor(context, [NSColor blackColor].CGColor);
  800. // CGContextSetLineWidth(context, 1.0);
  801. // CGContextSetLineCap(context, kCGLineCapSquare);
  802. //
  803. // if(self.columnIndex == 1 && self.lineIndex == 1) {
  804. // [self drawLeftBottomCutMarks:context size:size];
  805. // [self drawRightTopCutMarks:context size:size];
  806. // [self drawRightBottomCutMarks:context size:size];
  807. // } else if (self.lineIndex == 1 && self.columnIndex == self.vertArray.count) {
  808. // [self drawLeftTopCutMarks:context size:size];
  809. // [self drawRightTopCutMarks:context size:size];
  810. // [self drawRightBottomCutMarks:context size:size];
  811. // } else if (self.columnIndex == 1 && self.lineIndex == self.hourArray.count) {
  812. // [self drawLeftTopCutMarks:context size:size];
  813. // [self drawLeftBottomCutMarks:context size:size];
  814. // [self drawRightBottomCutMarks:context size:size];
  815. // } else if (self.columnIndex == self.vertArray.count && self.hourArray.count == self.lineIndex) {
  816. // [self drawLeftTopCutMarks:context size:size];
  817. // [self drawLeftBottomCutMarks:context size:size];
  818. // [self drawRightTopCutMarks:context size:size];
  819. // } else {
  820. // [self drawLeftTopCutMarks:context size:size];
  821. // [self drawLeftBottomCutMarks:context size:size];
  822. // [self drawRightTopCutMarks:context size:size];
  823. // [self drawRightBottomCutMarks:context size:size];
  824. // }
  825. // //绘制完成
  826. // CGContextStrokePath(context);
  827. // }
  828. //
  829. // //左上角切割标记
  830. // -(void)drawLeftTopCutMarks:(CGContextRef)context size:(CGSize)size
  831. // {
  832. // CGFloat KBlankA4H =size.height;
  833. // CGPoint point_LeftTop = CGPointZero;
  834. //
  835. // if (self.PDFPrint.splitType == kKMPDFPosterSplitType_PageNumber) {
  836. // point_LeftTop.x = self.PDFPrint.fullPageEdgeInsets.left;
  837. // } else {
  838. // point_LeftTop.x = self.PDFPrint.edgeInsets.left;
  839. // }
  840. //
  841. // point_LeftTop.y = KBlankA4H - self.PDFPrint.edgeInsets.top;
  842. //
  843. // CGContextMoveToPoint(context, 10,point_LeftTop.y);
  844. // CGContextAddLineToPoint(context,point_LeftTop.x, point_LeftTop.y);
  845. //
  846. // CGContextMoveToPoint(context, point_LeftTop.x - 10,KBlankA4H -10);
  847. // CGContextAddLineToPoint(context,point_LeftTop.x - 10,point_LeftTop.y);
  848. // }
  849. //
  850. // //右上角切割标记
  851. // -(void)drawRightTopCutMarks:(CGContextRef)context size:(CGSize)size
  852. // {
  853. // CGFloat KBlankA4W =size.width;
  854. // CGFloat KBlankA4H =size.height;
  855. //
  856. // CGPoint point_RightTop = CGPointZero;//右上角
  857. //
  858. // if (self.PDFPrint.splitType == kKMPDFPosterSplitType_PageNumber) {
  859. // point_RightTop.x = KBlankA4W - self.PDFPrint.fullPageEdgeInsets.right;
  860. // point_RightTop.y = KBlankA4H - self.PDFPrint.fullPageEdgeInsets.top;
  861. // } else {
  862. // point_RightTop.x = KBlankA4W - self.PDFPrint.edgeInsets.right;
  863. // point_RightTop.y = KBlankA4H - self.PDFPrint.edgeInsets.top;
  864. // }
  865. //
  866. // CGContextMoveToPoint(context,point_RightTop.x,point_RightTop.y);
  867. // CGContextAddLineToPoint(context,KBlankA4W - 10,point_RightTop.y);
  868. //
  869. // CGContextMoveToPoint(context,point_RightTop.x + 10,KBlankA4H - 10);
  870. // CGContextAddLineToPoint(context,point_RightTop.x + 10,point_RightTop.y);
  871. // }
  872. //
  873. // //左下角切割标记
  874. // -(void)drawLeftBottomCutMarks:(CGContextRef)context size:(CGSize)size
  875. // {
  876. // CGPoint point_LeftBottom = CGPointZero;//左下角
  877. // if (self.PDFPrint.splitType == kKMPDFPosterSplitType_PageNumber) {
  878. // point_LeftBottom.x = self.PDFPrint.fullPageEdgeInsets.left;
  879. // point_LeftBottom.y = self.PDFPrint.fullPageEdgeInsets.bottom;
  880. // } else {
  881. // point_LeftBottom.x = self.PDFPrint.edgeInsets.left;
  882. // point_LeftBottom.y = self.PDFPrint.edgeInsets.bottom;
  883. // }
  884. //
  885. // //左下角
  886. // CGContextMoveToPoint(context, 10,point_LeftBottom.y);
  887. // CGContextAddLineToPoint(context,point_LeftBottom.x, point_LeftBottom.y);
  888. //
  889. // CGContextMoveToPoint(context, point_LeftBottom.x- 10,10);
  890. // CGContextAddLineToPoint(context,point_LeftBottom.x - 10,point_LeftBottom.y);
  891. // }
  892. //
  893. // //右下角切割标记
  894. // -(void)drawRightBottomCutMarks:(CGContextRef)context size:(CGSize)size
  895. // {
  896. // CGFloat KBlankA4W =size.width;
  897. //
  898. // CGPoint point_RightBottom = CGPointZero;//右下角
  899. // if (self.PDFPrint.splitType == kKMPDFPosterSplitType_PageNumber) {
  900. // point_RightBottom.x = KBlankA4W - self.PDFPrint.fullPageEdgeInsets.right;
  901. // point_RightBottom.y = self.PDFPrint.fullPageEdgeInsets.bottom;
  902. // } else {
  903. // point_RightBottom.x = KBlankA4W - self.PDFPrint.edgeInsets.right;
  904. // point_RightBottom.y = self.PDFPrint.edgeInsets.bottom;
  905. // }
  906. //
  907. // CGContextMoveToPoint(context,KBlankA4W - 10,point_RightBottom.y);
  908. // CGContextAddLineToPoint(context,point_RightBottom.x,point_RightBottom.y);
  909. //
  910. // CGContextMoveToPoint(context,point_RightBottom.x+ 10,10);
  911. // CGContextAddLineToPoint(context,point_RightBottom.x+ 10,point_RightBottom.y);
  912. // }
  913. func drawString(_ pageModel: KMPrintPageModel, _ contextSize: CGSize) {
  914. var string = pageModel.operation.poster.tags.first ?? ""
  915. // if string.isEmpty {
  916. // string =
  917. // }
  918. }
  919. //
  920. // - (void)drawLabelTextContextSize:(CGSize)contextSize
  921. // {
  922. // CGFloat KBlankA4W =contextSize.width;
  923. // CGFloat KBlankA4H =contextSize.height;
  924. //
  925. // NSString *contextString = nil;
  926. // if (self.PDFPrint.labelString && self.PDFPrint.labelString.length > 0) {
  927. // contextString = self.PDFPrint.labelString;
  928. // } else {
  929. // NSDate *date = [NSDate date];
  930. // NSDateFormatter *formatter = [[[NSDateFormatter alloc] init] autorelease];
  931. // [formatter setDateFormat:@"YYYY-MM-dd hh:mm:ss"];
  932. // contextString = [NSString stringWithFormat:@"(%ld,%ld) %@ %@",self.columnIndex,self.lineIndex,[self.filePath lastPathComponent],[formatter stringFromDate:date]];
  933. // }
  934. //
  935. // CGFloat fontSize = 12.0 * (MAX(KBlankA4W, KBlankA4H)/842);
  936. // NSFont *font = [NSFont systemFontOfSize:fontSize];
  937. // NSColor *color = [NSColor blackColor];
  938. //
  939. // NSSize size = NSZeroSize;
  940. // NSMutableParagraphStyle *style = [[[NSMutableParagraphStyle alloc] init] autorelease];
  941. // [style setAlignment:NSCenterTextAlignment];
  942. // [style setLineBreakMode:NSLineBreakByCharWrapping];
  943. // NSMutableDictionary *dictionary = [NSMutableDictionary dictionary];
  944. // [dictionary setObject:style forKey:NSParagraphStyleAttributeName];
  945. // [dictionary setObject:color forKey:NSForegroundColorAttributeName];
  946. // [dictionary setObject:font forKey:NSFontAttributeName];
  947. // size = [contextString boundingRectWithSize:CGSizeMake(MAXFLOAT, MAXFLOAT)
  948. // options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading
  949. // attributes:dictionary].size;
  950. //
  951. // if (self.PDFPrint.splitType == kKMPDFPosterSplitType_PageNumber) {
  952. // [contextString drawInRect:CGRectMake(self.PDFPrint.fullPageEdgeInsets.left +10,
  953. // KBlankA4H - self.PDFPrint.fullPageEdgeInsets.top + size.height,
  954. // size.width, size.height)
  955. // withAttributes:dictionary];
  956. // } else {
  957. // [contextString drawInRect:CGRectMake(self.PDFPrint.edgeInsets.left +10,
  958. // KBlankA4H - self.PDFPrint.edgeInsets.top + size.height,
  959. // size.width, size.height)
  960. // withAttributes:dictionary];
  961. // }
  962. //
  963. // }
  964. }
  965. protocol KMPrintPresenterPrivate {}
  966. extension KMPrintPresenter: KMPrintPresenterPrivate {
  967. func isAnnoationStamp(type: String) -> Bool {
  968. let annotationStamp: [String] = ["Square", "Stamp"]
  969. return annotationStamp.contains(type)
  970. }
  971. func isAnnoationMarkup(type: String) -> Bool {
  972. let annotationStamp: [String] = ["Widget", "Freehand", "Highlight", "Underline", "Squiggly", "Circle", "StrikeOut", "Ink"]
  973. return annotationStamp.contains(type)
  974. }
  975. func isAnnoationForm(type: String) -> Bool {
  976. let annotationStamp: [String] = ["FreeText"]
  977. return annotationStamp.contains(type)
  978. }
  979. }
  980. protocol KMPrintPresenterProtocol: NSObject {
  981. }
  982. ///**
  983. // @abstract 获取context
  984. // @param size纸张大小
  985. // */
  986. //func createContext(_ saveFilePath: String, size: CGSize) -> CGContext {
  987. // let s = CGSize(width: nearbyint(size.width), height: nearbyint(size.height))
  988. // let rep = NSBitmapImageRep.init(bitmapDataPlanes: nil,
  989. // pixelsWide: Int(s.width),
  990. // pixelsHigh: Int(s.height),
  991. // bitsPerSample: 8,
  992. // samplesPerPixel: 4,
  993. // hasAlpha: true,
  994. // isPlanar: false,
  995. // colorSpaceName: NSColorSpaceName.calibratedRGB,
  996. // bytesPerRow: 0,
  997. // bitsPerPixel: 0)!
  998. // let context: CGContext = NSGraphicsContext.init(bitmapImageRep: rep)!.cgContext
  999. // return context
  1000. //}