-
Notifications
You must be signed in to change notification settings - Fork 6.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
captureLargeVideoScreenshot not working properly #7942
Comments
I am able to repro the case when the remote or local video is muted, will add a fix for that but this shouldn't happen when the remote video is not muted. |
Hello, I did retest with mic and cam enabled on both sides and I wasn´t be able to capture screen. Imediately when one attende leave room, it works properly... So Iam not sure if problem is only within on/off cam... |
@network12, can you try to reproduce it with this example - https://github.com/jitsi/jitsi-meet/blob/master/doc/examples/api.html when the video is not muted ? |
… track attached. Participants that join video muted do not have video tracks attached. Fixes jitsi#7942.
You are absolutely right - when I setup parentNode: undefined - I am finaly able to do screenshot! |
Hello, I have new knowledge regarding behavior of this issue - Issue doesn´t depend on number of attende in the room or on parentNode param, but on fact which video stream do you have on your screen. Eg if you have participant´s video, no way to get screenshot, if you have tile view, no way to get screenshot. But if you have own camera on the screen, everything works flawless... |
captureLargeVideoScreenshot takes a screenshot of the participant on the large video container, i.e., whatever participant is on the stage not in tile view. The error that you are getting when the remote participant is muted should be fixed after the above mentioned PR gets merged. |
Hello, |
Thank you for the update, re-opening the issue since I am reproduce the issue on Firefox. |
jitsi-meet 1.0.4628 ----------- * Merge pull request #8352 from jitsi/tavram/allow-tileview-disabling * feat(jaas) allow tile view to be disabled * Merge pull request #8356 from jitsi/tavram/top * feat(jaas) add config for displaying participants stats and conference subject * i18n: update Occitan language (#8346) * fix(JitsiStreamPresenterEffect): frozen on Safari * feat: Skip p2p when the participant is jigasi. * Merge pull request #8354 from jitsi/tavram/fix-filmstrip * fix(filmstrip) fix button not considering interface config settings * fix(ios) fix drag handle not rendering with latest react-native-svg * chore(deps) update react-native-svg to latest * fix(ios) fix crash on startup on iOS 11 * chore(deps) lib-jitsi-meet@latest * chore(android,ios) raise versions * feat: emit raise hand event to external API (#8312) * fix(setAudioOutputDeviceId): check if supported * fix: Process pre-existing participants properties. * fix: Fixes showing phone icon for jigasi participants. * fixed admin check for token verification * Consistent formatting/indentation of files in ./doc (#8178) * fix(jitsi-meet-web-config.postinst) allow cert and key pre-selection (#8319) * fix(lang) update zhCN translation * add systemd to letsencrypt installer (#8289) * full support persian language (#8300) Fixes #8299 * fix(lang) update German translation * fix(tile-view) allow watermark to be covered * fix(tile-view) reduce margins, take 2 * fix(ios,fastlane) adjust scheme name after rename * fix(android) avoid crashes if view is null * feat(analytics) unify Amplitude handlers across web and mobile * feat(stats) add stats for mobile * Merge pull request #8293 from jitsi/tavram/update-jaas-rec * fix(jaas) update recording label and hide option for jaas users * lang: Updating and uniforming italian translation (#8288) * Updated Galician translation * feat(analytics): Adds metric for SS issues. * fix(password): Fix add password button on Safari * fix(branding): Use config url for dynamic branding * fix(script) add commits list to update LJM message * feat(ios) rename SDK target to JitsiMeetSDK * fix: Skip sending multiple times disco-info to jicofo. * fix(welcome-page) fix .insecure-room-name-warning margin * fix(main-ko) add keyboardShortcuts videoQuality (#8264) * fix(main-ko.json) Update some korean spelling & words (#8253) * lang: update French translation (#7725) * feat: Update spanish translation (#8023) * Update main-fr.json (#8114) * Etherpad on join (#8212) * Update main-ptBR.json * Update main-ru.json * Fix #8095 (#8101) * languages-ka.json * Update main-sv.json * lang: Update Arabic translation * Update main-de.json * lang:New translation malayalam(ml-in) * Added missing language malayalam(ml) (#7732) * Update main-zhCN.json,languages-zhCN.json. * fix(remote-control) skip on mobile * chore(ios) remove references to no longer used files * fix(ios) fix joining a meeting when the app was closed * ref(remote-control): Use React/Redux. * fix(conference.js): 2 tracks of the same media type * fix: Skip sending unnecessary signalling for raise hand. * feat(ios) added ability to use an external CXProvider and CXCallController * chore(deps) update react-native-webview * chore(deps): bump react-native-webview from 10.9.0 to 11.0.0 * fix(LoginDialog) added missing double quotes * fix: Start p2p only when we have received all presences. * fix(video):Always show avatar if video is inactive * feat(tile-view) optimize for less margins * fix: the user placeholder translation issue #8219 (#8233) * feat: Update the Czech translation (#8133) * fix: Fixes VP9 support on Chrome. chore(deps) lib-jitsi-meet@latest * feat(analytics): Add tenant. * Merge pull request #8230 from jitsi/tavram/revert-fixroom * Revert "fix(external_api) replace special chars in roomName before constructing URL" * fix: Fixes detecting websocket disconnect by using xmpp pings. * feat: Exposes a method for checking is remote track received and played/testing. (#8186) * feat: Add option to force pc to use turn relay candidates. Helps with testing turn relay cases. * feat(ConferenceTimer): Add config option to hide. * doc: Add docs for enableLipSync. (#8195) * Remove conference-wide RTX/REMB/TCC/opus-red options. (#8194) * fix(lang) fix a few typos in Italian translation * fix(config) remove openBridgeChannel * fix(tracks): Do not add a second audio track. * cleanup: Remove the startBitrate option. (#8193) * cleanup: Remove obsolete config option. * cleanup: Remove unused code. * feat: Remove the min-participants config. * fix(lang) typo * ref: Remove unused option from whitelist. * chore(rn) raise SDK and app versions * fix(android) set stream type hardware buttons should control * fix(android) reset audio route after audio focus was lost * fix(android) use modern API for requesting audio focus * fix(lang) update Italian translation * fix(android) disables the RNWebViewFileProvider * chore(popups): Move popup configs to electron-utils * fix(TPC): Do not scale down desktop track in p2p/non-simulcast cases. chore(deps) lib-jitsi-meet@latest * fix(deps) update logger * feat(rn) switch to XCFramework and WebRTC M87 * fix(connection-status): action * fix(avatar) revert back to defaulting to Gravatar * feat: Makes it possible to hide the "Save Logs" link. (#8143) * Make jwt accept boolean values for features * feat: Include "Latvian" in the languages list (#8129) * fix(lastN): select screenshare endpoint always when auto pinning. When trying to auto pin screenshare, always select the endpoint even though it happens to be the large video participant in redux. The auto pin screenshare logic kicks in after the track is added. If the screenshare endpoint is not among the forwarded endpoints from the bridge, it needs to be selected again. * fix(lastN): Do not override channelLastN value. If limitLastN values are specified and channelLastN < limitLastN, configure channelLastN on the conference. * fix: Fixes 404 page link when base is used. * feat(avatar) add ability to customize Gravatar base URL * fix(UI): Add method for returning the video type of remote participants. This is needed for the torture clients to determine the video type for the remote participants when testing desktop share. * Merge pull request #8110 from jitsi/tavram/fix-double-slash * fix(jaas) replace only the first slash in a pathname * feat: Skips the default tile view when jibri is loading. * fix(screenshare): do not reconfigure encodings for simulcast SS chore(deps) lib-jitsi-meet@latest * fix(chat) stop using nicknames * Updates kick, fixes it after 4b8aae90. * Fix get subdomain function * fix(Toolbox) Maintain overflow button visible at all times * fix(welcome_page): Fix background image url path * fix(safari): Ensure simulcast stream resolutions don't change. Safari 14.1 has a bug where it returns 720p for every simulcast stream when RTCRtpSender.getParameters is called even though the stream resolutions are different. By using the encodings config used when source was added, on every RTCRtpSender.setParameters call, we ensure that simulcast stream resolutions don't change. chore(deps) lib-jitsi-meet@latest * fix(welcome_page): Add max width to welcome card * fix(vpaas): Make user media permission message more generic * fix(lang) update Japanese translations * feat: Drops filmStripOnly mode. (#8074) * fix: Fix module allowners and moderated rooms. * fix(password) set input type to "password" * feat(rn) add mute everyone / (else) capabilities * fix(welcome_page): Update header to latest design & use generic key name * feat(external_api) drop support for noSSL option * chore(deps) lib-jitsi-meet@latest * fix(lang) update Russian translation * fix(build) fix webpack-dev-server on Windows * fix(external_api) replace special chars in roomName before constructing URL * fix(lang) update Italian translation * fix(lang) update Italian translation * Merge pull request #8003 from jitsi/tavram/invite-url * fix(lang) update German translation * fix(lang) update for Occitan * fix(lang) improve Spanish translations * fix(lang) fix rendering accented characters in Italian * feat(BrowserCapabilities) drop supportsVideo * ref(presenter): refactor the desktop resize logic for presenter. * fix(welcome_page): Fix mobile version * Merge pull request #8053 from jitsi/fix-calendar-svg * fix(CalendarList): calendar.svg path. * fix(screenshare): Fixes for the blurry desktop share issues. Do not resize the desktop share to 720p by default when the desktop track resolution is higher than 720p. This is causing bluriness when presenter is turned on. Remove the 'detail' contentHint setting for the desktop+presenter canvas stream as it forcing chrome to send only 5 fps stream for high resolution desktop tracks. Move the desktop resizing logic behind a config.js option - videoQuality.resizeDesktopForPresenter. * fix: Optimizes hot paths in prosody modules, string comparisons. * feat: Drop enableUserRolesBasedOnToken and isGuest. * feat: Show cc button for ongoing transcribed meetings for guests * feat: Drop lockRoomGuestEnabled. * feat: Drop HIDE_KICK_BUTTON_FOR_GUESTS setting. * feat: Drop buttons tooltips specific to guests. * fix: Hide copy password if it is not available. Fixes #7783 * feat: Profile tab does not depend on isGuest. * feat: Drops SHOW_JITSI_WATERMARK_FOR_GUESTS and SHOW_WATERMARK_FOR_GUESTS. * fix: Show livestream button only for moderators. * Stringify boolean values from jwt user context * feat(welcome_page): Redesign welcome page * Merge pull request #8039 from jitsi/tavram/fix-double-slash * fix(jaas) fix double slash for branded invite urls * fix: Prosody modules - drop unused and duplicate code and drop chatty debug statements (#8027) * chore(deps) amplitude 7.3.1 * fix(rn, screen-sharing) don't render own screen-share in large view * feat(android) add screen-sharing support * allow wildcard in token issuer verification * fix(conference) remove no longer needed code * feat(misc) automatically assign feature-request tag to issues * feat: Reduce pings and adds xmpp ping config. * ref(thumbnail): mutedWhileDisconnected -> redux * feat(prejoin): Add name from jwt to prejoin screen * fix: Avoids storing lobby room instance in the main room object. * feat(vpaas): Track vpaas conference join * ref(thumbnail): use connectionStatus from redux. * fix(lang): update fr translation * fix(lang) update ptBR translation * fix(vpaas) fix invite url flicker for jaas users * fix(StatusIndicators): Improve isScreenSharing check * ref(StatusIndicators): isScreenSharing -> redux. * ref(StatusIndicators): Use audio muted from redux. * fix(logging): Add more details to onerror and onunhandledrejection errors. * fix(screenshare): bring back 'x-google-flag:conference' flag in remote description for SS. chore(deps) lib-jitsi-meet@latest * s/isLocalVideoTrackMuted/isLocalCameraTrackMuted/ * ref(StatusIndicators): Use video muted from redux. * fix(video-quality): set lastN to 1 when screenshare is added to call in audio-only mode. This fixes an issue where lastN is not bumped to 1 on an audio-only client when a screenshare source is added to the call. * fix(deviceChange):Dont create video track if muted * fix(conference): start muted values on initial GUM * fix(iFrame): capturScreenshot - check if the remote participant has a track attached. Participants that join video muted do not have video tracks attached. Fixes jitsi/jitsi-meet#7942. * fix(pwa) move manifest to the root * fix(pwa) remove no longer used file * fix(xmpp): Update previd value when trying to resume connection. lib-jitsi-meet@latest * fix(android) fix runtime WebRTC issue * fix(prejoin): Fix moving content when device status bar is toggled * fix(pwa) fix PWA worker script origin * fix(pwa) fix auto-generated TWA icons * fix(pwa) fix loading the service worker * feat(iFrame): Add recording options for RTMP streaming. Add methods for start/stop recording in addition to the commands that we already have. * fix: speakerstats_component, attempt to index (a nil value) * chore(deps) run npm audit fix * Merge pull request #7938 from jitsi/tavram/twa * feat(pwa) update TWA Android project * feat(pwa) do not display chrome extension banner for TWA * chore(deps) lib-jitsi-meet@latest * feat(pwa) add fastlane integration for building TWA APK * feat(pwa) update mask icon * fix(thumbnail): cleanup unused hover properties. * fix(avatar) remove participant's "avatarID" * fix(pwa) move logic for registering pwa worker * fix(pwa) remove window.load event handler for pwa registrator * fix(flow): ignore contentHint * feat(presenter): apply 'text' contentHint * fix(pwa) bypass loading in electron. ensure same origin with registrator * fix(UI): Do not re-compute the container width when chat window is closed. Since the external API now sets preferredWidth/preferredHeight for resizing the large video, we don't need to add chat width to the computed window width when the chat window is closed. Fixes jitsi/jitsi-meet#7889 * chore(deps) update Olm to 3.2.1 * fix(pwa) improve upon pwa specs * Merge pull request #7904 from saghul/preload-avatars-refer * fix(avatars) refactor preloading * fix(rn) use a RN-friendly URL polyfill * fix(rejoin) fix adding track parameters to rejoin URL * chore(git) update gitignore * feat(pwa) update generated Android project * feat(pwa) move twa manifest to twa/ * feat(pwa) update twa manifest with new (old) colors and manifest path * feat(pwa) use current icons * feat(pwa) add TWA generated files * feat(mobile) add splash screen * fix(prejoin) guard case for locationUrl being falsy in prejoin screen * fix(deps) update react-native to fix iOS 14 icons * Revert "fix(ios) fix not rendering images on iOS 14" * feat(prejoin): handle disabled precall test. ****************************************************************** lib-jitsi-meet ----------- * feat: Skip p2p when the participant is jigasi. * feat: Skips using disco-info for features. (#1450) * sdp: improve sdp matching for simulcast lines (#1452) * sdp: add missing colon to findLines calls (#1447) * fix(stats) fix parsing codec in new stats * feat(stats) migrate RN to new stats * fix: Skip sending multiple times disco-info to jicofo. * build(deps): bump ini from 1.3.5 to 1.3.7 * fix: Maybe start p2p only when we have received all presences. * fix: Implement the encodings workaround only on Safari. Explicitly check if all the encodings report the same scaleResolutionDownBy value before trying to ensure they match the expected values. This makes Chrome VP9 work again. * fix: Fixes ping options usage. * fix(XMPP): Get the correct domain for XMPP ping. * fix: Updates ping logic around detecting xmpp activity. * fix: add `getParticipants` to JitsiConference docs * feat: Add option to force pc to use turn relay candidates. * fix: Always query the main domain for features. Fixes jitsi/jitsi-meet#8173 (#1428) * Remove conference-wide RTX/REMB/TCC/opus-red options. (#1423) * devicesReceived array should not be modified * ref: Always use a websocket if offered, remove the openSctp option. (#1426) * ref: Remove the enableLipSync conference-wide option (moved to jicofo). (#1425) * cleanup: Remove the octo config. (#1421) * ref: Remove the useRoomAsSharedDocumentName option (moved to jicofo). (#1424) * Remove obsolete code (#1420) * feat: Remove the min-participants config. (#1418) * ref(JitsiConference): allow only 1 track per media type * fix(TPC): Do not scale down desktop track in p2p mdoe. * fix(deps) update logger to 1.0.0 * feat: Log the jvb version. (#1410) * fix(last-n): Do not let Jicofo initialize last-n for the whole conference. The plan is to move the lastNLimits logic to bridge. The clients will be able to override(lower) the bridge limits through the bridge channel only. Also, this lets us configure last-n per receiver and not set the last-n value for the whole conference the way Jicofo sets it currently. * fix(TPC): do not update encodings for simulcast desktop tracks. Fixes jitsi/jitsi-meet#8094. * Fix typos * Fix typos on comments * fix(TPC): Do not update encodings for non-simulcast sources. * feat(BrowserCapabilities) drop supportsVideo * feat(RTC) bump minimum supported Chromium version to 72 * fix(TPC): Ensure encodings resolutions match configured values. On every call to RTCRtpSender.setParameters(), ensure that the resolution configured for the encoding matches that of the value configured on the RTCRtpSender when the source was added to the peerconnection. This should prevent us from overriding the default values if the browser returns erroneous values when RTCRtpSender.getParameters is used for getting the encodings info. This fixes the issue on recent versions of Safari where the 'scaleResolutionDownBy' value comes back as 1 for all encodings even though the encoding resolution is different from the stream capture resolution. * fix(video-quality): Fix p2p desktop share quality. In p2p mode, 'scaleResolutionDownBy' is used for downscaling a stream when needed, i.e. when the user receives a receive constraint of 360p because the other participant is in tile view. When desktop share is started, the encoding config has to be scaled back up so that the other participant starts receiving HD resolution for the share as desktop shares are autopinned. Therefore, encodings have to enabled/disabled for desktop shares as well. Earlier it was done only for camera tracks. * fix(stun) update default list of STUN servers * feat: Reduce pings and adds xmpp ping config (#1389) * feat(rn) support getDisplayMedia * fix(rn) release audioVideo stream after creating new MediaStream * fix(audio-recorder) remove no longer needed code * (feat) e2ee: sign and verify frames (#1373) * fix(RTC): Fix log formatting * fix(video-quality): do not disable encodings when sender constraints are not configured on the conference. Fixes jitsi/lib-jitsi-meet#1333 in applications that use lib-jitsi-meet and do not have layer suspension enabled. * fix: Add the x-google-conference flag on RD when screensharing. Add the conference flag back since the bridge is able to handle the case where more than 1 temporal layers are received even when only 1 ssrc is signaled. * fix(xmpp): Update previd value when trying to resume connection. * Merge pull request #1379 from quitrk/tavram/twa * feat(twa) add TWA check function * Clean up logging and formatting. (#1378) * docs for setLocalParticipantProperty, PARTICIPANT_PROPERTY_CHANGED added. (#1375) * Add missing options to docs and improve naming (#1354) * fix(JingleSession) log initialization error * feat(e2ee) log Olm version
* commit '1648e4b407c5a7136657eca65d0ee09ebc982061': (118 commits) ref(thumbnail): mutedWhileDisconnected -> redux feat(prejoin): Add name from jwt to prejoin screen fix: Avoids storing lobby room instance in the main room object. feat(vpaas): Track vpaas conference join ref(thumbnail): use connectionStatus from redux. fix(lang): update fr translation fix(lang) update ptBR translation fix(StatusIndicators): Improve isScreenSharing check ref(StatusIndicators): isScreenSharing -> redux. ref(StatusIndicators): Use audio muted from redux. fix(logging): Add more details to onerror and onunhandledrejection errors. fix(screenshare): bring back 'x-google-flag:conference' flag in remote description for SS. chore(deps) lib-jitsi-meet@latest s/isLocalVideoTrackMuted/isLocalCameraTrackMuted/ ref(StatusIndicators): Use video muted from redux. fix(video-quality): set lastN to 1 when screenshare is added to call in audio-only mode. This fixes an issue where lastN is not bumped to 1 on an audio-only client when a screenshare source is added to the call. fix(deviceChange):Dont create video track if muted fix(conference): start muted values on initial GUM fix(iFrame): capturScreenshot - check if the remote participant has a track attached. Participants that join video muted do not have video tracks attached. Fixes jitsi#7942. fix(pwa) move manifest to the root fix(pwa) remove no longer used file ... # Conflicts: # android/build.gradle # android/sdk/build.gradle # android/sdk/src/main/java/org/jitsi/meet/sdk/ReactInstanceManagerHolder.java # config.js # css/_lobby.scss # ios/Podfile.lock # modules/API/API.js # modules/UI/UI.js # modules/UI/shared_video/SharedVideoThumb.js # modules/UI/videolayout/LargeVideoManager.js # modules/UI/videolayout/LocalVideo.js # modules/UI/videolayout/RemoteVideo.js # modules/UI/videolayout/SmallVideo.js # modules/UI/videolayout/VideoLayout.js # package-lock.json # package.json # react/features/app/actions.js # react/features/base/avatar/components/Avatar.js # react/features/base/participants/middleware.js # react/features/base/participants/preloadImage.web.js # react/features/base/premeeting/components/web/ActionButton.js # react/features/base/premeeting/components/web/ConnectionStatus.js # react/features/base/premeeting/components/web/PreMeetingScreen.js # react/features/base/premeeting/components/web/Preview.js # react/features/base/react/components/web/Linkify.js # react/features/calendar-sync/components/CalendarListContent.native.js # react/features/chrome-extension-banner/components/ChromeExtensionBanner.web.js # react/features/conference/functions.js # react/features/connection-indicator/components/web/ConnectionIndicator.js # react/features/filmstrip/components/web/StatusIndicators.js # react/features/invite/components/add-people-dialog/web/AddPeopleDialog.js # react/features/large-video/actions.web.js # react/features/lobby/components/web/LobbyScreen.js # react/features/lobby/middleware.js # react/features/remote-video-menu/components/web/RemoteVideoMenuTriggerButton.js # react/features/toolbox/components/web/Toolbox.js # react/features/video-quality/components/OverflowMenuVideoQualityItem.web.js # react/features/video-quality/components/VideoQualitySlider.web.js # react/features/video-quality/middleware.js
Hello,
we have own instance of Jitsi meet (Ubuntu 20.04 LTS) and we want to use api call captureLargeVideoScreenshot as is described in this handbook: https://jitsi.github.io/handbook/docs/dev-guide/dev-guide-iframe
So we have setuped this workload:
When I am alone in room with enabled camera and mic - everything is working properly.
But when someone join the same room, after click on button, call fail:
Same issue is in situation when I am alone without enabled cam.
The text was updated successfully, but these errors were encountered: