SwiftGtk is a experimental Gtk+ binding for Swift that tries to make usage of Gtk+ pleasant and "Swifty" as much as possible. Currently it implements only a small subset of Gtk+ and it works on Mac OS X and Linux.
You need to have Swift 3.0 or higher installed on your computer (tested with 3.0.2 bundled with Xcode 8.2.1) and depending on your platform you need to install Gtk+3. On Mac OS X you also build the project with Xcode.
You need to have Gtk+3 installed on your machine. Recommended way for installing Gtk+3 is through homebrew.
brew install gtk+3
You need to have Gtk+3 and Clang installed on your machine. You can easily install them with apt-get
.
sudo apt-get install libgtk-3-dev clang
SwiftGtk supports Swift Package Manager so you only need to add SwiftGtk to your Package.swift
.
import PackageDescription
let package = Package(
name: "SwiftGtkApplication",
dependencies: [
.Package(url: "https://github.com/TomasLinhart/SwiftGtk", majorVersion: 0, minor: 2)
]
)
Whenever you build you need to include headers for CGtk. Check Makefile how it is done and copy the makefile into your project so you can easily reference all your headers. In case you use other platform than Ubuntu 15.10 or Mac OS X with homebrew you might need to change the paths.
Following code will create a window with a button that when it is pressed presents another window.
import SwiftGtk
let app = Application(applicationId: "com.example.application")
app.run { window in
window.title = "Hello World"
window.defaultSize = Size(width: 400, height: 400)
window.resizable = true
let button = Button(label: "Press Me")
button.clicked = { _ in
let newWindow = Window(windowType: .topLevel)
newWindow.title = "Just a window"
newWindow.defaultSize = Size(width: 200, height: 200)
let labelPressed = Label(text: "Oh, you pressed the button.")
newWindow.add(labelPressed)
newWindow.showAll()
}
window.add(button)
}
All code is licensed under MIT license.