apple/SwiftUI, Combine

iOS 화면 캡쳐 및 녹화 감지 (feat. SwiftUI)

lgvv 2022. 6. 2. 16:22

iOS 화면 캡쳐 및 녹화 감지 (feat. SwiftUI)


DRM 기술 적용에 대해서 연구하면서 화면 녹화 감지에 대해서 서술하고자 함.

 

화면 캡쳐 및 감지하는 시스템 코드

// 화면캡쳐
NotificationCenter.default.publisher(for: UIScreen.capturedDidChangeNotification) 
// 화면녹화
NotificationCenter.default.publisher(for: UIApplication.userDidTakeScreenshotNotification)

 

코드 샘플

 

 

import SwiftUI

struct ContentView: View {
    var body: some View {
        
        ZStack {
            MainView() // 메인 컨텐트 뷰
            BlockView() // 블럭 뷰
        }
        
    }
}

// 얼럿창 데이터
struct AlertData: Identifiable {
    var id: UUID
    let title: String
    let message: String
    
    init(title: String = "안녕하세요!" , message : String = "스크린 캡쳐를 하셨군요! 🔦") {
        
        self.id = UUID()
        self.title = title
        self.message = message
    }
}

/// 블럭 처리 뷰
struct BlockView: View {
    
    // ios 시스템 에서는 시스템 이벤트를 알려준다. - 노티피케이션 센터
    // 노티피케이션 -> publisher 로 받을수 있다.
    // SwiftUI 에서는 publisher 이벤트를 onReceive 로 받는다.
    
    @State private var alertData: AlertData?
    
    // 녹화중 여부
    @State var isRecordingScreen = false
    
    var body: some View {
        ZStack {
            if isRecordingScreen {
                Color.white
                Text("화면 녹화중입니다! 🎥")
                    .font(.largeTitle)
                    .padding()
            }
        }
        .onReceive(NotificationCenter.default.publisher(for: UIScreen.capturedDidChangeNotification), perform: { _ in
            print("UIScreen.main.isCaptured : \(UIScreen.main.isCaptured)")
            isRecordingScreen = UIScreen.main.isCaptured
            print(isRecordingScreen ? "녹화 시작" : "녹화 중지")
        })
        .onReceive(NotificationCenter.default.publisher(for: UIApplication.userDidTakeScreenshotNotification), perform: { _ in
            
            print("스크린샷이 찍어졌다.")
            alertData = AlertData()
            
        })
        .edgesIgnoringSafeArea(.all)
        .alert(item: $alertData, content: { alertData in
            Alert(title: Text(alertData.title),
                  message: Text(alertData.message),
                  dismissButton: Alert.Button.cancel(Text("닫기")))
        })
    }
}



struct MainView: View {
    var body: some View {
        VStack {
            Text("안녕하세요\n개발하는 정대리 입니다! 🐶")
                .font(.largeTitle)
                .foregroundColor(.white)
                .padding()
        }
        .frame(minWidth: 0, maxWidth: .infinity,
                minHeight: 0, maxHeight: .infinity,
                alignment: .center)
        .background(Color.blue)
        .edgesIgnoringSafeArea(.all)
    }
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}

 

 

 

(참고)

https://green1229.tistory.com/176

 

SwiftUI - NotificationCenter

안녕하세요. 그린입니다🟢 이번 포스팅에서는 SwiftUI에서 NotificationCenter를 활용하는 방법에 대해 학습하겠습니다🧑🏻‍💻 UIKit에서는 잘 알겠는데 대체 SwiftUI에서는 어떻게 노피티케이션 센

green1229.tistory.com

 

'apple > SwiftUI, Combine' 카테고리의 다른 글

[SwiftUI] @StateObject  (0) 2022.06.02
[SwiftUI] State and Data Flow  (0) 2022.06.02
[SwiftUI] ViewModifier  (0) 2022.06.02
[SwiftUI] LazyVGrid  (0) 2022.05.25
SwiftUI menu (feat. Picker)  (0) 2022.05.25