Stripes
Beautiful background pattern views for SwiftUI.
Example Patterns
Diagonal Bars
data:image/s3,"s3://crabby-images/21639/2163901af494a53b8a1150ee71d83faa8dd29c54" alt="Stripes SwiftUI"
import SwiftUI
import Stripes
struct ContentView: View {
var body: some View {
ZStack {
Stripes(config: .default)
Text("Hello, world!")
.font(.system(size: 50))
.foregroundColor(.white)
.bold()
}
.background(Color.black)
.frame(maxWidth: .infinity, maxHeight: .infinity)
.edgesIgnoringSafeArea(.all)
}
}
Vertical Bars
data:image/s3,"s3://crabby-images/058ab/058ab5844ce296448b4fce10de8d383f26671d54" alt="Stripes SwiftUI"
import SwiftUI
import Stripes
struct ContentView: View {
var body: some View {
ZStack {
Stripes(config: StripesConfig(background: Color.green.opacity(0.6),
foreground: Color.white.opacity(0.3), degrees: 0,
barWidth: 50, barSpacing: 50))
Text("Hello, world!")
.font(.system(size: 50))
.foregroundColor(.white)
.bold()
}
.background(Color.black)
.frame(maxWidth: .infinity, maxHeight: .infinity)
.edgesIgnoringSafeArea(.all)
}
}
Overlapping Patterns
data:image/s3,"s3://crabby-images/1fd63/1fd639a442d12b15a40e089f3ec479c3503fabc0" alt="Stripes SwiftUI"
import SwiftUI
import Stripes
struct ContentView: View {
var body: some View {
ZStack {
Stripes(config: StripesConfig(background: Color.red.opacity(0.2),
foreground: Color.blue.opacity(0.6),
degrees: 45, barWidth: 50, barSpacing: 20))
Stripes(config: StripesConfig(background: Color.red.opacity(0.2),
foreground: Color.white.opacity(0.15),
degrees: -45, barWidth: 50, barSpacing: 20))
Text("Hello, world!")
.font(.system(size: 50))
.foregroundColor(.white)
.bold()
}
.background(Color.black)
.frame(maxWidth: .infinity, maxHeight: .infinity)
.edgesIgnoringSafeArea(.all)
}
}
Installation
Preferred: Add package to Xcode project
In Xcode, tap on File -> Swift Packages -> Add Package Dependency
Enter the package URL https://github.com/eneko/Stripes
data:image/s3,"s3://crabby-images/30754/307546bc318723c39dadde16ae8c188cf6a2d090" alt="Stripes Install"
Ensure the library is added to the list of Frameworks & Libraries
data:image/s3,"s3://crabby-images/66585/6658581e0f9850560b238da2b624894290841473" alt="Stripes Install"
Avoid dependencies, copy the code
public struct StripesConfig {
var background: Color
var foreground: Color
var degrees: Double
var barWidth: CGFloat
var barSpacing: CGFloat
public init(background: Color = Color.pink.opacity(0.5), foreground: Color = Color.pink.opacity(0.8),
degrees: Double = 30, barWidth: CGFloat = 20, barSpacing: CGFloat = 20) {
self.background = background
self.foreground = foreground
self.degrees = degrees
self.barWidth = barWidth
self.barSpacing = barSpacing
}
public static let `default` = StripesConfig()
}
public struct Stripes: View {
var config: StripesConfig
public init(config: StripesConfig) {
self.config = config
}
public var body: some View {
GeometryReader { geometry in
let longSide = max(geometry.size.width, geometry.size.height)
let itemWidth = config.barWidth + config.barSpacing
let items = Int(2 * longSide / itemWidth)
HStack(spacing: config.barSpacing) {
ForEach(0..<items, id: \.self) { index in
config.foreground
.frame(width: config.barWidth, height: 2 * longSide)
}
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
.rotationEffect(Angle(degrees: config.degrees), anchor: .center)
.offset(x: -longSide / 2, y: -longSide / 2)
.background(config.background)
}
.clipped()
}
}
Stripes
Beautiful background pattern views for SwiftUI.
Example Patterns
Diagonal Bars
Vertical Bars
Overlapping Patterns
Installation
Preferred: Add package to Xcode project
In Xcode, tap on
File -> Swift Packages -> Add Package Dependency
Enter the package URL
https://github.com/eneko/Stripes
Ensure the library is added to the list of Frameworks & Libraries
Avoid dependencies, copy the code