[FFmpeg-devel] [PATCH] avdevice/avfoundation: replace AVCaptureDevice with new api

Thilo Borgmann thilo.borgmann at mail.de
Tue Dec 5 16:19:13 EET 2023


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.

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];
>> +}
>> +
> 
> Thanks,
> Thilo

-Thilo



More information about the ffmpeg-devel mailing list