View in English

  • Apple Developer
    • 시작하기

    시작하기 탐색

    • 개요
    • 알아보기
    • Apple Developer Program

    알림 받기

    • 최신 뉴스
    • Hello Developer
    • 플랫폼

    플랫폼 탐색

    • Apple 플랫폼
    • iOS
    • iPadOS
    • macOS
    • tvOS
    • visionOS
    • watchOS
    • App Store

    피처링

    • 디자인
    • 배포
    • 게임
    • 액세서리
    • 웹
    • 홈
    • CarPlay
    • 기술

    기술 탐색

    • 개요
    • Xcode
    • Swift
    • SwiftUI

    피처링

    • 손쉬운 사용
    • 앱 인텐트
    • Apple Intelligence
    • 게임
    • 머신 러닝 및 AI
    • 보안
    • Xcode Cloud
    • 커뮤니티

    커뮤니티 탐색

    • 개요
    • Apple과의 만남 이벤트
    • 커뮤니티 주도 이벤트
    • 개발자 포럼
    • 오픈 소스

    피처링

    • WWDC
    • Swift Student Challenge
    • 개발자 이야기
    • App Store 어워드
    • Apple 디자인 어워드
    • 문서

    문서 탐색

    • 문서 라이브러리
    • 기술 개요
    • 샘플 코드
    • 휴먼 인터페이스 가이드라인
    • 비디오

    릴리즈 노트

    • 피처링 업데이트
    • iOS
    • iPadOS
    • macOS
    • watchOS
    • visionOS
    • tvOS
    • Xcode
    • 다운로드

    다운로드 탐색

    • 모든 다운로드
    • 운영 체제
    • 애플리케이션
    • 디자인 리소스

    피처링

    • Xcode
    • TestFlight
    • 서체
    • SF Symbols
    • Icon Composer
    • 지원

    지원 탐색

    • 개요
    • 도움말
    • 개발자 포럼
    • 피드백 지원
    • 문의하기

    피처링

    • 계정 도움말
    • 앱 심사 지침
    • App Store Connect 도움말
    • 새로 추가될 요구 사항
    • 계약 및 지침
    • 시스템 상태
  • 빠른 링크

    • 이벤트
    • 뉴스
    • 포럼
    • 샘플 코드
    • 비디오
 

비디오

메뉴 열기 메뉴 닫기
  • 컬렉션
  • 전체 비디오
  • 소개

