MacOS+SwiftUI 打印软件开发
最近项目上有个很奇葩的需求:公司内部管理系统(web版)的培训资料(图片、pdf),只能纸质打印,不能导出PDF。需求合理性先不管了,既然甲方大老爷开口了,做是肯定要做的,那就先调研一下目前的问题吧。
0.问题
Mac上面浏览器打印选项中可以选择“另存为PDF”,就可以保存PDF文件了。
image代码也很简单:
var iframe = document.getElementById("print-iframe");
var el = document.getElementById("printcontent");
iframe = document.createElement("IFRAME");
var doc = null;
iframe.setAttribute("id", "print-iframe");
iframe.setAttribute(
"style",
"position:absolute;width:0px;height:0px;left:-500px;top:-500px;"
);
document.body.appendChild(iframe);
doc = iframe.contentWindow.document;
doc.write("<div>" + el.innerHTML + "</div>");
doc.close();
iframe.contentWindow.focus();
iframe.contentWindow.print();
但是目前的需求是不能导出PDF,只能纸质打印。所以我遇到了第一个问题:浏览器内置的打印模块无法修改,无法禁用导出PDF功能。
这个时候我想起来,之前做过的Windows桌面端打印小票的程序。我是不是可以写一个桌面端程序,开放一个端口用于跟浏览器通讯。浏览器通过调用桌面端程序,完成打印功能,同时我在桌面端禁用导出PDF功能来实现需求。
那么问题又来了,如果是桌面端,就要考虑跨平台的问题了。之前写的是Windows端的打印程序,Mac端没有啊,只能先去搜一下是否有前人做过相关工作。功夫不负有心人,终于让我在大型同性交友平台上面找到了资源:
https://github.com/marc-medley/004.42Apple_CorePrintingExample
看看这可怜的star数就可以知道,在MacOS上开发打印软件真的是没人有这个需求哎。
image不管怎样,先把项目跑起来再说。这位兄弟的代码写的还是很不错的,虽然功能是选择本地文件夹下面的pdf文件,进行打印,而不是我需要的通过协议传递打印的内容。这个好说,我只要在这个项目基础上集成一个Websocket服务,然后让浏览器通过Websocket传输要打印的内容给打印程序就可以了。
但是,接下来我又遇到了第二个问题:MacOS自带的打印面板(Print Panel),包含了导出PDF功能,且无法禁用。
image到这里,我就有点后悔接这个需求了。但是冥冥之中我觉得还是有救的,接下来就开始研究MacOS的打印流程了
未完待续...