admin管理员组文章数量:1344235
I am currently trying to customize an HTML5 video player so that I can add a button that returns the current frame number.
Lets say I have a 30fps video that lasts 90 seconds. When I click on that button I want it to print me the number of the current frame. Is that possible?
I am currently trying to customize an HTML5 video player so that I can add a button that returns the current frame number.
Lets say I have a 30fps video that lasts 90 seconds. When I click on that button I want it to print me the number of the current frame. Is that possible?
Share Improve this question edited Aug 24, 2011 at 15:38 Paul D. Waite 99k57 gold badges203 silver badges271 bronze badges asked Aug 24, 2011 at 14:23 testtest 1111 gold badge1 silver badge3 bronze badges3 Answers
Reset to default 3I don't think there is a set standard framerate across browsers or any way of accessing the current frame out of the box with html5 video. What you could do though is use the television standard framerate of 29.97 frames per second and simply multiply that by the video's current time like so: (vid.currentTime * 29.97).toPrecision(6)
.
Here's a fiddle I set up demonstrating how to bind this to a button to get the current frame: http://jsfiddle/893aM/1/
I think you can use the following API for Webkit/Mozilla based browser:
Mozilla have implemented the following statistics into Firefox:
mozParsedFrames - number of frames that have been demuxed and extracted out of the media.
mozDecodedFrames - number of frames that have been decoded - converted into YCbCr.
mozPresentedFrames - number of frames that have been presented to the rendering pipeline for rendering - were "set as the current image".
mozPaintedFrames - number of frames which were presented to the rendering pipeline and ended up being painted on the screen. Note that if the video is not on screen (e.g. in another tab or scrolled off screen), this counter will not increase.
mozFrameDelay - the time delay between presenting the last frame and it being painted on screen (approximately).
Mozilla are also working on some of the statistics listed here.
Webkit have implemented these:
webkitAudioBytesDecoded - number of audio bytes that have been decoded.
webkitVideoBytesDecoded - number of video bytes that have been decoded.
webkitDecodedFrames - number of frames that have been demuxed and extracted out of the media.
webkitDroppedFrames - number of frames that were decoded but not displayed due to performance issues.
I still investigating the resolution on IE9...
Reference:http://wiki.whatwg/wiki/Video_Metrics
There is a decent Video Frame JS lib to work with frames https://github./X3TechnologyGroup/VideoFrame
It's very old question, but this may be useful for new readers.
Ref: Get frame numbers in HTML5 Video
本文标签: javascriptCan I get the number of the current frame in an HTML5 videoStack Overflow
版权声明:本文标题:javascript - Can I get the number of the current frame in an HTML5 video? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743697234a2523705.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论