View in English

  • Apple 开发者
    • 入门汇总

    探索“入门汇总”

    • 概览
    • 学习
    • Apple Developer Program

    及时了解最新动态

    • 最新动态
    • 开发者你好
    • 平台

    探索“平台”

    • Apple 平台
    • iOS
    • iPadOS
    • macOS
    • Apple tvOS
    • visionOS
    • watchOS
    • App Store

    精选

    • 设计
    • 分发
    • 游戏
    • 配件
    • 网页
    • Home
    • CarPlay 车载
    • 技术

    探索“技术”

    • 概览
    • Xcode
    • Swift
    • SwiftUI

    精选

    • 辅助功能
    • App Intents
    • Apple 智能
    • 游戏
    • 机器学习与 AI
    • 安全性
    • Xcode Cloud
    • 社区

    探索“社区”

    • 概览
    • “与 Apple 会面交流”活动
    • 社区主导的活动
    • 开发者论坛
    • 开源

    精选

    • WWDC
    • Swift Student Challenge
    • 开发者故事
    • App Store 大奖
    • Apple 设计大奖
    • Apple Developer Centers
    • 文档

    探索“文档”

    • 文档库
    • 技术概述
    • 示例代码
    • 《人机界面指南》
    • 视频

    发布说明

    • 精选更新
    • iOS
    • iPadOS
    • macOS
    • watchOS
    • visionOS
    • Apple tvOS
    • Xcode
    • 下载

    探索“下载”

    • 所有下载
    • 操作系统
    • 应用程序
    • 设计资源

    精选

    • Xcode
    • TestFlight
    • 字体
    • SF Symbols
    • Icon Composer
    • 支持

    探索“支持”

    • 概览
    • 帮助指南
    • 开发者论坛
    • “反馈助理”
    • 联系我们

    精选

    • 《开发者账户帮助》
    • 《App 审核指南》
    • 《App Store Connect 帮助》
    • 即将实行的要求
    • 协议和准则
    • 系统状态
  • 快速链接

    • 活动
    • 新闻
    • 论坛
    • 示例代码
    • 视频
 

视频

打开菜单 关闭菜单
  • 专题
  • 所有视频
  • 关于

