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("
" + el.innerHTML + "
"); 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的打印流程了

未完待续...

你可能感兴趣的:(MacOS+SwiftUI 打印软件开发)