zego_express_engine 3.14.5-private.158  zego_express_engine: ^3.14.5-private.158 copied to clipboard
zego_express_engine: ^3.14.5-private.158 copied to clipboard
ZegoExpressEngine Flutter SDK is a flutter plugin wrapper based on ZEGO Express RTC SDK (Native & Web), providing live video and real-time audio/video services.
Change Log #
3.14.5 #
New Features #
1. Support iOS 17.0 version
Note: Starting with this release, iOS 11.0 and earlier versions are no longer supported.
Starting from 2024-04-29, all apps on the App Store must support iOS 17.0 version. For details, please refer to Apple Developer Website Official Instructions.
2. Supports capturing video by using high frame rates of 60 fps
Note: Please contact ZEGOCLOUD technical support if you need to use this feature.
3. Added two new sound effects
ZegoVoiceChangerPreset added enumeration values for two voice-changing effects, Autobot and OutOfPower, to enrich the voice-changing effects.
For related API, please refer to [setVoiceChangerPreset]
4. ZegoMediaPlayer supports video mirroring
For related API, please refer to [enableViewMirror]
5. Supports initiating mixed-streaming tasks normally when image resource verification fails
ZegoMixerTask added new parameter mixImageCheckMode, used to control whether backgroundImageURL, inputList.imageInfo.url, or watermark.imageURL image resources fail to verify whether the mixing task can be initiated normally.
This function is not enabled by default (the default value of mixImageCheckMode is 0), which means that image verification is strictly performed, that is, the original restriction rules of parameters must be met before the mixed flow task can be initiated normally.
For related API, please refer to [startMixerTask]
6. Supports determining in advance whether the device can run the AI voice changing function
The AI voice changing function has certain requirements on the performance of the running device. You can use the [isAIVoiceChangerSupported] interface to determine in advance whether the device can support the AI voice changing function.
For related API, please refer to [isAIVoiceChangerSupported]
Enhancements #
1. Optimize the super-resolution function
Optimize the super-resolution effect and reduce the sharpness of the algorithm, thereby improving the subjective quality when the original picture has noise, there are faces in the picture, etc. For example, the flaws on the anchor’s face will not be highlighted, and the anchor’s hairline will not become more obvious.
Optimize the frame rate performance of the super-resolution algorithm on Qualcomm chips.
Bug Fixes #
- 
Fixed an issue where the release timing of undefined global variables caused the process to exit abnormally. 
- 
Fixed the issue where some models use AudioTrack to play audio, resulting in abnormal sound. 
- 
Fixed the problem of using the AI voice changing function to occasionally cause the audio and video to be out of sync, and causing words to be swallowed instantly when starting and stopping. 
- 
Fixed the issue where the iPad collects audio through the microphone and occasionally has no sound. 
- 
Fixed the problem of multi-thread concurrency when destroying a camera, causing a crash when accessing a null pointer. 
- 
Fixed the problem that the mediaPlayer takes a long time to open files in M3U8 format. 
3.13.3 #
Bug Fixes #
- Fixed the problem of using TextureView to render video frame on the iOS platform to set viewMode abnormally.
3.13.1 #
Bug Fixes* #
- Fixed an issue where publishing a screen share stream on the web platform failed.
3.13.0 #
New Features #
1. Added video stabilization feature (Only supports iPhone and Android)
Note:
This feature is only available for use during internal video capture.
When this feature is enabled, there may be delays or cropping of the image, so please use it accordingly.
The new video stabilization feature is added to reduce the impact of camera shake during internal video capture and improve the quality of video capture.
For related API, please refer to [setCameraStabilizationMode]
2. When using the QUIC protocol for CDN streaming, it supports 0-RTT connection establishment
Note:
The security of this feature is slightly lower compared to traditional methods. Please use it with caution.
When using this feature, set ZegoCDNConfig.protocol to quic.
[ZegoCDNConfig] adds the [quicConnectMode] attribute, which allows developers to use the QUIC protocol for CDN streaming. Set quicConnectMode to 1 for QUIC connection mode, enabling 0-RTT connection and fast service activation. Currently compatible with CDN live streaming products from Huawei, Wangsu, Tencent, and other vendors.
This feature is not enabled by default (quicConnectMode is set to 0, indicating normal connection establishment).
For related API, please refer to ZegoCDNConfig > quicConnectMode
3. Support setting a timeout for CDN repushing to monitor the existence of a stream
Note: This feature only takes effect when initiating a retweet. If there is a disconnection during the retweet process, the SDK will maintain the retry logic and there will be no callback notification in this case.
When initiating a retweet task, you can set the timeout for the retweet CDN through the [addPublishCdnUrl] interface to monitor if the stream exists. For example, if the developer has initiated a retweet task but the stream has not started streaming yet, after the timeout set, the SDK will return a callback notification indicating that the stream does not exist.
This callback notification will only be sent to the retweet initiator, not the streaming initiator. If the retweet initiator and the streaming initiator are not the same user, it is recommended for developers to initiate the retweet from the server side and receive this notification.
For related API, please refer to addPublishCdnUrl
4. Support for callback local recording quality data
[ZegoDataRecordProgress] adds the [quality] attribute, which can be used to callback the quality data of the recorded file, such as frame rate and bit rate, during the local recording process.
For related API, please refer to onCapturedDataRecordProgressUpdate
5. Supports low-light enhancement and color enhancement when using external capturing
Note: The external capture function and pre-processing function cannot be used at the same time, otherwise abnormal images may occur when playing streams.
After enabling the external capture function, you can use the [setLowlightEnhancement] and [enableColorEnhancement] interfaces to separately enable low-light enhancement and color enhancement to adjust the captured images according to your business needs.
For related API, please refer to setLowlightEnhancement, enableColorEnhancement
6. Support for H.265 automatic compatibility strategy
Note: Please contact ZEGOCLOUD technical support if you need to use this feature.
When some users in the room do not support the H.265 format, the streaming end that supports it will fall back to the H.264 format and republish stream.
Enhancements #
1. Optimizing the callback notification logic of the media streamer
Optimize the callback notification logic of the media streaming engine, add error callbacks for unsupported audio sampling rate (for example, not supporting a sampling rate of 24K), and help developers quickly locate problems.
For related API, please refer to onMediaDataPublisherFileClose
2. Optimized color enhancement algorithm
Optimized color enhancement algorithm performs better than previous versions in scenes with high color saturation.
3. For low-performance Android devices, optimize the fluency of voice and the effect of echo cancellation during background operation
Note: Please contact ZEGOCLOUD technical support if you need to use this feature.
4. For KTV scenarios, optimize the alignment effect of Bluetooth earphones on vocals and accompaniment, enhancing the K-song experience
Bug Fixes #
- 
Fix the problem of abnormal time consumption of interface calls caused by not deinitializing the SDK after long-term use. 
- 
Fixed compatibility issues with hardware encoding and decoding, addressing occasional crashes. 
- 
Fix known compatibility issues and null pointer problems. 
- 
Fixing an issue where the engine occasionally initializes with incorrect states. 
3.12.5 #
Bug Fixes #
- Fixed the issue where the video rendering black screen on Mac10.15 safari 13.0.2.
3.12.4 #
Bug Fixes** #
- 
Fixed the issue where the UI would occasionally freeze if a network abnormality occurs when initializing the SDK. 
- 
Fixed the issue where UI freezes may occur in a very low probability if the network is abnormal when switching networks. 
3.12.3 #
**New Features #
1. Support Copyright-music plugin
Note:
Please contact ZEGOCLOUD technical support if you need to use this feature.
The plugin cannot be used alone and must be used with Express SDK.
Support for copyright-music function pluginization, when the developer's business scenario only needs to update the copyright-music related, you can independently integrate the plugin without updating the Express SDK, which can smoothly migrate.
2. Support for getting a list of streams in the room from the client
Note: The function retrieves a real-time stream list inside the room. If the room service is disconnected, the results obtained may not be accurate.
Developers are supported to obtain the stream list inside the room from the client, which can be used to handle related business logic.
For related API, please refer to getRoomStreamList
3. Support for adding silent frames to audio and video streams transcoded to CDN
Note: Please contact ZEGOCLOUD technical support if you need to use this feature.
Support is provided for adding silent frames to the audio and video streams that are pushed to the CDN. This can be used to avoid issues such as stuttering or audio-video synchronization problems caused by timestamp discrepancies.
4. The media player supports obtaining the real-time frame rate of the file
Support for obtaining frame rate statistical information of the currently playing media file, which can be used for data display, anomaly monitoring, etc..
For related API, please refer to getPlaybackStatistics
5. Media player supports caching network resources locally
Support local caching of network resources, so that if the same network resource needs to be played, cached data will be prioritized, enhancing user experience.
For related API, please refer to enableLocalCache, onMediaPlayerLocalCache
**Bug Fixes #
- 
Fix the issue where certain models would display stripes on the screen when motion is occurring after enabling the super resolution feature. 
- 
Fix the issue of memory leak when destroying GPU resources in external filter blending mode for some phones. 
- 
Fix the issue of stuck when playing and rendering streams on some devices. 
- 
Fix the issue of crashing when playing audio or video with a sample rate higher than 48K on certain Android devices. 
- 
Fix the issue of occasional crashes when calling the [enableAudioCaptureDevice] interface. 
3.11.0 #
New Features** #
1. Support high-definition and low-code video in the cloud transcoding service
Note: If you need to use this feature, please contact ZEGOCLOUD business personnel.
By applying leading coding and decoding algorithms and other video pre-processing capabilities in the cloud transcoding service, we continuously optimize the smoothness and clarity of video playback, significantly improving the image quality. This feature is suitable for the following scenarios:
- 
Showroom live streaming scenes with high viewership. It ensures stable video transmission and high quality while saving bandwidth costs; without affecting the image quality, it can reduce the bitrate by about 30%. 
- 
Danmaku game live streaming, sports live streaming, and other scenes with rich color and texture details in the video content. Under the same bitrate conditions, it can provide a higher definition viewing experience. 
For related API, please refer to ZegoMixerOutputVideoConfig > enableLowBitrateHD
2. Color enhancement is supported when publishing video-streams
For various cameras and other devices that capture images, if the colors appear grayish or have low saturation, we support enhancing the colors while preserving the natural skin tones. This will make the images more vibrant and brighter, creating a more realistic visual experience for the human eye.
For related API, please refer to enableColorEnhancement
3. All network requests support the IPv6 protocol
4. Real-time room messaging supports sending transparent messages
Support sending real-time room messages to specified clients or client servers; message types are divided into normal and ordered, with the latter ensuring that messages are received strictly in order. This feature is suitable for scenarios where the anchor needs to manage the microphone positions in the room, for example:
- 
Send messages to users who need to mute through the anchor client, and the receiving client will mute accordingly. 
- 
When the anchor wants to kick a user out of the room, send a message to the client server of the other party through the anchor client, and kick out the user. 
For related API, please refer to sendTransparentMessage
5. Hardware decoding acceleration supported for MJPEG format
Note: This feature only supports pre-processing of screenshots and does not support other processing such as rotation or watermarking.
When the video format output by the capture device is MJPEG, hardware decoding acceleration is enabled by default to prevent issues such as insufficient frame rate due to insufficient device performance.
This feature is suitable for use on capture devices with a 4K resolution mainly.
6. Automatic mixing supports setting water level
Note:
- 
This feature is not enabled by default, meaning the server uses the default configuration values. 
- 
This feature may increase latency, so use it judiciously. 
The automatic stream mixing interface supports setting a watermark to control the lower limit of the range for adaptive adjustment of the mixing server's stream cache. This helps maintain a balance between mixing time and video stuttering caused by unstable streaming from the source. This feature only takes effect on new input streams and does not affect input streams that have already started mixing.
For example, in a real-time karaoke KTV scenario, slight fluctuations in the streaming network from the source may cause mixing stuttering, which in turn increases the likelihood of stuttering for viewers. By adjusting the lower limit of the watermark, you can optimize the viewer's experience with stuttering, but this will increase latency.
For related API, please refer to ZegoAutoMixerTask > minPlayStreamBufferLength
7. Support for using live streams as input streams for mixing
Newly added support for using live streams as input streams for mixing; the URL of the live input stream supports both RTMP and HTTP-FLV protocols. This feature is suitable for mixing the RTC video streams of hosts' interactive broadcasting with cloud sports live streams, game live streams, etc., to achieve scenarios such as game or sports commentary in live broadcasting.
8. Custom audio offset value is supported for mixing
When using custom audio and video capture function and the corresponding audio capture sources have inconsistent delays, you can customize the audio offset value during mixing to achieve audio-video synchronization after mixing output, ensuring a better experience for the audience.
For related API, please refer to ZegoMixerInput > advancedConfig
9. The media player supports callbacks for video resolution change events
The media player supports throwing relevant callback notifications to developers when the video resolution changes. This feature is suitable for scenarios where the resolution of the streaming screen changes multiple times and requires adjusting the encoding resolution on the streaming end and matching the rendering view size on the receiving end.
For related API, please refer to onMediaPlayerVideoSizeChanged
10. The audio player supports separate settings for streaming volume and local volume
The sound effect player supports setting the streaming volume and local playback volume separately, ensuring that the volume on both ends, local and remote, is within an appropriate range.
For related API, please refer to ZegoAudioEffectPlayer > setPublishVolume, ZegoAudioEffectPlayer > setPlayVolume, ZegoAudioEffectPlayer > setPublishVolumeAll, ZegoAudioEffectPlayer > setPlayVolumeAll
Enhancements** #
1. Optimize server-side mixing and single-stream transcoding capabilities
Optimize server-side mix streaming and single-stream transcoding capabilities to improve encoding efficiency and achieve a 5% or more increase in subjective and objective video quality at the same bitrate.
2. Optimize the AEC (Acoustic Echo Cancellation) algorithm to achieve better AEC performance
3. Optimize network connection strategies to enhance the experience of audio and video calls
4. Optimize the strategy of switching between the front and back end to solve the problem of collecting silence in certain specific scenarios or models
5. Optimize multi-device login logic
After the user successfully logs in on device A, device A loses network connection. Then, the user logs in successfully on device B using the same userID. If the network connection on device A is restored and a reconnection is attempted, it will fail and throw error code 1002086, indicating that the userID is already logged in another device.
Bug Fixes #
1. Fixed the issue that caused crashes in certain decoding scenarios
3.10.3 #
Bug Fixes #
- Fixed the problem of false positives in the mobile terminal sleep detection module, affecting room re-login and push-pull stream retry logic.
3.10.2 #
Bug Fixes #
- Fixed the issue of a black screen appearing after turning on low-light enhancement.
3.10.0 #
New Features #
1. Added real-time AI voice-changing function
Note:
The AI Voice-Changing function is a paid function. If you need to apply for a trial or inquire about the official charging standards, please contact ZEGOCLOUD business personnel.
The current official website SDK does not include this function. If necessary, please contact ZEGOCLOUD technical support for special packaging.
New AI voice changing function, like the Conan's Bowtie in real-time calls, perfectly reproduces the timbre and rhythm of the target character, while retaining the user's speech speed, emotion, and intonation, and can switch timbre at will, with ultra-low latency allowing users Enjoy social chat, live broadcast, game voice and other scenarios.
For related API, please refer to createAIVoiceChanger, destroyAIVoiceChanger
2. The virtual background of subject segmentation supports video materials
Note:
The current official website SDK does not include this function. If necessary, please contact ZEGOCLOUD technical support for special packaging.
The video filling method of the virtual background is centered and proportionally scaled. When the video is too large, the excess part will be cropped.
When using the subject segmentation function, the virtual background supports the use of video materials. The final frame rate of the video materials will be consistent with the encoding frame rate and played in a loop.
For related API, please refer to enableVideoObjectSegmentation
3. Media player supports accompaniment sound quality enhancement
The media player supports accompaniment sound quality enhancement, which improves the sound quality of the accompaniment and the atmosphere of the scene. It is suitable for chat rooms, karaoke and other scenes.
For related API, please refer to enableLiveAudioEffect
4. Supports obtaining and uploading audio Dump files
Note: Since audio dump files are sensitive privacy data of users, developers must read ZEGOCLOUD Privacy Policy carefully when implementing this capability. In addition, when collecting audio Dump files, please indicate the purpose of Express SDK collection when obtaining user authorization and consent.
Supports saving and uploading audio data before and after processing, which can be used to locate audio-related problems, improve troubleshooting efficiency, and shorten access time.
For related API, please refer to startDumpData, stopDumpData, uploadDumpdata, removeDumpData, onRequestDumpData, onStartDumpData, onStopDumpData, onUploadDumpData
5. Custom video capture supports transparent channel transmission
Supports the extraction, encoding, and transmission of Alpha channel data in the RGBA channel collected by developers, thereby rendering the subject with a transparent background on the streaming side to achieve a more immersive and realistic video scene.
For related API, please refer to enableAlphaChannelVideoEncoder
Enhancements #
1. Optimized low-light enhancement function, smoother in automatic mode
In the automatic mode with low illumination enhancement, the dynamic adjustment of brightness will be smoother and smoother, improving the user's visual experience.
For related API, please refer to setLowlightEnhancement
2. Optimize the upper limit of expected publish and play stream bit rates for network speed testing
Optimize the upper limit of expected publish and play streaming bit rates for network speed testing, increasing it to 15M. Developers can check how well the audio and video quality matches the current network before publishing and playing streams to ensure stable call quality.
For related API, please refer to startNetworkSpeedTest
3. Optimize the [muteAll] interface logic for receiving audio and video data from remote users when playing streams
Note: The new interfaces [muteAllPlayAudioStreams], [muteAllPlayVideoStreams] and the old interfaces [muteAllPlayStreamAudio], [muteAllPlayStreamVideo] cannot be mixed.
New interfaces [muteAllPlayAudioStreams] and [muteAllPlayVideoStreams] are added to receive the audio and video data of all remote users when playing streams; at the same time, the [mutePlayStreamAudio] and [mutePlayStreamVideo] interfaces are used to individually control the specified streams.
After the old interfaces [muteAllPlayStreamAudio] and [muteAllPlayStreamVideo] are called, the receiving status of the specified stream cannot be controlled individually.
For related API, please refer to muteAllPlayAudioStreams, muteAllPlayVideoStreams, mutePlayStreamAudio, mutePlayStreamVideo
4. The media player supports only playing video or audio without consuming additional decoding performance
Note: During playback, if the media stream type is modified, it will take effect the next time it is played.
When using a media player to play audio and video files, the [setPlayMediaStreamType] interface can be used to set it to Audio-only or Video-only, which does not consume audio and video decoding performance.
For related API, please refer to setPlayMediaStreamType
**Bug Fixes #
1. Fixed the issue of occasional no sound when playing streams
2. Fixed the issue where the [logoutRoom] and [loginRoom] interfaces were called multiple times when multiple rooms were disconnected, resulting in subsequent failure to log in to the room
4. Fixed the problem of frequent retries when room reconnection fails
3.9.0 #
New Features #
1. ScreenCapture supports system WGC
Note: This feature requires Windows 10.18362 or above.
When the multi-source acquisition module performs screen capture, it supports system WGC, which also known as Windows Graphics Capture, and uses this mode by default, making the acquisition more efficient.
2. ScreenCapture supports setting publishing-stream area
The multi-source collection module supports users to set independent preview and publishing-stream areas when performing screen capture.
For related API, please refer to updatePublishRegion
3. Added SEI callback with timestamp
For related API, please refer to onPlayerRecvMediaSideInfo
4. The single-stream transcoding function supports playing stream by RTC
Note:
If you need to use this function, please contact ZEGOCLOUD technical support.
Transcoding will cause additional delays. It is not recommended if you use this function in your Live Streaming scenarios which playing stream by RTC.
When RTC plays streams, it supports triggering single-stream transcoding tasks through preset transcoding templates, and outputs transcoded streams with different resolutions.
This function can be used in scenarios such as live broadcasts. Viewers can choose streams of different resolutions to ensure smooth playback that based on network quality, terminal equipment, etc..
For related API, please refer to ZegoPlayerConfig > codecTemplateID
5. Supports throwing [setDummyCaptureImagePath] exception callback
For related API, please refer to onPublisherDummyCaptureImagePathError
6. Direct-publish CDN supports updating the CDN address during publishing
For related API, please refer to enablePublishDirectToCdn
7. Supports AI-balanced noise reduction mode
Note: The current official SDK does not include this function. If necessary, please contact ZEGOCLOUD technical support for special packaging.
Support balanced AI noise reduction mode. Compared with the original mode, under the premise of the same human voice fidelity effect, the noise suppression effect is significantly improved, and can reach the level of clean and noise-free or non-disturbing; but the performance Consumption increased slightly. Suitable for noisy (low signal-to-noise ratio) outdoor environments such as streets, roads, markets, etc..
For related API, please refer to ZegoANSModeAIBalanced
Enhancements #
1. Optimize [setLogConfig] interface
The life cycle of [setLogConfig] is expanded to the App life cycle, and its priority is higher than the configuration in [setEngineConfig].
For related API, please refer to setLogConfig, setEngineConfig
2. Optimize the retry rules when the App is dormant
Optimize the retry rules when the App is sleeping. During the loginRoom and publishing-playing process, the App Sleep Time is also included in the Maximum Allowed Retry Time.
Bug Fixes #
- 
Fixed the problem that the audio external collection module would cause silence when switching audio sources. 
- 
Fixed the issue where no error message is thrown when the watermark path exceeds the maximum length set by setPublishWatermark. 
- 
Fixed the issue of a very small probability of failure when sending a new stream. 
- 
Fixed the issue of the sound effects player occasionally crashes. 
- 
Fixed the problem that when calling the sendAudioSideInfo interface to send audio secondary messages, it takes about 10 seconds for the player to receive the message. 
- 
Fix the problem that the time spent on TCP disconnection of WS CDN in the case of direct publishing is fixed at 500 ms 
3.8.1 #
New Features #
1. Added support for Smart Cloud Proxy mode
Note: If you need to use this function, please contact ZEGOCLOUD technical support
After the developer sets the Smart Cloud Proxy mode, when publishing streams from RTC or L3, it will give priority to using the direct network mode to try. If the direct connection network is unavailable and it is currently a cellular network, continue to stay in the direct connection mode and try again; if the direct connection network is not available and it is currently a non-cellular network, then switch to the cloud proxy mode.
2. Support returning low frame rate alarms for encoding and hardware decoding
Note: If you need to use this function, please contact ZEGOCLOUD technical support
Added a low frame rate alarm callback that supports throwing encoding and hardware decoding. In 1v1 chats, live broadcasts and other scenarios, developers can adjust the streaming resolution and trigger transcoding based on this callback.
For related API, please refer to onPlayerLowFpsWarning, onPublisherLowFpsWarning
3. Mediaplayer supports setting Http Headers of network resources
The mediaplayer supports setting the Http Headers of network resources. Based on this configuration, developers can customize and limit the access methods of network resources to strengthen the security protection of resources.
For related API, please refer to setHttpHeader
4. The range voice supports configuring the attenuation range of the 3D sound effect distance and the sound range of a single stream
In the range voice scene:
- Support to set the attenuation range [min, max] of the 3D audio effect distance through the setAudioReceiveRange function,set the attenuation range [min, max] of the 3D audio effect interface. When the distance is less than min, the volume will not attenuate as the distance increases; when the distance is greater than max, the other party's voice will not be heard.
- Support setting the vocal range [min, max] of a single stream through the setStreamVocalRange interface.
5. Support callback related event activities by publish channel
The onPublisherSendAudioFirstFrame callback function adds a channel parameter, which supports multi-channel listening and streaming to send the first frame information.
For related API, please refer to onPublisherSendAudioFirstFrame
Enhancements #
1. Optimize the noise performance of the low-light enhancement algorithm
2. Optimize the URL length of resources loaded by mediaplayers, with a maximum support of 2048 bytes
3. Optimize the callback synchronization of media player SEI information and corresponding frame data to ensure the consistency of SEI and screen
Bug Fixes #
1. Fix the problem of hard unblocking of H.265 RTMP streams with B frames
2. Fix the probelm that changing the userID after [createEngine] and before [destroyEngine] may cause publish-play stream failure when using Token authentication
Deleted #
1. Abandoned some API interfaces
In version 3.8.1, deprecated changes were made to the following API interfaces.
- 
Abandoned the original onPublisherSendAudioFirstFramecallback interface and replaced it with the onPublisherSendAudioFirstFrame callback of the same name, and added achannelparameter to support callback-related event activities by publsih channel.
- 
The original member function of ZegoRangeAudio class: - The original member function setAudioReceiveRangeis discarded and replaced with the setAudioReceiveRange interface with the same name, and the parameter ZegoReceiveRangeParam type is extended to support setting the audio receiving range of the range voice.
- The original member function setStreamVocalRangeis discarded and replaced with the setStreamVocalRange interface with the same name, and the parameter ZegoVocalRangeParam type is extended to support setting the voice range of a single stream of range voice.
 
