summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormirandac@chromium.org <mirandac@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-05-23 01:01:57 +0000
committermirandac@chromium.org <mirandac@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-05-23 01:01:57 +0000
commit920603a234542c6fa484bb00ae2e8e20e7ffabbc (patch)
tree0c05e474aed055d4af0dbfc11fab06251e1e3add
parentfea0d343e62f931872a0f394bdc81fe738b5582b (diff)
downloadchromium_src-920603a234542c6fa484bb00ae2e8e20e7ffabbc.zip
chromium_src-920603a234542c6fa484bb00ae2e8e20e7ffabbc.tar.gz
chromium_src-920603a234542c6fa484bb00ae2e8e20e7ffabbc.tar.bz2
Forces window to show and hide with native system calls at the beginning
and end of animation. This allows the system bubble to hide and display in systems that don't respect opacity, such as the Parallels desktop. BUG= http://crbug.com/622 TEST=Start Chrome on a system running in a Parallels window. Hover over a status bubble, and move mouse away. Status bubble should disappear. (NOTE: This was reviewed at http://codereview.chromium.org/113747. It is in a different review here because that code was uploaded from another machine, before I had committer access.) Committed: http://src.chromium.org/viewvc/chrome?view=rev&revision=16802 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@16824 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/browser/views/status_bubble_views.cc4
1 files changed, 4 insertions, 0 deletions
diff --git a/chrome/browser/views/status_bubble_views.cc b/chrome/browser/views/status_bubble_views.cc
index 8a83fd9..59b78ef 100644
--- a/chrome/browser/views/status_bubble_views.cc
+++ b/chrome/browser/views/status_bubble_views.cc
@@ -185,6 +185,7 @@ void StatusBubbleViews::StatusView::Show() {
Stop();
CancelTimer();
SetOpacity(1.0);
+ popup_->Show();
stage_ = BUBBLE_SHOWN;
PaintNow();
}
@@ -194,6 +195,7 @@ void StatusBubbleViews::StatusView::Hide() {
CancelTimer();
SetOpacity(0.0);
text_.clear();
+ popup_->Hide();
stage_ = BUBBLE_HIDDEN;
}
@@ -266,6 +268,7 @@ void StatusBubbleViews::StatusView::StartHiding() {
void StatusBubbleViews::StatusView::StartShowing() {
if (stage_ == BUBBLE_HIDDEN) {
+ popup_->Show();
stage_ = BUBBLE_SHOWING_TIMER;
StartTimer(kShowDelay);
} else if (stage_ == BUBBLE_HIDING_TIMER) {
@@ -309,6 +312,7 @@ void StatusBubbleViews::StatusView::AnimationEnded(
if (stage_ == BUBBLE_HIDING_FADE) {
stage_ = BUBBLE_HIDDEN;
+ popup_->Hide();
} else if (stage_ == BUBBLE_SHOWING_FADE) {
stage_ = BUBBLE_SHOWN;
}