更多视频

  • 简介
  • 概要
  • 代码
  • 了解 Music Understanding 框架

    探索 Music Understanding 这个新框架,让你的 App 能在设备端从六个维度分析音频:调性、节奏、结构、速度、乐器活动和响度。你还将利用“Music Understanding Lab”示例 App 直观地查看各个结果。

    章节

    • 0:00 - Introduction
    • 1:39 - Musical features
    • 3:19 - Framework integration
    • 3:55 - Music Understanding Lab

    资源

    • Creating visuals with Music Understanding analysis results
    • MusicUnderstanding
      • 高清视频
      • 标清视频
  • 搜索此视频…
    • 4:47 - Initialize the session

      import MusicUnderstanding
      
      .fileImporter(isPresented: $isPresented, allowedContentTypes: [.audio]) { result in
          switch result {
          case .success(let url):
              let asset = AVURLAsset(url: url, 
                                     options: [AVURLAssetPreferPreciseDurationAndTimingKey : true])
              let session = try await MusicUnderstandingSession(asset: asset)
              let results = try await session.analyze()
          }
      }
    • 5:24 - Inside SessionResult

      import MusicUnderstanding
      
      public struct SessionResult: Codable, Sendable {
          public let instrumentActivity: InstrumentActivityResult?
          public let key: KeyResult?
          public let loudness: LoudnessResult?
          public let pace: PaceResult?
          public let rhythm: RhythmResult?
          public let structure: StructureResult?
      }
    • 5:53 - TimedValue

      import MusicUnderstanding
      
      public struct TimedValue<Value>: Codable, Equatable, Sendable
      where Value: Codable & Equatable & Sendable {
          public let time: CMTime
          public let value: Value
      }
    • 5:58 - RangedValue

      import MusicUnderstanding
      
      public struct RangedValue<Value>: Codable, Equatable, Sendable
      where Value: Codable & Equatable & Sendable {
          public let range: CMTimeRange
          public let value: Value
      }
    • 6:27 - Key analysis

      public struct KeyResult: Codable, Sendable {
          public let ranges: [MusicUnderstandingSession.RangedValue<KeySignature]
      }
    • 6:43 - KeySignature

      public struct KeySignature: Codable, Hashable, Sendable {
          public let tonic: Tonic
          public let mode: Mode
      }
    • 6:48 - Using tonic

      @frozen public enum Tonic: String, Codable, Hashable, Sendable {
          case aFlat, aSharp, a, bFlat, b, c, cSharp, d, dFlat, dSharp, eFlat, e, f, fSharp, g, gFlat, gSharp
      }
    • 6:59 - Using mode

      public enum Mode: String, Codable, Hashable, Sendable {
          case major, minor
      }
    • 7:16 - Rhythm analysis

      import MusicUnderstanding
      
      public struct RhythmResult: Codable, Sendable {
          public let beats: [CMTime]
          public let bars: [CMTime]
          public let beatsPerMinute: Float?
      }
    • 8:42 - StructureResult

      import MusicUnderstanding
      
      public struct StructureResult: Codable, Sendable {
          public let sections: [CMTimeRange]
          public let segments: [CMTimeRange]
          public let phrases: [CMTimeRange]
      }
    • 9:26 - Analyzing pace

      import MusicUnderstanding
      
      public struct PaceResult: Codable, Sendable {
          public let ranges: [MusicUnderstandingSession.RangedValue<Double>]
      }
    • 10:13 - InstrumentActivityResult

      import MusicUnderstanding
      
      public struct InstrumentActivityResult: Codable, Sendable {
          public let ranges: [Instrument: [CMTimeRange]]
          public let activity: [Instrument: [MusicUnderstandingSession.TimedValue<Float>]]
      }
    • 11:45 - LoudnessResult

      import MusicUnderstanding
      
      public struct LoudnessResult: Codable, Sendable {
          public let integrated: MusicUnderstandingSession.TimedValue<Float>
          public let momentary: [MusicUnderstandingSession.TimedValue<Float>]
          public let shortTerm: [MusicUnderstandingSession.TimedValue<Float>]
          public let peak: MusicUnderstandingSession.TimedValue<Float>
      }
    • 12:48 - Streaming API for loudness

      import MusicUnderstanding
      
      public var loudnessResults: some AsyncSequence<LoudnessResult, any Error> & Sendable
    • 12:55 - Streaming API for loudness

      import MusicUnderstanding
      
      let audioProvider = AudioProvider()
      let session = MusicUnderstandingSession(audioProvider: audioProvider)
      await withThrowingTaskGroup(of: Void.self) { taskGroup in
          group.addTask {
              for try await result in await session.loudnessResults {
                  updateAudioLevel(result.momentary.value)
              }
          }
      
          group.addTask {
              try await session.analyze(for: [.loudness])
          }
      }
    • 13:19 - Audio Provider

      import MusicUnderstanding
      
      struct AudioProvider: AsyncSequence, AsyncIteratorProtocol {
         func makeAsyncIterator() -> Self {
              return self
          }
      
         mutating func next() async -> AVReadOnlyAudioPCMBuffer? {
              // Return the next audio buffer, or nil to signal completion
          }
      }
    • 13:55 - Encode to JSON

      import MusicUnderstanding
      
      let session = try await MusicUnderstandingSession(asset: asset)
      let results = try await session.analyze()
      
      let encoder = JSONEncoder()
      try encoder.encode(results)
    • 14:47 - Suggestion for using pace

      let timePerClip = 60 / paceValue
    • 0:00 - Introduction
    • Discover how the Music Understanding framework brings on-device offline audio analysis to all Apple platforms.

    • 1:39 - Musical features
    • Explore the six areas of the framework's music analysis: key, rhythm, structure, pace, instrument activity, and loudness.

    • 3:19 - Framework integration
    • Learn how to initialize a MusicUnderstandingSession and begin analysis with an AVAsset or custom audio provider.

    • 3:55 - Music Understanding Lab
    • Walk through a sample app that visualizes all analysis types from the framework.

Developer Footer

  • 视频
  • WWDC26
  • 了解 Music Understanding 框架
  • 打开菜单 关闭菜单
    • iOS
    • iPadOS
    • macOS
    • Apple tvOS
    • visionOS
    • watchOS
    打开菜单 关闭菜单
    • Swift
    • SwiftUI
    • Swift Playground
    • TestFlight
    • Xcode
    • Xcode Cloud
    • SF Symbols
    打开菜单 关闭菜单
    • 辅助功能
    • 配件
    • Apple 智能
    • App 扩展
    • App Store
    • 音频与视频 (英文)
    • 增强现实
    • 设计
    • 分发
    • 教育
    • 字体 (英文)
    • 游戏
    • 健康与健身
    • App 内购买项目
    • 本地化
    • 地图与位置
    • 机器学习与 AI
    • 开源资源 (英文)
    • 安全性
    • Safari 浏览器与网页 (英文)
    打开菜单 关闭菜单
    • 完整文档 (英文)
    • 部分主题文档 (简体中文)
    • 教程
    • 下载
    • 论坛 (英文)
    • 视频
    打开菜单 关闭菜单
    • 支持文档
    • 联系我们
    • 错误报告
    • 系统状态 (英文)
    打开菜单 关闭菜单
    • Apple 开发者
    • 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 Research Device Program (英文)
    打开菜单 关闭菜单
    • 与 Apple 会面交流
    • Apple Developer Center
    • App Store 大奖 (英文)
    • Apple 设计大奖
    • Apple Developer Academies (英文)
    • WWDC
    阅读最近新闻。
    获取 Apple Developer App。
    版权所有 © 2026 Apple Inc. 保留所有权利。
    使用条款 隐私政策 协议和准则