Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2012 Victor Carbune (victor@rosedu.org) | 2 * Copyright (C) 2012 Victor Carbune (victor@rosedu.org) |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| 11 * documentation and/or other materials provided with the distribution. | 11 * documentation and/or other materials provided with the distribution. |
| 12 * | 12 * |
| 13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY | 13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY |
| 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR | 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR |
| 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
| 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 24 */ | 24 */ |
| 25 | 25 |
| 26 #include "config.h" | 26 #include "config.h" |
| 27 | |
| 28 #include "core/rendering/RenderTextTrackCue.h" | 27 #include "core/rendering/RenderTextTrackCue.h" |
| 29 | 28 |
| 29 #include "RuntimeEnabledFeatures.h" | |
| 30 #include "core/html/track/TextTrackCue.h" | 30 #include "core/html/track/TextTrackCue.h" |
| 31 #include "core/html/track/TextTrackCueGeneric.h" | 31 #include "core/html/track/TextTrackCueGeneric.h" |
| 32 #include "core/rendering/RenderView.h" | 32 #include "core/rendering/RenderView.h" |
| 33 | 33 |
| 34 namespace WebCore { | 34 namespace WebCore { |
| 35 | 35 |
| 36 RenderTextTrackCue::RenderTextTrackCue(TextTrackCueBox* element) | 36 RenderTextTrackCue::RenderTextTrackCue(TextTrackCueBox* element) |
| 37 : RenderBlockFlow(element) | 37 : RenderBlockFlow(element) |
| 38 , m_cue(element->getCue()) | 38 , m_cue(element->getCue()) |
| 39 { | 39 { |
| 40 } | 40 } |
| 41 | 41 |
| 42 void RenderTextTrackCue::layout() | 42 void RenderTextTrackCue::layout() |
| 43 { | 43 { |
| 44 RenderBlockFlow::layout(); | 44 RenderBlockFlow::layout(); |
| 45 | 45 |
| 46 #if ENABLE(WEBVTT_REGIONS) | |
| 47 // If WebVTT Regions are used, the regular WebVTT layout algorithm is no | 46 // If WebVTT Regions are used, the regular WebVTT layout algorithm is no |
| 48 // longer necessary, since cues having the region parameter set do not have | 47 // longer necessary, since cues having the region parameter set do not have |
| 49 // any positioning parameters. Also, in this case, the regions themselves | 48 // any positioning parameters. Also, in this case, the regions themselves |
| 50 // have positioning information. | 49 // have positioning information. |
| 51 if (!m_cue->regionId().isEmpty()) | 50 if (RuntimeEnabledFeatures::webVTTRegionsEnabled() && !m_cue->regionId().isE mpty()) |
|
acolwell GONE FROM CHROMIUM
2013/10/04 19:48:20
nit: If regionId's can't be non-empty w/o the flag
vcarbune.chromium
2013/10/08 18:07:38
Done.
| |
| 52 return; | 51 return; |
| 53 #endif | |
| 54 | 52 |
| 55 LayoutStateMaintainer statePusher(view(), this, locationOffset(), hasTransfo rm() || hasReflection() || style()->isFlippedBlocksWritingMode()); | 53 LayoutStateMaintainer statePusher(view(), this, locationOffset(), hasTransfo rm() || hasReflection() || style()->isFlippedBlocksWritingMode()); |
| 56 | 54 |
| 57 if (m_cue->cueType()== TextTrackCue::WebVTT) { | 55 if (m_cue->cueType()== TextTrackCue::WebVTT) { |
| 58 if (m_cue->snapToLines()) | 56 if (m_cue->snapToLines()) |
| 59 repositionCueSnapToLinesSet(); | 57 repositionCueSnapToLinesSet(); |
| 60 else | 58 else |
| 61 repositionCueSnapToLinesNotSet(); | 59 repositionCueSnapToLinesNotSet(); |
| 62 } else | 60 } else |
| 63 repositionGenericCue(); | 61 repositionGenericCue(); |
| (...skipping 220 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 284 setX(right); | 282 setX(right); |
| 285 } | 283 } |
| 286 | 284 |
| 287 void RenderTextTrackCue::repositionCueSnapToLinesNotSet() | 285 void RenderTextTrackCue::repositionCueSnapToLinesNotSet() |
| 288 { | 286 { |
| 289 // FIXME: Implement overlapping detection when snap-to-lines is not set. htt p://wkb.ug/84296 | 287 // FIXME: Implement overlapping detection when snap-to-lines is not set. htt p://wkb.ug/84296 |
| 290 } | 288 } |
| 291 | 289 |
| 292 } // namespace WebCore | 290 } // namespace WebCore |
| 293 | 291 |
| OLD | NEW |