123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- /*
- * Copyright 2016 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
- #import <Foundation/Foundation.h>
- #import <WebRTC/RTCVideoCodecInfo.h>
- NS_ASSUME_NONNULL_BEGIN
- /**
- * Model class for user defined settings.
- *
- * Handles storing the settings and provides default values if setting is not
- * set. Also provides list of available options for different settings. Stores
- * for example video codec, video resolution and maximum bitrate.
- */
- @interface ARDSettingsModel : NSObject
- /**
- * Returns array of available capture resoultions.
- *
- * The capture resolutions are represented as strings in the following format
- * [width]x[height]
- */
- - (NSArray<NSString *> *)availableVideoResolutions;
- /**
- * Returns current video resolution string.
- * If no resolution is in store, default value of 640x480 is returned.
- * When defaulting to value, the default is saved in store for consistency reasons.
- */
- - (NSString *)currentVideoResolutionSettingFromStore;
- - (int)currentVideoResolutionWidthFromStore;
- - (int)currentVideoResolutionHeightFromStore;
- /**
- * Stores the provided video resolution string into the store.
- *
- * If the provided resolution is no part of the available video resolutions
- * the store operation will not be executed and NO will be returned.
- * @param resolution the string to be stored.
- * @return YES/NO depending on success.
- */
- - (BOOL)storeVideoResolutionSetting:(NSString *)resolution;
- /**
- * Returns array of available video codecs.
- */
- - (NSArray<RTC_OBJC_TYPE(RTCVideoCodecInfo) *> *)availableVideoCodecs;
- /**
- * Returns current video codec setting from store if present or default (H264) otherwise.
- */
- - (RTC_OBJC_TYPE(RTCVideoCodecInfo) *)currentVideoCodecSettingFromStore;
- /**
- * Stores the provided video codec setting into the store.
- *
- * If the provided video codec is not part of the available video codecs
- * the store operation will not be executed and NO will be returned.
- * @param video codec settings the string to be stored.
- * @return YES/NO depending on success.
- */
- - (BOOL)storeVideoCodecSetting:(RTC_OBJC_TYPE(RTCVideoCodecInfo) *)videoCodec;
- /**
- * Returns current max bitrate setting from store if present.
- */
- - (nullable NSNumber *)currentMaxBitrateSettingFromStore;
- /**
- * Stores the provided bitrate value into the store.
- *
- * @param bitrate NSNumber representation of the max bitrate value.
- */
- - (void)storeMaxBitrateSetting:(nullable NSNumber *)bitrate;
- /**
- * Returns current audio only setting from store if present or default (NO) otherwise.
- */
- - (BOOL)currentAudioOnlySettingFromStore;
- /**
- * Stores the provided audio only setting into the store.
- *
- * @param setting the boolean value to be stored.
- */
- - (void)storeAudioOnlySetting:(BOOL)audioOnly;
- /**
- * Returns current create AecDump setting from store if present or default (NO) otherwise.
- */
- - (BOOL)currentCreateAecDumpSettingFromStore;
- /**
- * Stores the provided create AecDump setting into the store.
- *
- * @param setting the boolean value to be stored.
- */
- - (void)storeCreateAecDumpSetting:(BOOL)createAecDump;
- /**
- * Returns current setting whether to use manual audio config from store if present or default (YES)
- * otherwise.
- */
- - (BOOL)currentUseManualAudioConfigSettingFromStore;
- /**
- * Stores the provided use manual audio config setting into the store.
- *
- * @param setting the boolean value to be stored.
- */
- - (void)storeUseManualAudioConfigSetting:(BOOL)useManualAudioConfig;
- @end
- NS_ASSUME_NONNULL_END
|