Files
letro-ios/ElementX/Sources/Other/EffectsScene/EffectsView.swift
manuroe c29f4cc9b4 Dual licensing: AGPL + Element Commercial (#3657)
* New LICENSE-COMMERCIAL file

* Apply dual licenses: AGPL + Element Commercial to file headers

* Update README with dual licensing
2025-01-06 11:27:37 +01:00

50 lines
1.3 KiB
Swift

//
// Copyright 2022-2024 New Vector Ltd.
//
// SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Element-Commercial
// Please see LICENSE files in the repository root for full details.
//
import SceneKit
import SwiftUI
/// A SwiftUI wrapper around `SCNView`, that unlike `SceneView` allows the
/// scene to have a transparent background and be rendered on top of other views.
struct EffectsView: UIViewRepresentable {
enum Effect {
/// A confetti drop effect from the top centre of the screen.
case confetti
/// No effect will be shown.
case none
}
/// The type of effects to be shown in the view.
var effect: Effect
func makeUIView(context: Context) -> SCNView {
SCNView(frame: .zero)
}
func updateUIView(_ sceneView: SCNView, context: Context) {
sceneView.scene = makeScene()
sceneView.backgroundColor = .clear
}
// MARK: - Private
private func makeScene() -> EffectsScene? {
switch effect {
case .confetti:
return EffectsScene.confetti()
case .none:
return nil
}
}
}
struct EffectsView_Previews: PreviewProvider {
static var previews: some View {
EffectsView(effect: .confetti)
}
}