더 많은 비디오

  • 소개
  • 요약
  • 코드
  • Xcode로 Reality Composer Pro 3 기능 확장하기

    Reality Composer Pro 3로 어떻게 더 크고 야심 찬 공간 프로젝트를 빌드할 수 있는지 확인해 보세요. 맞춤형 구성요소를 편집할 수 있는 프로젝트별 플러그인을 생성하고, 맞춤형 시스템을 실행하며, 고유한 ScriptGraph 노드를 빌드하여 공간 제작 워크플로를 완벽하게 제어하는 방법을 알아보세요.

    챕터

    • 0:00 - Introduction
    • 2:00 - Extending the editor
    • 4:51 - Custom components and systems
    • 10:32 - Controlling the water surface
    • 13:19 - Custom animation actions
    • 17:12 - Custom Script Graph nodes
    • 21:16 - Next steps

    리소스

      • HD 비디오
      • SD 비디오

    관련 비디오

    WWDC26

    • Reality Composer Pro 3로 공간 워크플로 강화하기
    • Reality Composer Pro 3로 더 빠르게 공간 장면 반복하기
    • Reality Composer Pro 3로 코드 없는 게임을 디자인하기
    • RealityKit의 개선 사항 살펴보기
  • 비디오 검색…
    • 6:08 - Cauldron component

      // Add a component to represent the water level
      
      import RealityKit
      
      public struct Cauldron: Component, Codable {
          public var waterLevel: Float
      
          enum CodingKeys: CodingKey {
              case waterLevel
          }
      }
    • 6:42 - CauldronSystem

      // Add a system to control the water level
      
      import RealityKit
      
      public struct CauldronSystem: System {
          let query = EntityComponentQuery(Cauldron.self)
          public init(scene: Scene) {}
      
          public func update(context: SceneUpdateContext) {
              for (entity, cauldron) in context.entities(matching: query) {
                  guard let water = entity.findEntity(named: "Cauldron_Water_mesh")
                      else { continue }
                  water.setPosition(SIMD3<Float>(0, 1, 0) * cauldron.waterLevel, relativeTo: entity)
              }
          }
      }
    • 7:00 - RCPCustomComponentsPlugin

      // Make sure that Reality Composer Pro 3 knows about the Cauldron and CauldronSystem
      
      import RealityComposerPro
      
      final class RCPCustomComponentsPlugin: RealityComposerProPlugin {
          public func setup(context: any RealityComposerProContext) {
              context.registerComponent(Cauldron.self)
              context.registerSystem(CauldronSystem.self)
          }
      }
      
      @_cdecl("createRealityComposerProPlugin")
      public func createRealityComposerProPlugin() -> UnsafeMutableRawPointer {
          return RCPCustomComponentsPlugin().passRetained()
      }
    • 10:49 - Cauldron component with vortex properties

      // Properties to control water surface
      
      import RealityKit
      
      public struct Cauldron: Component, Codable {
          public var waterLevel: Float
          public var rotationSpeed: Float
          public var minWaterLevel: Float
          public var maxWaterLevel: Float
          public var vortexCoeff: Float
      }
    • 11:05 - CauldronSystem update with ShaderGraph

      public func update(context: SceneUpdateContext) {
          for (entity, cauldron) in context.entities(matching: query) {
              guard let water = entity.findEntity(named: "Cauldron_Water_mesh") else { continue }
              water.setPosition(SIMD3<Float>(0, 1, 0) * cauldron.waterLevel, relativeTo: entity)
      
              guard var model = water.components[ModelComponent.self] else { continue }
              guard var mat = model.materials.first as? ShaderGraphMaterial else { continue }
              let surface = computeSurface(cauldron: cauldron)
              try? mat.setParameter(name: "Level Radius", value: .float(surface.levelRadius))
              try? mat.setParameter(name: "Lowest Point",
                  value: .float(cauldron.waterLevel - surface.lowestPoint))
              try? mat.setParameter(name: "Height Change", value: .float(surface.heightChange))
              try? mat.setParameter(name: "Level Coeff", value: .float(surface.levelCoeff))
              try? mat.setParameter(name: "Is Level", value: .bool(surface.isLevel))
              model.materials[0] = mat
              water.components.set(model)
          }
      }
    • 13:25 - SetWaterLevelAction

      // Custom action for setting the water level of the Cauldron
      
      import RealityKit
      
      public struct SetWaterLevelAction: EntityAction, Codable {
          // Parameters for the action
          public let startWaterLevel: Float
          public let endWaterLevel: Float
      
          // Required by EntityAction protocol
          public var animatedValueType: (any AnimatableData.Type)? { Transform.self }
      }
    • 14:05 - SetWaterLevelAction subscribe

      extension SetWaterLevelAction {
          static func subscribe() {
              Task { @MainActor in
                  SetWaterLevelAction.subscribe(to: .updated) { event in
                      let normalizedTime = (event.playbackController.time - event.startTime) /
                          event.duration
                      let action = event.action
                      let currentLevel = action.startWaterLevel +
                          Float(normalizedTime) * (action.endWaterLevel - action.startWaterLevel)
                      guard let entity = event.targetEntity else { return }
                      guard var cauldron = entity.components[Cauldron.self] else { return }
                      cauldron.waterLevel = currentLevel
                      entity.components.set(cauldron)
                  }
              }
          }
      }
    • 14:56 - RCPCustomComponentsPlugin with action

      // Make sure that Reality Composer Pro 3 knows about the SetWaterLevelAction
      
      import RealityComposerPro
      
      final class RCPCustomComponentsPlugin: RealityComposerProPlugin {
          public func setup(context: any RealityComposerProContext) {
              context.registerComponent(Cauldron.self)
              context.registerSystem(CauldronSystem.self)
      
              context.registerAction(SetWaterLevelAction.self)
              SetWaterLevelAction.subscribe()
          }
      }
      
      @_cdecl("createRealityComposerProPlugin")
      public func createRealityComposerProPlugin() -> UnsafeMutableRawPointer {
          return RCPCustomComponentsPlugin().passRetained()
      }
    • 17:32 - Cauldron with @Scriptable macro

      // Expose Cauldron to Script Graphs
      
      import RealityKit
      import RealityKitScripting
      import RealityKitScriptingMacros
      
      @Scriptable
      public struct Cauldron: Component, Codable {
          public var waterLevel: Float
          public var rotationSpeed: Float
          public var minWaterLevel: Float
          public var maxWaterLevel: Float
          public var vortexCoeff: Float
      }
    • 18:08 - Register scripting module

      // Register scripting module
      
      public func setup(context: any RealityComposerProContext) {
          context.registerComponent(Cauldron.self)
          context.registerSystem(CauldronSystem.self)
      
          context.registerAction(SetWaterLevelAction.self)
          SetWaterLevelAction.subscribe()
      
          Task { @MainActor in
              let config = RKS.Configuration(id: "ChaparralVillage")
                  .onInitialize { _ in
                  [
                      Module("ChaparralVillage") {
                          Cauldron.SchemaProvider.schema
                      }
                  ]
              }
              try! RKS.addConfiguration(config)
          }
      }
    • 0:00 - Introduction
    • An overview of the Reality Composer Pro 3 plugin system, showing how Xcode and the editor share a project to let engineers and artists collaborate — with custom components, systems, animation actions, and Script Graph nodes all running live inside the editor.

    • 2:00 - Extending the editor
    • Learn how the Reality Composer Pro 3 plugin system works: how the editor and Xcode share a single git repository, how custom Swift code is compiled into a dynamic library, and how the editor loads and trusts plugins at runtime.

    • 4:51 - Custom components and systems
    • Build a Cauldron component and CauldronSystem using RealityKit, expose them to the editor via a RealityComposerProPlugin, and see the water level property update in real time as artists adjust values in the inspector.

    • 10:32 - Controlling the water surface
    • Extend the Cauldron component with vortex shader properties and update the system to drive a ShaderGraphMaterial at runtime, enabling artists to control vortex depth and rotation speed directly from the Reality Composer Pro 3 inspector.

    • 13:19 - Custom animation actions
    • Implement the EntityAction protocol to create a SetWaterLevelAction that animates the cauldron water level on the sequencer timeline, subscribe to animation update events to interpolate the level, and register the action with the editor plugin.

    • 17:12 - Custom Script Graph nodes
    • Use the @Scriptable macro to expose a custom component to Reality Composer Pro 3 Script Graphs, register a scripting module in the plugin setup, and see the generated nodes appear in the Script Graph editor for no-code artist workflows.

    • 21:16 - Next steps
    • Recap of the plugin capabilities covered — custom components, systems, animation actions, and Script Graph nodes — with recommendations to explore the Explore Advances in RealityKit and Supercharge Your Spatial Workflows sessions.