- The original member function 
There may be compatibility issues after the API interface changes, please refer to Upgrade guide 3.8.1+ for details.
3.7.0 #
New Features #
- 
After enabling the encoding of H.264 DualStream, in addition to the video parameters for the big stream, it is now possible to set the video parameters for the small one. Note: Before using this function, you need to call the [setVideoConfig] interface to specify the video codecID as ZegoVideoCodecIDH264DualStream. The ratio of setting the resolution for the big stream and the small stream needs to be consistent, otherwise it will cause errors when calling the interface. When specifying the codecID as ZegoVideoCodecIDH264DualStream, you can separately set the resolution, frame rate, and bitrate for the big stream and the small stream. For related API, please refer to setVideoConfig, setPublishDualStreamConfig 
- 
Added a callback notification when the desktop screen capture area changes. The callback notification for when the desktop screen capture area changes is called [onRectChanged]. After starting the screen capture, when the capture area changes, the SDK will notify the developer through this callback. By listening to this callback, developers can modify the preview screen size and other configurations. For related API, please refer to onRectChanged 
Enhancements #
- 
Optimize the internal logic of the SDK and reduce the memory usage by 400KB ~ 600KB. 
- 
Optimize the SDK video capture strategy to improve image quality. 
- 
In the publish-play stream retry state caused by network disconnection, support callback for local network quality For related API, please refer to onNetworkQuality 
- 
Support generating log upload tasks after calling the [destroyEngine] interface. For related API, please refer to submitLog 
- 
Optimize the internal logic of the SDK to improve the call experience in a weak network environment. 
Bug Fixes #
- 
Fixed the occasional stuck problem when rendering on the metal screen. 
- 
Fix the problem that after MediaRecorder and AudioObserver stop streaming, the local streaming is not resumed and the collection continues. 
- 
Fix the problem of multi-thread deadlock in NetMonitor module. 
3.6.0 #
💥 Breaking changes #
The applicationVolume and microphoneVolume fields in the ZegoScreenCaptureConfig class become optional fields.
New Features #
- 
Added support for background blur and virtual background functions. Note: The current official website SDK does not include this function. If necessary, please contact ZEGOCLOUD technical support. In real scene or greenscreen scenes, developers can use this function to blur the user's background, or replace it with a custom picture background. This function can be used in video conferences, 1v1 audio and video calls and other scenarios to help users better protect personal privacy and improve the fun of calls. For related API, please refer to enableVideoObjectSegmentation 
- 
The screen capture function supports the capture of system audio. The screen capture function adds the ability to capture system audio on the basis of only supporting image capture, so as to share the music being played while sharing the demo courseware screen. This function can be used in scenarios such as online teaching and game live broadcasting. For related API, please refer to startScreenCapture 
- 
Added Enhanced KTV reverb effect. Added an enhanced KTV reverb effect to achieve a more concentrated and brighter KTV vocal effect. Compared with the previous KTV reverb sound effect, the Enhanced KTV reverb effect shortens the reverb duration and improves the dry-wet ratio. The original KTV reverb effect is only suitable for users with obvious vocal defects, and the enhanced KTV reverb effect is suitable for most professional users and ordinary users. For related API, please refer to setReverbPreset 
- 
Game voice function supports media player and audio player to use 3D sound effects. Developers can realize 3D sound effects of local audio and online audio resources by setting the position and orientation of media players and sound effect players. This function can be used to set the sound effect of the item in the virtual scene, as well as the background music of the specified location, etc. For related API, please refer to ZegoMediaPlayer > updatePosition, ZegoAudioEffectPlayer > updatePosition 
- 
The media player supports obtaining media stream video information For the video file being played by the media player, the developer can actively obtain information such as the resolution and frame rate of the video. For related API, please refer to ZegoMediaPlayer > getMediaInfo. 
- 
Media player double speed function supports up to 4x The maximum speed of the media player has been increased to 4x. For example, when the user is playing an audio and video file, if it has been set to play at 2x, it can be accelerated to 4x when long pressing the screen. For related API, please refer to ZegoMediaPlayer > setPlaySpeed 
- 
The media player supports functions such as downloading, retrieving data decryption, and playing at the same time. For copyright music protection in online players, the media player supports downloading while recalling unencrypted binary data, which is decrypted by the developer and then returned to the media player for playback. During the process, no files or cache files are generated. For related API, please refer to ZegoMediaPlayer > enableBlockData 
Bug Fixes #
- 
Fixed an issue that could cause a memory leak when using the media player. 
- 
Fixed an issue that enableCustomVideoCapture/enableCustomVideoProcessing/enableCustomVideoRender not result called. 
3.5.0 #
New Features #
- 
Support the first frame callback for audio and video streaming. When publishing audio and video stream, monitor the release timing of the "first frame of audio" or "first frame of video" through onPublisherSendAudioFirstFrame and onPublisherSendVideoFirstFrame callbacks. This function can be used to count the time consumption of audio and video streaming, or update UI performance, etc. For related API, please refer to onPublisherSendAudioFirstFrame, onPublisherSendVideoFirstFrame 
- 
The media player supports the first frame callback after the audio and video rendering is completed. When rendering audio and video through the media player, use the onMediaPlayerFirstFrameEvent callback to monitor the release timing of the "first frame of audio" or "first frame of video" after rendering. This function can be used to count the time consumption of audio and video rendering, or update UI performance, etc. For related API, please refer to onMediaPlayerFirstFrameEvent 
- 
External collection supports active offset NTP timestamps. Note: If you need to use this function, please contact ZEGOCLOUD technical support. When using the external acquisition function, support actively offsetting the NTP timestamp through the experimental API interface. This function can be used in KTV chorus, accompaniment, lyrics alignment and other scenarios. 
- 
Support for fast switching rooms in multi-room mode. In the multi-room mode, the switchRoom interface is supported to quickly and conveniently realize the function of switching rooms. For related API, please refer to switchRoom 
Enhancements #
- 
Significantly reduce the time-consuming time spent on video hard decoding of Huawei models. Note: If you need to use this function, please contact ZEGO technical support. For HUAWEI devices, the SDK supports relevant configurations to reduce the time spent on video hardware decoding by 80%. 
- 
Drastically reduces SDK memory consumption on iOS device. This optimization takes effect from version 3.5.0 and does not require additional interfaces. 
Bug Fixes #
- 
Fix the problem that the media player cannot make the playback progress jump to 0 through the seekTo interface in some m3u8 file formats. 
- 
Fix the occasional problem that the video on the streaming side freezes after re-pushing the stream. 
- 
Fix the problem that Android memory usage information is not updated. 
- 
Fix the occasional problem that when the iOS media player loads a file for the first time, there will be no picture for the first few seconds. 
3.4.2 #
- 
Support for Geofencing Function. Note: - 
To use this feature, please contact ZEGO technical support. 
- 
Please configure geofencing information before creating the engine. 
 Restrict access to audio, video, and signaling data to a specific area to meet regional data privacy and security regulations, which restrict users' access to audio and video services in a specific area. For related API, please refer to setGeoFence 
