Recently, SwiftUI has been receiving significant attention as Apple’s user interface toolkit in mobile application development. SwiftUI allows developers to construct UI using declarative syntax, bringing a significant change in how code is written. This article will detail how to develop a sketch app using SwiftUI and add features that allow users to change colors and thickness.
1. What is SwiftUI?
SwiftUI is a declarative UI framework that can be used across all of Apple’s platforms. With SwiftUI, UI can be developed more easily and intuitively, and reusable, modular components can be created. SwiftUI serves as an alternative to UIKit, enhancing code readability and facilitating maintenance through a transition from existing UIKit.
2. Overview of the Sketch App
A sketch app is an application that allows users to draw by hand, helping both artists and general users express their creativity through various features. It primarily provides the ability to draw lines on the screen through touch input, but offering additional options (such as a color picker and line thickness adjustments) enhances the app’s utility.
3. Project Setup
To set up a SwiftUI project, we will use Xcode to create a new iOS project. Here, we will select the ‘Single View App’ template and configure it to use SwiftUI.
- Open Xcode and select ‘Create a new Xcode project’.
- Select ‘Single View App’ and click ‘Next’.
- Enter the product name and set ‘Interface’ to ‘SwiftUI’.
- Create the project.
4. Building the UI
In SwiftUI, you can compose the user interface by combining various views. To implement basic sketch functionality, we will use GeometryReader to recognize touch events and add drawing code.
        struct ContentView: View {
            // Drawing state
            @State private var lines: [Line] = []
            @State private var currentColor: Color = .black
            @State private var currentLineWidth: CGFloat = 5.0
            
            var body: some View {
                VStack {
                    ZStack {
                        // Drawing area
                        DrawingView(lines: $lines)
                            .background(Color.white)
                            .border(Color.gray, width: 1)
                        
                        VStack {
                            Spacer()
                            ColorPicker("Select Color", selection: $currentColor)
                                .padding()
                            Slider(value: $currentLineWidth, in: 1...20, step: 1) {
                                Text("Line Width")
                            }.padding()
                        }
                    }
                }
                .onAppear {
                    // Initial settings
                }
            }
        }
    5. Handling Touch Events and Adding Drawing Functionality
The DrawingView will implement the functionality to draw actual lines. This view needs to detect touch events and store the lines drawn by the user.
        struct DrawingView: View {
            @Binding var lines: [Line]
            @State private var currentLine: Line?
            
            var body: some View {
                GeometryReader { geometry in
                    Path { path in
                        for line in lines {
                            path.addLines(line.points)
                        }
                        if let currentLine = currentLine {
                            path.addLines(currentLine.points)
                        }
                    }
                    .stroke(Color.black, lineWidth: 1.0)
                    .background(Color.white)
                    .gesture(DragGesture()
                        .onChanged { value in
                            let newPoint = value.location
                            if currentLine == nil {
                                currentLine = Line(points: [newPoint])
                            } else {
                                currentLine?.points.append(newPoint)
                            }
                        }
                        .onEnded { _ in
                            if let currentLine = currentLine {
                                lines.append(currentLine)
                            }
                            self.currentLine = nil
                        })
                }
            }
        }
    6. Implementing Color and Thickness Change Functionality
It is necessary to modify the drawing functionality to reflect the color and line thickness selected by the user.
        struct Line {
            var points: [CGPoint]
            var color: Color = .black
            var lineWidth: CGFloat = 5.0
            
            init(points: [CGPoint]) {
                self.points = points
            }
        }
        
        // Adjust Stroke color and thickness used in DrawingView
        .stroke(currentColor, lineWidth: currentLineWidth)
    7. Final Testing and Debugging
Once app development is complete, run the app on a real device or simulator to verify that all features are functioning correctly. Here, you need to test that lines are drawn correctly and that colors and thickness can be adjusted properly. If any bugs occur, use Xcode’s debugging tools to resolve the issues.
8. Conclusion
We looked at the process of developing a sketch app using SwiftUI and adding color and thickness adjustment features. SwiftUI allows for intuitive and declarative UI composition, enhancing development efficiency. Addressing various issues that may arise during app creation and ultimately completing the desired functionality constitutes an essential experience in app development.
Going forward, actively utilize the various features of SwiftUI and challenge yourself with more projects.