[FFmpeg-devel] [PATCH] avdevice/avfoundation: replace AVCaptureDevice with new api
Thilo Borgmann
thilo.borgmann at mail.de
Tue Dec 5 16:21:47 EET 2023
Am 05.12.23 um 15:19 schrieb Thilo Borgmann via ffmpeg-devel:
> Am 05.12.23 um 15:16 schrieb Thilo Borgmann via ffmpeg-devel:
>> Hi,
>>
>> Am 05.12.23 um 14:33 schrieb xufuji456 via ffmpeg-devel:
>>> Building with iOS platform, the compiler has a warning: "'devicesWithMediaType:' is deprecated: first deprecated in iOS 10.0 - Use AVCaptureDeviceDiscoverySession instead"
>>>
>>> Signed-off-by: xufuji456 <839789740 at qq.com>
>>> ---
>>> libavdevice/avfoundation.m | 25 ++++++++++++++++++++-----
>>> 1 file changed, 20 insertions(+), 5 deletions(-)
>>>
>>> diff --git a/libavdevice/avfoundation.m b/libavdevice/avfoundation.m
>>> index 36ad834753..1bc99d543a 100644
>>> --- a/libavdevice/avfoundation.m
>>> +++ b/libavdevice/avfoundation.m
>>> @@ -761,6 +761,21 @@ static int get_audio_config(AVFormatContext *s)
>>> return 0;
>>> }
>>> +static NSArray* getDevicesWithMediaType(AVMediaType mediaType) {
>>
>>
>>> +#if ((TARGET_OS_IPHONE && __IPHONE_OS_VERSION_MAX_ALLOWED >= 100000) || (TARGET_OS_OSX && __MAC_OS_X_VERSION_MAX_ALLOWED >= 101500))
>>> + if (@available(macOS 10.15, iOS 10.0, *)) {
>>
>> The preprocessor guard is meant to void the @available condition.
>>
>> Also something appears not yet to achieve what you want, as on MacOS 13.4 I still get the deprication warning:
>>
>> libavdevice/avfoundation.m:776:29: warning: 'devicesWithMediaType:' is deprecated: first deprecated in macOS 10.15 - Use AVCaptureDeviceDiscoverySession instead. [-Wdeprecated-declarations]
>> return [AVCaptureDevice devicesWithMediaType:mediaType];
>>
>>
>>
>>> + AVCaptureDeviceDiscoverySession *captureDeviceDiscoverySession =
>>> + [AVCaptureDeviceDiscoverySession
>>> + discoverySessionWithDeviceTypes:@[AVCaptureDeviceTypeBuiltInWideAngleCamera]
>>> + mediaType:mediaType
>>> + position:AVCaptureDevicePositionUnspecified];
>>> + return [captureDeviceDiscoverySession devices];
>>> + }
>>
>>> +#endif
>>
>> why not #else... #endif ?
>
> #elif
> ... of course.
#else
... writing faster than thinking is no good...
>
> Also using it, would remove the deprication warning on capable systems. Otherwise it is still in the code and warned about.
>
>
>>> + // fallback
>>> + return [AVCaptureDevice devicesWithMediaType:mediaType];
>>> +}
>>> +
-Thilo
More information about the ffmpeg-devel
mailing list