- 
- 
The media player supports functions such as downloading, retrieving data decryption, and playing at the same time. For copyright music protection in online players, the media player supports downloading while recalling unencrypted binary data, which is decrypted by the developer and then returned to the media player for playback. During the process, no files or cache files are generated. For related API, please refer to enableBlockData 
- 
Support dynamic switching of flow control strategies Supports dynamic switch flow control function, as well as setting flow control attributes. For related API, please refer to enableTrafficControl, setMinVideoBitrateForTrafficControl, setMinVideoFpsForTrafficControl, setMinVideoResolutionForTrafficControl 
- 
Expand the acquired song resource information. Support acquiring the start and end time information of the "snatch singing segment" of the song corresponding to the songID through the requestResource interface. Other users can obtain the shared information through the getSharedResource interface. Note: This feature is only supported for use by some copyright holders. Please contact ZEGO technical support. For related API, please refer to requestResource, getSharedResource 
- 
Copyrighted music adds a new billing model. A new billing model has been added, which charges monthly based on the host. Please contact ZEGO technical support. 
- 
The copyright content center has added song resources from music copyright holders. It is supported to pass different values of copyright holders in the parameter "vendorID" of the relevant interface to perform operations such as song request and obtaining lyrics. Note: Detailed information about the copyright holder. Please contact ZEGO technical support. For related API, please refer to requestResource, getSharedResource 
- 
Expand the range of supported song rating capabilities. Support the ability to rate and display pitch lines for multiple copyrighted songs, with detailed information. Please contact ZEGO technical support. 
- 
Support the use of copyrighted music in multi-room mode. By adding the roomID parameter to the "request song" and "get shared resources" interfaces, the use of copyrighted music in multi-room mode is enabled. For related API, please refer to requestResource, getSharedResource 
- 
Copyrighted music support song aggregation search. Support searching and querying through multiple copyright music libraries by inputting keywords such as singer or song title. The search results can be filtered, sorted, and customized for display. For related API, please refer to sendExtendedRequest 
Enhancements #
- 
Optimize SDK memory usage Delete some unnecessary memory applications within the SDK and optimize the SDK's memory usage. Compared to the previous version, the memory usage has decreased by about 10%. 
- 
Optimize the rotation logic of iOS screen sharing to avoid crashes caused by memory usage exceeding the 50MB limit caused by rotation during the screen recording process. 
- 
Optimize error code prompts. Due to the expiration limit of song resources, the API for obtaining song resources has added a new error code 1008011, indicating that the song resource has expired. For related API, please refer to loadCopyrightedMusicResourceWithPosition 
- 
To add a new enumeration value for a music copyright holder. To add a new enumeration value for a music copyright holder. Please contact ZEGO technical support. For related API, please refer to ZegoCopyrightedMusicVendorID 
Bug Fixes #
- 
Fixed the issue of macOS platform screen sharing where the actual collection frame rate is lower than the set frame rate. 
- 
Fixed the problem of iOS blurred video picture caused by uncontrolled video hard coding rate when hard coding streaming is performed on iOS 16.4.1 devices. 
- 
Fixed the issue of abnormal listening of game voice in certain situations. 
Deleted #
- 
Starting from version 3.4.1, support for iOS 11.0 and below has been discontinued, and the iOS Deployment Target (minimum supported version) has been upgraded to iOS 11.0. For specific instructions, Please refer to App Store submission requirement starts April 25 and Xcode 14 Release Notes. 
- 
Starting from version 3.4.1, the iOS SDK no longer supports the 32-bit armv7 architecture. For specific instructions, Please refer to Xcode 14 Release Notes. 
3.3.1 #
Bug Fixes #
- 
Fixed the failure of Android hardware ear feedback in some scenarios. 
- 
Fixed H265 decoding failure in Android some scenarios. 
3.3.0 #
New Features #
- 
Support for voice enhancement effect in external scenes. In the external scene, the microphone of the device is too close to the speaker, which may easily lead to blurred or dull voice. In this scenario, voice enhancement can effectively improve the clarity of voice and improve the sense of boredom. Therefore, it is recommended to enable this function in an external scenario. In order to achieve the voice enhancement effect in the external broadcast scene, the voice enhancement effect can be turned on and the enhancement level can be set. It can be used in the KTV external broadcast scene to fine control the voice effect. The recommended enhancement level is 4. For related API, please refer to enableSpeechEnhance 
- 
Game voice supports customized voice mode and listening mode. The game voice supports the customized setting of voice mode and listening mode, which can be used to shield the scene of the same team of players outside the range after joining the team. For related API, please refer to setRangeAudioCustomMode 
- 
Express SDK iOS streaming function supports picture-in-picture capability. Note: To use this function, please contact ZEGO technical support. 
- 
The single-stream transcoding function supports L3 or CDN streaming. Note: When pulling the transcoding stream through CDN, you must use the push CDN. To use this function, please contact ZEGO technical support. Single-stream transcoding refers to converting each original stream into transcoding streams with different encoding formats and different resolutions in the cloud. The transcoding template ID needs to be passed in to pull the transcoding stream. In live broadcast and other scenes, viewers can choose streams of different resolutions to watch based on the quality of the access network, terminal equipment, etc., to ensure the smoothness of playback. 
- 
The same mixed-stream task supports the output of multiple resolution video streams. Note: - 
At present, one mixing task can output up to four video streams with different resolutions, and only server mixing is supported. 
- 
To use this function, please contact ZEGO technical support. 
 The same mixing task supports the output of multiple resolution video streams, which can be used to meet the transcoding requirements in the mixing scenario. 
