namespace SHH.CameraSdk; /// /// 视频分辨率档位描述符(Record 类型,不可变对象) /// 核心职责:定义相机通道在特定编码格式下支持的分辨率、帧率上限及友好描述 /// 协作场景: /// 1. 前端界面:展示清晰度选择下拉列表 /// 2. 配置校验:下发分辨率前判断是否符合硬件能力,防止超限黑屏 /// 3. 性能评估:通过总像素量计算编码/解码的计算负载与带宽压力 /// /// 画面像素宽度(如 1920、3840) /// 画面像素高度(如 1080、2160) /// 该分辨率下硬件支持的最大输出帧率(防止超限配置) /// 档位友好描述(如 "高清(1080P/H.265)") public record ResolutionProfile( int Width, int Height, int MaxFps, string Description ) { #region --- 计算属性 (Derived Properties) --- /// /// 当前档位的总像素量 /// 业务用途:衡量编码/解码的计算负载、网络传输的带宽压力 /// 计算公式:Width * Height /// public long TotalPixels => (long)Width * Height; /// /// 当前档位的屏幕宽高比 /// 业务用途:前端渲染容器(WinForm/WPF/Web)自动调整比例,避免画面拉伸变形 /// 保护逻辑:高度为 0 时返回 0,防止除零异常 /// public double AspectRatio => Height == 0 ? 0 : (double)Width / Height; /// /// 判断当前档位是否属于高清范畴(行业标准:720P 及以上,即 1280x720 分辨率) /// 业务用途:前端分类展示、带宽策略选择 /// public bool IsHighDefinition => Width >= 1280 && Height >= 720; #endregion #region --- 重写方法 (Overridden Methods) --- /// /// 格式化分辨率档位的显示文本 /// 输出格式:友好描述 (宽x高@最大帧率fps) /// 示例:高清(1080P/H.265) (1920x1080@30fps) /// /// 格式化的显示字符串 public override string ToString() => $"{Description} ({Width}x{Height}@{MaxFps}fps)"; #endregion }