https://github.com/danielsaidi/printingkit
Easily print texts, views, images, PDFs etc. from any SwiftUI app.
https://github.com/danielsaidi/printingkit
ios ipados macos pdf print printer swift swiftui tvos visionos watchos
Last synced: 11 days ago
JSON representation
Easily print texts, views, images, PDFs etc. from any SwiftUI app.
- Host: GitHub
- URL: https://github.com/danielsaidi/printingkit
- Owner: danielsaidi
- License: mit
- Created: 2023-08-21T11:30:53.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2025-06-01T19:04:45.000Z (4 months ago)
- Last Synced: 2025-09-17T20:47:29.654Z (17 days ago)
- Topics: ios, ipados, macos, pdf, print, printer, swift, swiftui, tvos, visionos, watchos
- Language: Shell
- Homepage: https://danielsaidi.com/opensource
- Size: 3.99 MB
- Stars: 114
- Watchers: 5
- Forks: 13
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
![]()
# PrintingKit
PrintingKit is a SwiftUI library that lets you print images, strings, views, files, PDFs, etc. from any SwiftUI app. Just create a ``Printer`` instance or use the ``Printer.shared`` printer, then call any of its print functions to print.
## Installation
PrintingKit can be installed with the Swift Package Manager:
```
https://github.com/danielsaidi/PrintingKit.git
```## Support My Work
You can [become a sponsor][Sponsors] to help me dedicate more time on my various [open-source tools][OpenSource]. Every contribution, no matter the size, makes a real difference in keeping these tools free and actively developed.
## Getting started
To print, just create a ``Printer`` instance, or use the ``Printer.shared`` printer, then use it to print any of the following supported printable types:
* ``printAttributedString(_:config:)`` - print an attributed string.
* ``printData(_:withFileExtension:)`` - try to print generic data.
* ``printFile(at:)`` - try to print a generic file.
* ``printImage(_:)`` - print a `UIImage` or `NSImage`.
* ``printImageData(_:)`` - print JPG or PNG data.
* ``printImageFile(at:)`` - print a JPG or PNG file at a certain URL.
* ``printPdfData(_:)`` - print PDF document data.
* ``printPdfFile(at:)`` - print a PDF document file at a certain URL.
* ``printString(_:config:)`` - print a plain string.
* ``printView(_:withScale:)`` - print a SwiftUI view.In SwiftUI, you can either print programatically, when a user taps/clicks a button, etc.:
```swift
struct MyView: View {var body: some View {
VStack {
Button("Print something") {
do {
try? Printer.shared.printString("Hello, world!")
} catch {
print("Handle this \(error)")
}
}
}
}
}
```PrintingKit also has PDF utilities, which are used to print certain types. Since these utilies are the only ones that support paper size, page margins, etc. we should aim to make more print functions use PDF as print format.
> Note: Only some functions support providing a custom page configuration, which can be used to specify paper size and margins. More functions should support this functionality in the future.
## macOS Sandbox Configuration
For a sandboxed application (default on macOS), you must allow printing in the target's "Signing & Capabilities" > "App Sandbox" section or, you'll be met with the error "This application does not support printing.".
## Documentation
The online [documentation][Documentation] has more information, articles, code examples, etc.
## Demo Application
The `Demo` folder has a demo app that lets you explore the library.
## Contact
Feel free to reach out if you have questions, or want to contribute in any way:
* Website: [danielsaidi.com][Website]
* E-mail: [daniel.saidi@gmail.com][Email]
* Bluesky: [@danielsaidi@bsky.social][Bluesky]
* Mastodon: [@danielsaidi@mastodon.social][Mastodon]## License
PrintingKit is available under the MIT license. See the [LICENSE][License] file for more info.
[Email]: mailto:daniel.saidi@gmail.com
[Website]: https://danielsaidi.com
[GitHub]: https://github.com/danielsaidi
[OpenSource]: https://danielsaidi.com/opensource
[Sponsors]: https://github.com/sponsors/danielsaidi[Bluesky]: https://bsky.app/profile/danielsaidi.bsky.social
[Mastodon]: https://mastodon.social/@danielsaidi
[Twitter]: https://twitter.com/danielsaidi[Documentation]: https://danielsaidi.github.io/PrintingKit
[License]: https://github.com/danielsaidi/PrintingKit/blob/master/LICENSE