- 
- 
Mixed flow task supports input of super whiteboard information. In the mixed-stream function, the operation content in the whiteboard can be converted into real-time video, and the whiteboard configuration information can be set, for example, the whiteboard ID, the whiteboard aspect ratio, and whether dynamic PPT loading is supported. Note: Currently the super whiteboard flutter SDK is under development. For related API, please refer to ZegoMixerTask, startMixerTask 
- 
Scenario-based audio and video configuration adds [ZegoScenario.StandardVoiceCall] standard voice call scenario. StandardVoiceCall standard voice call scenario is added for scenario-based audio and video configuration, which is applicable to 1v1 pure voice call scenario. For related API, please refer to setRoomScenario 
- 
Android support adaptive device acquisition rendering delay and echo cancellation (AEC) in customized audio acquisition and SDK internal rendering mode. Note: To use this function, please contact ZEGO technical support. In the customized audio acquisition and SDK internal rendering mode, the AUX adaptive alignment and AEC functions are supported, which can achieve better results when performing chorus in KTV scenes. 
- 
Added a new copyright content center, and some interfaces support the query of distinguishing copyright parties. According to the copyright owner, it supports ordering songs, obtaining line-by-line analysis of lyrics, and querying whether resources are cached. Note: For detailed information about the copyright owner, please contact ZEGO technical support for processing. For related API, please refer to requestResource, getLrcLyric, queryCache, getSharedResource 
- 
When sending an extended request, it is supported to obtain a list of tags, get songs based on tags, query song information in batches, and search for songs according to the copyright owner. For related API, please refer to sendExtendedRequest 
Enhancements #
- 
Optimize the supersection algorithm to greatly improve the coverage of aircraft models. Note: - [enableVideoSuperResolution] modifies the call time, and can only be called after [initVideoSuperResolution].
- Video super resolution currently only supports Android and iOS
 For related API, please refer to enableVideoSuperResolution, initVideoSuperResolution 
