Closed Bug 704326 Opened 8 years ago Closed 6 years ago

Standalone audio files should have different style so they don't look awkward

Categories

(Toolkit :: Video/Audio Controls, defect)

defect
Not set

Tracking

()

VERIFIED FIXED
mozilla28
Tracking Status
firefox28 --- verified

People

(Reporter: jaws, Assigned: jaws)

References

(Depends on 1 open bug, )

Details

Attachments

(3 files, 8 obsolete files)

Attached image Screenshot of bug
Followup from bug 698940.

VideoDocument.cpp (which audio files use) creates a <video> element even when viewing <audio>.

<video> elements seem to have extra height to them by default.

See these examples:
data:text/html, <audio src="http://upload.wikimedia.org/wikipedia/commons/1/1d/Demo_chorus.ogg" controls />
data:text/html, <video src="http://upload.wikimedia.org/wikipedia/commons/1/1d/Demo_chorus.ogg" controls />

The default sizes for video elements is set here:
http://mxr.mozilla.org/mozilla-central/source/layout/generic/nsVideoFrame.cpp#577

We may be able to set the intrinsic height and width on standalone <video> elements if we determine them to be audio only.
These changes can be made from the video controls within toolkit.

In the file located at /toolkit/content/widgets/videocontrols.xml, at the point where we determine that the video is audio-only, we should set an intrinsic height and width on the video element.

We should also store the previous intrinsic height and width in case we later determine this element to actually be a video.

