html 5 video create

本文详细介绍了视频元素从创建、属性设置到渲染过程的实现机制,包括视频的创建、获取属性、处理开始标签、插入元素、创建渲染器、播放控制器等关键步骤。同时,阐述了事件处理和停止图像生成的原理。
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
MediaLayer::drawGL

LayerAndroid::drawChildrenGL
VideoLayerAndroid::drawGL//VideoLayerAndroid be child of LayerAndroid
VideoLayerAndroid::createPosterTexture

RenderSkinMediaButton::Draw

c

MediaLayer--->LayerAndroid
VideoLayerAndroid--->LayerAndroid




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值