ConsoleUI
Demo repository to showcase how to programmatically generate images from a command-line tool with SwiftUI.
data:image/s3,"s3://crabby-images/86647/8664715d748122f75f276f62b5b1be73399879f1" alt=""
The Basics: Hello, world!
Create a new command-line executable
$ mkdir mytool && cd mytool
$ swift package init --type executable
$ swift run
Hello, world!
Generate Xcode project (optional)
Xcode does not support live previews on Swift packages yet (FB8979344). To allow for realtime previews follow these steps:
- Generate an Xcode project
- Add a macOS target to the project
- Add your view (see next section) to the macOS target
$ swift package generate-xcodeproj
$ open mytool.xcodeproj
Add SwiftUI view
Create a view with a red label over white background
import SwiftUI
struct MySwiftUIView : View {
var body: some View {
ZStack {
Color.blue.edgesIgnoringSafeArea(.all)
Text("Hello, world!")
.foregroundColor(.white)
.font(.largeTitle)
}
}
}
#if DEBUG
struct MySwiftUIView_Previews : PreviewProvider {
static var previews: some View {
MySwiftUIView()
}
}
#endif
data:image/s3,"s3://crabby-images/19bbb/19bbbabc3a9685792a99f0388a1a3c4672dc788d" alt="SwiftUI"
Rasterize view and save to file
We will use this method to rasterize views to images:
func rasterize(view: NSView, format: NSBitmapImageRep.FileType) -> Data? {
guard let bitmapRepresentation = view.bitmapImageRepForCachingDisplay(in: view.bounds) else {
return nil
}
bitmapRepresentation.size = view.bounds.size
view.cacheDisplay(in: view.bounds, to: bitmapRepresentation)
return bitmapRepresentation.representation(using: format, properties: [:])
}
The following code instantiates the SwiftUI view, wrapped inside a NSHostingView
which is then
rasterized and saved to disk
let wrapper = NSHostingView(rootView: MySwiftUIView())
wrapper.frame = CGRect(x: 0, y: 0, width: 800, height: 450)
let png = rasterize(view: wrapper, format: .png)
try png?.write(to: URL(fileURLWithPath: "test.png"))
data:image/s3,"s3://crabby-images/b7fb1/b7fb129049141afca2005ce137b387c3be4adffb" alt="main.swift"
Run the command and open in Preview
$ swift run && open test.png
data:image/s3,"s3://crabby-images/aba78/aba78158f0e5c3afbd48bd2be5bf67f73f0da7b9" alt="Preview"
ConsoleUI
Demo repository to showcase how to programmatically generate images from a command-line tool with SwiftUI.
The Basics: Hello, world!
Create a new command-line executable
Generate Xcode project (optional)
Xcode does not support live previews on Swift packages yet (FB8979344). To allow for realtime previews follow these steps:
Add SwiftUI view
Create a view with a red label over white background
Rasterize view and save to file
We will use this method to rasterize views to images:
The following code instantiates the SwiftUI view, wrapped inside a
NSHostingView
which is then rasterized and saved to diskRun the command and open in Preview