To check if the controls are being shown in a top-level video document, use the boolean document.mozSyntheticDocument. document.mozSyntheticDocument will be true if the video/audio file is being viewed in a top-level (standalone) document.
Component: Video/Audio → Video/Audio Controls
Product: Core → Toolkit
QA Contact: video.audio → video.audio
Whiteboard: [good first bug][mentor=jwein][lang=js]
Martijn: Would you like to work on this bug?
Jared: Yes, looks like something I can handle.
Assignee: nobody → mgerrits
Status: NEW → ASSIGNED
(In reply to Jared Wein [:jwein and :jaws] from comment #1)
> document.mozSyntheticDocument
> will be true if the video/audio file is being viewed in a top-level
> (standalone) document.

I think there is an error in my previous statement. document.mozSyntheticDocument won't say if the document is top-level. We'll need to continue to check document.mozSyntheticDocument and also check if window == top to know if it is a top-level document.
Martijn: Is there anything that I can do to help you out here?
Whiteboard: [good first bug][mentor=jwein][lang=js] → [good first bug][mentor=jaws][lang=js]
Assignee: mgerrits → dan
Updating the <video> size is going to be tricky since the bubble containing the current time position extends outside the control bar.

Instead, we can add have videocontrols.xml automatically add a class to <video> itself if it is currently being run inside a synthetic document and we find out that it is audio-only when we receive metadata.

From there, we can put CSS in the appropriate theme files to remove the box shadow from the <video> element.
Assignee: dan → jonathan
Summary: Standalone audio files should have an intrinsic size so they don't look awkward → Standalone audio files should have different so they don't look awkward
Summary: Standalone audio files should have different so they don't look awkward → Standalone audio files should have different style so they don't look awkward
I pushed this patch to try server yesterday. It's looking like everything is passing, with the exception of intermittent oranges:
 
https://tbpl.mozilla.org/?tree=Try&rev=6b238d181094
Attachment #631024 - Flags: review?(jaws)
Keywords: checkin-needed
Comment on attachment 631024 [details] [diff] [review]
Bug 704326 - Standalone audio files should have different style so they don't look awkward

Review of attachment 631024 [details] [diff] [review]:
-----------------------------------------------------------------

::: toolkit/content/widgets/videocontrols.xml
@@ +372,5 @@
>                          show = true;
>  
>                      // Explicitly hide the status fader if this
>                      // is audio only until bug 619421 is fixed.
> +                    if (this.isAudioOnly || (document.mozSyntheticDocument && window === window.top))

It looks like this will remove the status fader for top level videos.
Attachment #631024 - Flags: review?(jaws)
Comment on attachment 631593 [details] [diff] [review]
Status fader is no longer explicitly hidden for top-level synthetic a/v pages that contain what we know for sure is a video

Fixing bug 619421 would hopefully make these things less messy to handle. :(

Thanks for writing the patch, Jonathan. :)

I'll defer to Jared here.
Attachment #631593 - Flags: feedback?(fryn)
Comment on attachment 631593 [details] [diff] [review]
Status fader is no longer explicitly hidden for top-level synthetic a/v pages that contain what we know for sure is a video

Review of attachment 631593 [details] [diff] [review]:
-----------------------------------------------------------------

Can we just set the audio-only class when we are sure that the file is audio only? There are a couple places within videocontrols.xml that we speculate that it's audio only, but I don't want the throbber to flicker while we are determining the final state.

If all we do is remove the box-shadow, then I am OK with the size of the element being a little larger since there will be no visible outline of the element.

::: toolkit/themes/winstripe/global/TopLevelVideoDocument.css
@@ +5,5 @@
>  body {
>    background: #333 url();
>  }
>  
>  video {

We should probably just do |video:not(.audio-only)| for the selector here instead of adding a rule that overrides the default.

We also shouldn't worry about setting the width & height here. If we're a couple hundred pixels lower than centered I think that's fine. Having explicit width & height here will just add to maintenance costs in the future.
Attachment #631593 - Flags: review?(jaws)
(In reply to Jared Wein [:jaws] from comment #11)
> If all we do is remove the box-shadow, then I am OK with the size of the
> element being a little larger since there will be no visible outline of the
> element.

A black rectangle still appears while it's loading.
Oh ok, I still think we should only add the audio-only class when we have metadata. We can hide the throbber at that time too.
Attached patch Massively simplified patch (obsolete) — Splinter Review
The status fader hangs around for a little longer than the drop shadow now.  I'm not sure how to handle this.  Is there any way we could animate this?
Attachment #631593 - Attachment is obsolete: true
Attachment #631598 - Attachment is patch: true
Attachment #631598 - Flags: review?(jaws)
Comment on attachment 631598 [details] [diff] [review]
Massively simplified patch

The area currently marked by the box-shadow is clickable. Please disable this when removing the shadow.
Attachment #631598 - Flags: review-
Attachment #631598 - Flags: review?(jaws)
Comment on attachment 631598 [details] [diff] [review]
Massively simplified patch

Review of attachment 631598 [details] [diff] [review]:
-----------------------------------------------------------------

::: toolkit/content/widgets/videocontrols.xml
@@ +531,5 @@
>                                  (this.video.videoWidth == 0 || this.video.videoHeight == 0)) {
>                                  this.isAudioOnly = true;
>                                  this.clickToPlay.hidden = true;
>                                  this.startFadeIn(this.controlBar);
> +                                if (document.mozSyntheticDocument && window === window.top)

This can just be |window == top|, no need to preface top with |window.| since it is implied.
Assignee: hello → nobody
Status: ASSIGNED → NEW
i am new, how should i proceed to fix this bug?
(In reply to Nikhil Johny from comment #17)
> i am new, how should i proceed to fix this bug?

You can use Johnathan's patch as a starting point. Comment #15 and #16 need to be addressed. You can address #15 by tweaking the code at http://mxr.mozilla.org/mozilla-central/source/toolkit/content/widgets/videocontrols.xml#1041 to return early if the video has the "audio-only" class.
where do we notice the bug while using firefox, i mean when do we encounter it?
(In reply to Nikhil Johny from comment #19)
> where do we notice the bug while using firefox, i mean when do we encounter
> it?

You can see the bug when you visit http://upload.wikimedia.org/wikipedia/commons/1/1d/Demo_chorus.ogg
Assignee: nobody → nikhiljohny
Status: NEW → ASSIGNED
Can you confirm that you're still working on this bug?
Flags: needinfo?(nikhiljohny)
Attached patch new patch (obsolete) — Splinter Review
sorry for the delay, yes i am still working on this bug. there is a black box that appears during loading, i dont know what is causing it do so. the new patch solves both problems mentioned in comment 15 and 16. please let me know if there is something else that i need to do to solve this bug.
Attachment #742711 - Flags: review?(jaws)
Flags: needinfo?(nikhiljohny)
Comment on attachment 742711 [details] [diff] [review]
new patch

>diff --git a/toolkit/themes/winstripe/global/media/TopLevelVideoDocument.css b/toolkit/themes/winstripe/global/media/TopLevelVideoDocument.css
>--- a/toolkit/themes/winstripe/global/media/TopLevelVideoDocument.css
>+++ b/toolkit/themes/winstripe/global/media/TopLevelVideoDocument.css
>-video {
>+video:not(.audio-only) {
>    box-shadow: 0 0 15px #000;
> }

The /toolkit/themes/winstripe directory no longer exists. You'll need to update your local tree and rebase this patch. winstripe has changed to windows, pinstripe -> osx, and gnomestripe -> linux.

You'll also need to include patches that update the relevant TopLevelVideoDocument.css files for the other platforms.

>diff --git a/toolkit/content/widgets/videocontrols.xml b/toolkit/content/widgets/videocontrols.xml
>--- a/toolkit/content/widgets/videocontrols.xml
>+++ b/toolkit/content/widgets/videocontrols.xml
>                                 this.startFadeIn(this.controlBar);
>+                                if (document.mozSyntheticDocument && window === top)
>+                                    this.video.classList.add("audio-only");
>                             }

How did this work for you? I tried testing it today and referencing 'top' like this wasn't working for me. I had to prefix it with 'window.', but I'm not sure why.

>                 clickToPlayClickHandler : function(e) {	    
>+		     if(this.getElementByClass("audio-only"))
>+                        return;
>                     if (e.button != 0 || this.hasError())

Did you test this patch before uploading? The getElementByClass function doesn't exist. You should use this.video.classList.contains() here.
Attachment #742711 - Flags: review?(jaws) → review-
Nikhil, are you still working on this?
Flags: needinfo?(nikhiljohny)
sorry, i am not currently working on this bug, my firefox build doesn't seem to be working at the moment. sorry again for the late reply.
Flags: needinfo?(nikhiljohny)
Ok, let me know if you can pick this back up. If you get latest from mozilla-central and delete your object directory, your build should complete successfully.

I'll reopen the bug now so someone else can work on it.
Assignee: nikhiljohny → nobody
Status: ASSIGNED → NEW
I would like to work on this bug. Do i Need to carry forward any patch or work from scratch ? Also I understood comment #16 but not comment #18. Tweaking code in what form ?
Whiteboard: [good first bug][mentor=jaws][lang=js]
This bug turned out to be more complicated than I had thought.

This patch implements the desired solution, but document.mozSyntheticDocument is ChromeOnly and so the XBL binding can't check the value of it. This means that we would set the "audio-only" class on elements that aren't in standalone documents, which isn't acceptable.
Assignee: nobody → jaws
Attachment #631598 - Attachment is obsolete: true
Attachment #742711 - Attachment is obsolete: true
Status: NEW → ASSIGNED
Attached patch Patch (obsolete) — Splinter Review
I worked around mozSyntheticDocument being chrome-only by setting a class on the body to state if the document is synthetic. I only applied the class to the body element if the document is also top-level, so that content doesn't start depending on the presence of this class name for subframes, plus we don't need it for subframes anyways.
Attachment #813824 - Attachment is obsolete: true
Attachment #813857 - Flags: review?(dao)
Attachment #813857 - Flags: review?(Ms2ger)
Maybe we should make it work in xbl?
Flags: needinfo?(bzbarsky)
That seems quite reasonable to me.
Flags: needinfo?(bzbarsky)
Attached patch Patch (obsolete) — Splinter Review
Made mozSyntheticDocument available to XBL. I like this approach much better.
Attachment #813857 - Attachment is obsolete: true
Attachment #813857 - Flags: review?(dao)
Attachment #813857 - Flags: review?(Ms2ger)
Attachment #813942 - Flags: review?(dao)
Attachment #813942 - Flags: review?(bobbyholley+bmo)
Attachment #813942 - Flags: review?(bobbyholley+bmo) → review?(bugs)
Attachment #813942 - Flags: review?(bugs) → review+
Attachment #813942 - Flags: review?(dolske)
Comment on attachment 813942 [details] [diff] [review]
Patch

Review of attachment 813942 [details] [diff] [review]:
-----------------------------------------------------------------

r+, though I'd like to know why the toggleFullscreen() change is needed.

::: toolkit/content/widgets/videocontrols.xml
@@ +355,5 @@
> +                    if (val)
> +                        this.video.classList.add("audio-only");
> +                    else
> +                        this.video.classList.remove("audio-only");
> +                },

This somehow feels a bit gross, but I don't have a simpler idea at hand.

@@ +1051,5 @@
>                  },
>  
>                  toggleFullscreen : function () {
> +                    if (this.isAudioOnly)
> +                        return;

I feel like I've asked about this before, but don't see any previous reviews here... Why this change? If it's audio-only, we should be making the button/menu hidden, not make it non-functional.

@@ +1081,5 @@
>                      this.setFullscreenButtonState();
>                  },
>  
>                  clickToPlayClickHandler : function(e) {
> +                    if (e.button != 0 || this.isAudioOnly)

Ditto.

::: toolkit/themes/osx/global/media/TopLevelVideoDocument.css
@@ +10,1 @@
>    box-shadow: 0 0 15px #000;

'Twould be nice to keep the shadow. Perhaps the new audioOnly setter could simply set video.height = $CONTROL_BAR_HEIGHT? I was a bit wary of needing to watch for media changes and resetting it, but I suppose that can't really happen for mediadocuments, since there's no other content script running. Fine either way, I suppose.
Attachment #813942 - Flags: review?(dolske)
Attachment #813942 - Flags: review?(dao)
Attachment #813942 - Flags: review+
(In reply to Justin Dolske [:Dolske] from comment #33)
> Comment on attachment 813942 [details] [diff] [review]
> Patch
> 
> Review of attachment 813942 [details] [diff] [review]:
> -----------------------------------------------------------------
> 
> r+, though I'd like to know why the toggleFullscreen() change is needed.
> 
> ::: toolkit/content/widgets/videocontrols.xml
> @@ +355,5 @@
> > +                    if (val)
> > +                        this.video.classList.add("audio-only");
> > +                    else
> > +                        this.video.classList.remove("audio-only");
> > +                },
> 
> This somehow feels a bit gross, but I don't have a simpler idea at hand.

How about this.video.classList.toggle("audio-only", !!val)?
You don't even need the "!!" bit, do you?  The last arg is coerced to a boolean anyway.
Attached patch Alternative patch (obsolete) — Splinter Review
This patch implements the recommendation from comment #33 by setting the controls height and width to the minimum size required.

The minimum width is probably too narrow for most use-cases. It's only 143 pixels wide and it doesn't leave much granularity for seeking in audio files, so it may be better to introduce a standalone-audio-minimum-width constant around 400px.
Attachment #823565 - Flags: review?(dolske)
Comment on attachment 823565 [details] [diff] [review]
Alternative patch

Review of attachment 823565 [details] [diff] [review]:
-----------------------------------------------------------------

::: toolkit/content/widgets/videocontrols.xml
@@ +346,5 @@
> +                    let win = doc.defaultView;
> +                    if (win !== win.top || !doc.mozSyntheticDocument)
> +                        return;
> +                    this.video.style.height = this._controlBarHeight + "px";
> +                    this.video.style.width = this._minWidthAllControls + "px";

Why set it to the minimum width?

this.video.style.width = "66%" would seem fine?
Attachment #823565 - Flags: review?(dolske)
Switched to a width of 66%.

Also fixed the volume mouse in/out so it doesn't show the volume slider on standalone audio documents. This is consistent with bug 502892 since we are now reducing the height of the element guaranteeing that the volume slider will be outside of the bounding box.
Attachment #823565 - Attachment is obsolete: true
Attachment #823718 - Flags: review?(dolske)
Attachment #823718 - Flags: review?(dolske) → review+
Attachment #813942 - Attachment is obsolete: true
(In reply to Jared Wein [:jaws] from comment #38)
> Created attachment 823718 [details] [diff] [review]
> Alternative patch v1.1
> 
> Switched to a width of 66%.
> 
> Also fixed the volume mouse in/out so it doesn't show the volume slider on
> standalone audio documents. This is consistent with bug 502892 since we are
> now reducing the height of the element guaranteeing that the volume slider
> will be outside of the bounding box.

So this patch makes it so that you can't adjust the volume for standalone audio files anymore? This cure sounds worse than the disease (i.e. the pointless box shadow).
https://hg.mozilla.org/mozilla-central/rev/f9a5108cf2b2
Status: ASSIGNED → RESOLVED
Closed: 6 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla28
Depends on: 936695
Depends on: 937429
Whiteboard: [good first verify]
This has caused a regression, see bug 974910.
Whiteboard: [good first verify]
Flagging for verification, the regression in comment 42 notwithstanding.
Keywords: verifyme
Attached image Firefox 28 beta 8.png
Verified as fixed with Firefox 28 beta 8 on: Win 8 x64, Ubuntu 12.04 x86, Mac OS X 10.8.5.

More details in the attached screenshot.
Status: RESOLVED → VERIFIED
Keywords: verifyme
Depends on: 1222374
Depends on: 1222669
No longer depends on: 1222374
You need to log in before you can comment on or make changes to this bug.