- 
Optimize the over-division logic and add initialization and de-initialization interfaces. Note: - [enableVideoSuperResolution] modifies the call time, and can only be called after [initVideoSuperResolution].
- Video super resolution currently only supports Android and iOS
 For related API, please refer to initVideoSuperResolution, uninitVideoSuperResolution 
- 
Optimize the deep echo cancellation (AEC) effect of KTV scenes. The deep AEC optimization for KTV scenes has achieved: - 
The sound quality of the human voice in the external scene is greatly improved to make the human voice more fidelity. 
- 
While eliminating the echo, effectively avoid the occasional swallowing of words or the fluctuation of voice. 
 
- 
- 
Optimize the inter-process communication performance of screen sharing on the iOS side of the Express SDK. In the application project, developers can start AppGroup configuration through the new [ZegoExpressEngine>setAppGroupID] and [ZegoReplayKitExt>setupWithDelegate:appGroup] interfaces to obtain better performance and stability. For related API, please refer to setAppGroupID 
Bug Fixes #
- 
Fixed the problem that the Android player has no sound after plugging the headset. 
- 
Fixed the problem of Android screen collection failure when the main process does not start the screen sharing service. 
- 
Fixed the problem that immediately getting the pitch line would fail when getting song accompaniment resources or climax clip resources 
3.2.1 #
New Features #
- 
Add screen capture stream function of web platform; Note: Firstly, getting screen capture instance by calling the createScreenCaptureSource.Sencondly, setting the video soure are "screen" by calling setVideoSource function.Now, you can call startCapture for the screen capture instance. 
- 
Add login multi-room function of web platform; Note: On the web platform, setRoomMode now allows users to log into multiple rooms if they want. 
- 
Add basic beauty function of web platform; Note: On the web platform, support users to use the beauty function by calling enableEffectsBeauty and setEffectsBeautyParam support . 
Bug Fixes #
- 
Fixed the problem that the customized audio acquisition and audio acquisition source need to be reset to take effect after logging in to the room again in some scenarios. 
- 
Fixed an exception caused by the onRemoteSoundLevelUpdate callback. 
- 
Fixed an issue with setting SEIType for the setSEIConfig interface on iOS that did not work. 
3.3.0-prerelease.1 #
New Features #
- 
Add screen capture stream function of web platform; Note: Firstly, getting screen capture instance by calling the createScreenCaptureSource.Sencondly, setting the video soure are "screen" by calling setVideoSource function.Now, you can call startCapture for the screen capture instance. 
- 
Add login multi-room function of web platform; Note: On the web platform, setRoomMode now allows users to log into multiple rooms if they want. 
- 
Add basic beauty function of web platform; Note: On the web platform, support users to use the beauty function by calling enableEffectsBeauty and setEffectsBeautyParam support . 
Bug Fixes #
- 
Fixed an exception caused by the onRemoteSoundLevelUpdate callback. 
- 
Fixed an issue with setting SEIType for the setSEIConfig interface on iOS that did not work. 
3.2.0+1 #
Bug Fixes #
- Fix the problem that the ZegoVideoSourceType value does not match the actual effect.
3.2.0 #
New Features #
- 
Support video DualStream. When video streams are layered through video DualStream coding (H.264 DualStream), Compared to Layered Video Coding (H.264 SVC), Video DualStream encoding (H.264 DualStream) supports hardware encoding, that is, [ZegoVideoCodecID] adds [H264DualStream] field. For related API, please refer to ZegoVideoCodecID.H264DualStream. 
Enhancements #
- 
CustomCommand configuration support extended to 4KB. Note: The default size of the CustomCommand configuration is 1KB, if it needs to be extended to 4KB, please contact ZEGO technical support for processing. 
Bug Fixes #
- 
Fix hardware coded access to null pointer crash. 
- 
Fix the problem that the network time module fails to retry. 
3.1.0 #
New Features #
- 
Support multi-source acquisition capability. For a variety of interactive scenarios of audio and video sources such as online KTV, watching movies together, watching competitions, video conferences, and online education, multi-source acquisition provides flexible and easy-to-use audio and video acquisition sources and channel management capabilities, greatly reducing developers' development and maintenance costs. Multi source acquisition capability shortens, optimizes and normalizes the implementation path of common capabilities such as screen sharing and mixing. After version 3.1.0, you can no longer implement the above complex capabilities through custom acquisition. The main capabilities and characteristics are as follows. - 
Streaming channel supports setting or switching multiple audio and video sources. 
- 
Common capabilities such as screen sharing and mixing are supported. 
 
