html 5 video create

本文详细解析了HTML5视频播放的过程,从HTML构造站点创建元素到渲染阶段,包括视频元素的创建、属性设置、事件处理及播放控制等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

video
1.create videoElement
HTMLTreeBuilder::processStartTagForInBody
HTMLConstructionSite::insertHTMLElement(此时已经解析出了end)
cHTMLConstructionSite::createHTMLElement
HTMLElementFactory::createHTMLElement
HTMLElementFactory::videoConstructor
HTMLVideoElement::create

2.get element attribute
in "videoConstructor"
will call "MediaPlayer::isAvailable()" decide to create media or html
in " HTMLElementFactory::createHTMLElement"
will create different element according to the tag name.
3.in "processStartTagForInBody"
will enter different process according to the tag
4.in "HTMLConstructionSite::createHTMLElement"
after createHTMLElemen
will call element->setAttributeMap

3.from insert to attach to area
in "HTMLConstructionSite::insertHTMLElement"
a.will call "attachToCurrent(createHTMLElement(token)"
b.HTMLConstructionSite::attach
c.and then
HTMLVideoElement::attach()//depending on different Element
d.final will call
Element::attach()

e.

HTMLVideoElement::attach() //HTMLMediaElement::attach()

 

4.from attach to render area

a.in "HTMLMediaElement::attach()"

renderer()->updateFromElement()

b.RenderVideo::updateFromElement()
c1.RenderMedia::updateFromElement()

 "RenderMedia::updateControls"

"MediaControlElement::attach()"

c2.RenderMedia::updatePlayer();



5. event handle
a. for controller bar

code is

in "MediaControlMuteButtonElement::defaultEventHandler"

b. for video event
Node::dispatchEvent
HTMLMediaElement::defaultEventHandler
RenderMedia::forwardEvent

6.play controller
all in "MediaControlElements.cpp"
MediaControlMuteButtonElement
MediaControlPlayButtonElement,mediaElement()->togglePlayState()
HTMLMediaElement::togglePlayState()
MediaControlSeekButtonElement
MediaControlRewindButtonElement
MediaControlReturnToRealtimeButtonElement
MediaControlToggleClosedCaptionsButtonElement
MediaControlTimelineElement
MediaControlVolumeSliderElement
MediaControlFullscreenButtonElement

7.simple play procedure
a HTMLMediaElement.defaultEventHandler()
b RenderMedia.forwardEvent()
c MediaControlElement.defaultEventHandler();

8.
HTMLVideoElement::createRenderer
RenderVideo::RenderVideo

 

9.

video stop image

a.Button was drawn in:
RenderSkinMediaButton.cpp
b. call trace

VideoLayerAndroid::drawGL
VideoLayerAndroid::createPosterTexture
RenderSkinMediaButton::Draw
who call VideoLayerAndroid::drawGL?

I am finding out.
VideoLayerAndroid was in MediaPlayerPrivateAndroid.cpp

转载于:https://www.cnblogs.com/elfylin/archive/2012/04/06/2435411.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值