Developer Footer

  • 비디오
  • WWDC26
  • Xcode로 Reality Composer Pro 3 기능 확장하기
  • 메뉴 열기 메뉴 닫기
    • iOS
    • iPadOS
    • macOS
    • tvOS
    • visionOS
    • watchOS
    메뉴 열기 메뉴 닫기
    • Swift
    • SwiftUI
    • Swift Playground
    • TestFlight
    • Xcode
    • Xcode Cloud
    • SF Symbols
    메뉴 열기 메뉴 닫기
    • 손쉬운 사용
    • 액세서리
    • Apple Intelligence
    • 앱 확장 프로그램
    • App Store
    • 오디오 및 비디오(영문)
    • 증강 현실
    • 디자인
    • 배포
    • 교육
    • 서체(영문)
    • 게임
    • 건강 및 피트니스
    • 앱 내 구입
    • 현지화
    • 지도 및 위치
    • 머신 러닝 및 AI
    • 오픈 소스(영문)
    • 보안
    • Safari 및 웹(영문)
    메뉴 열기 메뉴 닫기
    • 문서(영문)
    • 튜토리얼
    • 다운로드
    • 포럼(영문)
    • 비디오
    메뉴 열기 메뉴 닫기
    • 지원 문서
    • 문의하기
    • 버그 보고
    • 시스템 상태(영문)
    메뉴 열기 메뉴 닫기
    • Apple Developer
    • App Store Connect
    • 인증서, 식별자 및 프로파일(영문)
    • 피드백 지원
    메뉴 열기 메뉴 닫기
    • Apple Developer Program
    • Apple Developer Enterprise Program
    • App Store Small Business Program
    • MFi Program(영문)
    • Mini Apps Partner Program
    • News Partner Program(영문)
    • Video Partner Program(영문)
    • Security Bounty Program(영문)
    • Security Research Device Program(영문)
    메뉴 열기 메뉴 닫기
    • Apple과의 만남
    • Apple Developer Center
    • App Store 어워드(영문)
    • Apple 디자인 어워드
    • Apple Developer Academy(영문)
    • WWDC
    최신 뉴스 읽기.
    Apple Developer 앱 받기.
    Copyright © 2026 Apple Inc. 모든 권리 보유.
    약관 개인정보 처리방침 계약 및 지침