setLayoutMode 接口快速切换,无需手动计算位置。宫格布局 | 元素布局 | 纵向布局 | 自定义布局 |
![]() | ![]() |
![]() |
![]() |
public func setLayoutMode(layoutMode: SGLayoutMode, layoutConfig: SGSeatViewLayoutConfig? = nil)
参数 | 描述 |
layoutMode | 布局模式: GRID(宫格布局):适用于多人语聊场景,所有麦位均匀分布。 FOCUS(元素布局):适用于有主麦位的场景,突出显示主麦位。 VERTICAL(纵向布局):适用于竖屏场景,麦位垂直排列。 FREE(自定义布局):适用于需要完全自定义布局的场景 。 |
layoutConfig | 自定义的行列布局信息,仅当 layoutMode 为 FREE 时需传入此参数。 |
// 设置宫格布局seatGridView.setLayoutMode(layoutMode: .grid)// 设置元素布局seatGridView.setLayoutMode(layoutMode: .focus)// 设置纵向布局seatGridView.setLayoutMode(layoutMode: .vertical)// 设置自定义布局// 第一行配置let rowConfig1 = SGSeatViewLayoutRowConfig(count: 3, // 第一行显示的数量seatSpacing: 10, // 第一行每个麦位的水平间距seatSize: CGSize(width: 50, height: 50), // 第一行显示的每个麦位视图大小alignment: .center) // 第一行麦位的对齐方式// 第二行配置let rowConfig2 = SGSeatViewLayoutRowConfig(count: 3, // 第二行显示的数量seatSpacing: 10, // 第二行每个麦位的水平间距seatSize: CGSize(width: 50, height: 50), // 第二行显示的每个麦位视图大小alignment: .spaceAround) // 第二行麦位的对齐方式let layoutConfig = SGSeatViewLayoutConfig(rowConfigs: [rowConfig1, rowConfig2],rowSpacing: 10)seatGridView.setLayoutMode(layoutMode: .free, layoutConfig: layoutConfig)

Adapter/Delegate )来完全托管麦位的渲染逻辑。默认麦位视图 | 自定义麦位视图示例 |
![]() |
![]() |
@objc public protocol SGSeatViewDelegate {func seatGridView(_ view: SeatGridView, createSeatView seatInfo: TUISeatInfo) -> UIView?func seatGridView(_ view: SeatGridView, updateSeatView seatInfo: TUISeatInfo, seatView: UIView)func seatGridView(_ view: SeatGridView, updateUserVolume volume: Int, seatView: UIView)}public func setSeatViewDelegate(_ delegate: SGSeatViewDelegate)
参数 | 描述 |
view | 当前语聊麦位组件。 |
seatInfo | 当前麦位信息。 |
volume | 当前麦上用户音量。 |
seatView | 您自定义的麦位 view 。 |
delegate | 自定义麦位 delegate 。 |
class TestSeatViewDelegate: SGSeatViewDelegate {func seatGridView(_ view: SeatGridView, createSeatView seatInfo: TUISeatInfo) -> UIView? {return TestSeatInfoView(seatGridView: view, seatInfo: seatInfo)}func seatGridView(_ view: SeatGridView, updateSeatView seatInfo: TUISeatInfo, seatView: UIView) {if let seatView = seatView as? TestSeatInfoView {seatView.updateSeatView(seatGridView: view, seatInfo: seatInfo)}}func seatGridView(_ view: SeatGridView, updateUserVolume volume: Int, seatView: UIView) {if let seatView = seatView as? TestSeatInfoView {seatView.updateUserVolume(seatGridView: view, volume: volume)}}}seatGridView.setSeatViewDelegate(TestSeatViewDelegate())class TestSeatInfoView: UIView {init(seatGridView: SeatGridView, seatInfo: TUISeatInfo) {super.init(frame: .zero)initView() // 初始化view}func updateSeatView(seatGridView: SeatGridView, seatInfo: TUISeatInfo) {updateView(seatInfo) // 更新自定义麦位视图UI}func updateUserVolume(seatGridView: SeatGridView, volume: Int) {updateUserVolume(volume) // 更新音量变化UI}}
View 内部设置点击监听,在回调中处理业务逻辑。SeatGridView 内部维护了数据状态,setLayoutMode 仅改变视觉排布,不会影响用户的上麦状态。SeatGridView 内部已实现了麦位注册监听,当任何麦位状态变化时,会自动回调 updateSeatView 方法。您只需在该方法中更新 UI 即可。文档反馈