Firefox 3でのタブバーの問題を修正

git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@2053 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
piro 2008-03-10 07:21:32 +00:00
parent af5fcc7193
commit 2c26efd81b
2 changed files with 12 additions and 14 deletions

View File

@ -105,11 +105,9 @@ tabbrowser[treestyletab-mode="multirow"] .tabbrowser-tab {
} }
*/ */
tabbrowser[treestyletab-tabbar-autohide]:not([treestyletab-tabbar-transparent]) .tabs-stack > *:first-child > :not(html|canvas) { tabbrowser[treestyletab-tabbar-autohide]:not([treestyletab-tabbar-transparent]) .tabs-stack > *:first-child > :not(html|canvas),
display: none !important;
}
tabbrowser[treestyletab-tabbar-resizing] .tabs-stack > *:first-child > html|canvas { tabbrowser[treestyletab-tabbar-resizing] .tabs-stack > *:first-child > html|canvas {
visibility: hidden !important; display: none !important;
} }

View File

@ -400,7 +400,7 @@ TreeStyleTabBrowser.prototype = {
var stack = document.getAnonymousElementByAttribute(b.mTabContainer, 'class', 'tabs-stack'); var stack = document.getAnonymousElementByAttribute(b.mTabContainer, 'class', 'tabs-stack');
if (stack) { if (stack) {
var canvas = document.createElementNS('http://www.w3.org/1999/xhtml', 'canvas'); var canvas = document.createElementNS('http://www.w3.org/1999/xhtml', 'canvas');
canvas.setAttribute('style', 'visibility:collapse;width:0;height:0;'); canvas.setAttribute('style', 'display:none;width:1;height:1;');
stack.firstChild.appendChild(canvas); stack.firstChild.appendChild(canvas);
this.tabbarCanvas = canvas; this.tabbarCanvas = canvas;
this.clearTabbarCanvas(); this.clearTabbarCanvas();
@ -2807,13 +2807,14 @@ TreeStyleTabBrowser.prototype = {
var yOffset = (pos == 'left' || pos == 'right') ? var yOffset = (pos == 'left' || pos == 'right') ?
contentBox.screenY + frame.scrollY - browserBox.screenY : contentBox.screenY + frame.scrollY - browserBox.screenY :
0 ; 0 ;
var w = tabContainerBox.width - xOffset; // zero width (heigh) canvas becomes wrongly size!!
var h = tabContainerBox.height - yOffset; var w = Math.max(1, (tabContainerBox.width - xOffset));
var h = Math.max(1, (tabContainerBox.height - yOffset));
this.tabbarCanvas.style.display = 'inline';
this.tabbarCanvas.style.margin = (yOffset || 0)+'px 0 0 '+(xOffset || 0)+'px'; this.tabbarCanvas.style.margin = (yOffset || 0)+'px 0 0 '+(xOffset || 0)+'px';
this.tabbarCanvas.style.width = (this.tabbarCanvas.width = w)+'px'; this.tabbarCanvas.style.width = (this.tabbarCanvas.width = w)+'px';
this.tabbarCanvas.style.height = (this.tabbarCanvas.height = h)+'px'; this.tabbarCanvas.style.height = (this.tabbarCanvas.height = h)+'px';
this.tabbarCanvas.style.visibility = 'visible';
var ctx = this.tabbarCanvas.getContext('2d'); var ctx = this.tabbarCanvas.getContext('2d');
ctx.clearRect(0, 0, w, h); ctx.clearRect(0, 0, w, h);
ctx.save(); ctx.save();
@ -2825,12 +2826,11 @@ TreeStyleTabBrowser.prototype = {
{ {
if (!this.tabbarCanvas) return; if (!this.tabbarCanvas) return;
this.tabbarCanvas.style.margin = this.tabbarCanvas.style.display = 'none';
this.tabbarCanvas.style.width = this.tabbarCanvas.style.margin = 0;
this.tabbarCanvas.style.height = // zero width (heigh) canvas becomes wrongly size!!
this.tabbarCanvas.width = this.tabbarCanvas.style.width = this.tabbarCanvas.style.height = '1px';
this.tabbarCanvas.height = 0; this.tabbarCanvas.width = this.tabbarCanvas.height = 1;
this.tabbarCanvas.style.visibility = 'collapse';
}, },
updateTabbarTransparency : function() updateTabbarTransparency : function()