mirror of
https://github.com/exyte/ActivityIndicatorView.git
synced 2026-04-07 19:17:39 +00:00
56 lines
1.5 KiB
Swift
56 lines
1.5 KiB
Swift
//
|
|
// DefaultIndicatorView.swift
|
|
// ActivityIndicatorView
|
|
//
|
|
// Created by Daniil Manin on 10/7/20.
|
|
// Copyright © 2020 Exyte. All rights reserved.
|
|
//
|
|
|
|
import SwiftUI
|
|
|
|
struct DefaultIndicatorView: View {
|
|
|
|
private let count: Int = 8
|
|
|
|
public var body: some View {
|
|
GeometryReader { geometry in
|
|
ForEach(0..<self.count) { index in
|
|
DefaultIndicatorItemView(index: index, count: self.count, size: geometry.size)
|
|
}.frame(width: geometry.size.width, height: geometry.size.height)
|
|
}
|
|
}
|
|
}
|
|
|
|
struct DefaultIndicatorItemView: View {
|
|
|
|
let index: Int
|
|
let count: Int
|
|
let size: CGSize
|
|
|
|
@State private var opacity: Double = 0
|
|
|
|
var body: some View {
|
|
let height = size.height / 3.2
|
|
let width = height / 2
|
|
let angle = 2 * .pi / CGFloat(count) * CGFloat(index)
|
|
let x = (size.width / 2 - height / 2) * cos(angle)
|
|
let y = (size.height / 2 - height / 2) * sin(angle)
|
|
|
|
let animation = Animation.default
|
|
.repeatForever(autoreverses: true)
|
|
.delay(Double(index) / Double(count) / 2)
|
|
|
|
return RoundedRectangle(cornerRadius: width / 2 + 1)
|
|
.frame(width: width, height: height)
|
|
.rotationEffect(Angle(radians: Double(angle + CGFloat.pi / 2)))
|
|
.offset(x: x, y: y)
|
|
.opacity(opacity)
|
|
.onAppear {
|
|
self.opacity = 1
|
|
withAnimation(animation) {
|
|
self.opacity = 0.3
|
|
}
|
|
}
|
|
}
|
|
}
|