- 
- 
SDK supports setting cloud proxy. Note: If you need to use this function, please contact ZEGO technical support. By setting the cloud proxy interface of the SDK, all the traffic corresponding to the SDK is transferred through the cloud proxy server to achieve communication with the RTC. For related API, please refer to setCloudProxyConfig. 
Enhancements #
- 
Greatly improve the audio and video connectivity in extremely weak network areas, and reduce the connection time. The ZEGO self-developed dispatching system has been deeply optimized for areas with poor network quality. 
Bug Fixes #
- 
Fixed the problem that sending room [Logout] signaling may fail. 
- 
Fixed Android the occasional black screen problem caused by the camera authority occupation. 
- 
Fixed occasional crash of Android audio player. 
- 
Fixed iOS the occasional crash of null pointer in restart access after the video hardware failure. 
- 
Fixed Android the problem of device restart in low latency mode. 
3.0.3 #
💥 Breaking changes #
This version contains breaking changes, please refer to v3.0.3 Upgrade Guide for details.
New Features #
- 
New video super-resolution capability Note: If you need to use this function, please contact ZEGO technical support. This feature currently only supports IOS and Android platforms. The new [enableVideoSuperResolution] interface supports super-resolution processing of a video stream to achieve better image quality. Super resolution, referred to as super resolution, is a technology that the client multiplies the width and height of the pulled video stream in real time. For example, from 640x360 to 1280x720. For related API, please refer to enableVideoSuperResolution, onPlayerVideoSuperResolutionUpdate 
- 
Scene AI noise reduction adds the ability to reduce noise in music scenes Note: If you need to use this function, please contact ZEGO technical support. This feature currently only supports IOS,Android,mac and window platforms. The scene AI noise reduction function, based on the previous noise reduction for all non human voices, supports the noise reduction capability in the music scene, and restores the music sound quality by identifying music and intelligently adjusting the noise reduction effect. The SDK will perform music detection on the microphone input in real time, and automatically adjust the noise reduction level in sound card, playing and singing or near field music scenes to ensure the high fidelity sound quality of music. 
- 
Scenario of adding room dimensions In order to facilitate the rapid access of developers and reduce the access threshold for developers, the SDK provides a variety of preset scenarios. Developers can select the corresponding room mode ZegoScenario according to the desired scenario, and the SDK will automatically apply audio and video codecs, audio and video parameters, flow control strategies and other configurations suitable for the scenario, so as to quickly achieve the best effect in the scenario. Currently supported scenarios include live show, KTV, standard 1v1 audio and video calls, high quality 1v1 audio and video calls, standard chat rooms, and high quality chat rooms. For related API, please refer to setRoomScenario 
- 
Support for obtaining the codec capability of the specified video codec of the current device Note: The interface adds an optional parameter codecBackend. The return value is changed to an int type; 0 means not supported, and this encoding format cannot be used for streaming; 1 means supported, and this encoding format can be used for streaming; 2 means not confirmed, and it is recommended to call this interface later.This feature currently only supports IOS,Android,mac and window platforms. The SDK supports obtaining the support of the codec mode of the video codec specified by the current device, so as to better help developers choose the encoder and codec mode to use and obtain better results. The hardware or software encoding support of the current encoder can be obtained through the [isVideoEncoderSupported] interface. Through the [isVideoDecoderSupported] interface. The hardware or software decoding support of the current decoder can be obtained. The above two interfaces contain three enumerated values:support hardware or software, support hardware, and support software. For example, ZegoExpressEngine.instance.isVideoEncoderSupported(ZegoVideoCodecID.H265, codecBackend: ZegoVideoCodecBackend.Hardware)means to check whether the current device supports H265 hardcoding. If yes, return 1. For related API, please refer to isVideoEncoderSupported, isVideoDecoderSupported 
- 
Added switch interface for acquiring GPS information Note: This function is enabled by default. If you need to disable this function, please contact ZEGO technical support. n If the app has access to the geographical location, the developer can choose whether to allow the ZEGO SDK to obtain the GPS information cached by the system, which is obtained by default. When developers want to disable this function, they need to contact ZEGO technical support to set it.This feature currently only supports IOS , Android,mac and window platforms. 
- 
New video first frame callback based on camera opening Support callback after SDK pulls the stream and renders the first frame of remote camera video data each time the remote camera is turned on. Developers can use this callback to calculate the first frame time consumption, or update the UI components of the playback stream.This feature currently only supports IOS,Android,mac and window platforms. For related API, please refer to onPlayerRenderCameraVideoFirstFrame 
- 
Add the CDN Plus playing configuration to the startPlayingStream interface on the web platform. Note: If you want to control the stream-playing mode from the cloud by more criteria such as region and user, please contact ZEGO technical support for related configuration. In the past, the web did not support playing CDN plus.Now, we can play CDN plus on the IOS,Android,mac, window and web platforms.The [startPlayingStream] interface adds CDN_PLUS as a new ZegoResourceType on the web platform. interface. You can enable CDN_PLUS to play stream by yourself based on to the stream critirion. The CDN Plus stream-playing is a cost-effective method, because its quality is higher than CDN stream-playing with similar price. For related API, please refer to startPlayingStream 
Enhancements #
- 
Optimized for 1v1 pure RTC call scenarios Note: If you need to use this function, please contact ZEGO technical support. It is optimized for 1v1 call scenarios and is applicable to pure RTC scenarios. 
- 
Optimize space audio function The space audio capability is optimized, so that users can distinguish the front and rear audio sources, so as to achieve a better sense of immersion. 
- 
Optimize the situation of broken sound caused by excessive collection volume The AGC automatic gain control algorithm is optimized. When the acquisition volume is too large, it will not cause broken sound. 
- 
Optimize the audio and video experience in extremely weak networks The SDK optimizes the internal strategy. In the audio and video scenarios, it supports a minimum downlink of 50 kbps without congestion, ensuring a better experience in extremely weak networks. 
Bug Fixes #
- 
Fixed the problem that under some system versions of Mac M1 chip computers, the Web side enabled hardware encoding streaming, and used multiple SPS (Sequence Parameter Set) and PPS (Picture Parameter Set) output forms. 
- 
Fixed the problem that the logs currently being uploaded may crash when the network status is switched from having a network to having no network. 
- 
Fixed GetCallbackController non thread safety issue. 
- 
Fixed the problem that the SDK did not trigger [onPlayerRenderVideoFirstFrame] without a View. 
- 
Fixed the SDK crash caused by repeatedly starting and stopping the camera under Android system. 
- 
Fixed the problem of abnormal screen scaling when iOS, macOS, and windows use texture mode to render the screen. 
- 
Fixed the problem of iOS hardware decoding failure. For related API, please refer to enableHardwareDecoder 
- 
Fixed the problem that when streaming is stopped in the multi room mode, other people in the room cannot receive stream deletion notifications. 
- 
Fixed the possible crash of hardware decoding on iOS, macOS and Windows platforms. 
- 
Fixed the Android issue that [onNetworkQuality] not calling back 
Deleted #
- 
Three old versions of [ZegoScenario] scenarios have been abandoned Discard [General], [Communication] and [Live] three scenarios in the [ZegoScenario] scenario enumeration. 
- 
[setDebugVerbose],[setPlayStreamVideoLayer],[setBuiltInSpeakerOn],[onDeviceError],[loginMultiRoom] are deleted.