タイマーを一箇所にまとめて、アニメーションの負荷を軽くした
git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@4077 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
parent
bbf11ff688
commit
7de0a547d3
@ -32,7 +32,7 @@ var TreeStyleTabService = {
|
|||||||
kDROP_MARKER_CONTAINER : 'treestyletab-drop-marker-container',
|
kDROP_MARKER_CONTAINER : 'treestyletab-drop-marker-container',
|
||||||
kCOUNTER : 'treestyletab-counter',
|
kCOUNTER : 'treestyletab-counter',
|
||||||
kCOUNTER_CONTAINER : 'treestyletab-counter-container',
|
kCOUNTER_CONTAINER : 'treestyletab-counter-container',
|
||||||
kSPLITTER : 'treestyletab-splitter',
|
kSPLITTER : 'treestyletab-splitter',
|
||||||
kTABBAR_TOGGLER : 'treestyletab-tabbar-toggler',
|
kTABBAR_TOGGLER : 'treestyletab-tabbar-toggler',
|
||||||
kSTRINGBUNDLE : 'treestyletab-stringbundle',
|
kSTRINGBUNDLE : 'treestyletab-stringbundle',
|
||||||
|
|
||||||
@ -84,7 +84,7 @@ var TreeStyleTabService = {
|
|||||||
kSHOWN_BY_UNKNOWN : 0,
|
kSHOWN_BY_UNKNOWN : 0,
|
||||||
kSHOWN_BY_SHORTCUT : 1 << 0,
|
kSHOWN_BY_SHORTCUT : 1 << 0,
|
||||||
kSHOWN_BY_MOUSEMOVE : 1 << 1,
|
kSHOWN_BY_MOUSEMOVE : 1 << 1,
|
||||||
kSHOWN_BY_FEEDBACK : 1 << 2,
|
kSHOWN_BY_FEEDBACK : 1 << 2,
|
||||||
kKEEP_SHOWN_ON_MOUSEOVER : (1 << 0) | (1 << 1) | (1 << 2),
|
kKEEP_SHOWN_ON_MOUSEOVER : (1 << 0) | (1 << 1) | (1 << 2),
|
||||||
|
|
||||||
kTRANSPARENT_NONE : 0,
|
kTRANSPARENT_NONE : 0,
|
||||||
@ -963,6 +963,50 @@ var TreeStyleTabService = {
|
|||||||
|
|
||||||
useTMPSessionAPI : false,
|
useTMPSessionAPI : false,
|
||||||
kTMP_SESSION_DATA_PREFIX : 'tmp-session-data-',
|
kTMP_SESSION_DATA_PREFIX : 'tmp-session-data-',
|
||||||
|
|
||||||
|
/* animation */
|
||||||
|
animationTasks : [],
|
||||||
|
animationInterval : 10,
|
||||||
|
animationTimer : null,
|
||||||
|
|
||||||
|
addAnimationTask : function(aTask)
|
||||||
|
{
|
||||||
|
if (!aTask) return;
|
||||||
|
this.animationTasks.push(aTask);
|
||||||
|
if (this.animationTasks.length > 1) return;
|
||||||
|
this.endAnimations();
|
||||||
|
this.animationTimer = window.setInterval(
|
||||||
|
this.animationCallback,
|
||||||
|
this.animationInterval,
|
||||||
|
this
|
||||||
|
);
|
||||||
|
},
|
||||||
|
|
||||||
|
removeAnimationTask : function(aTask)
|
||||||
|
{
|
||||||
|
if (!aTask) return;
|
||||||
|
var index = this.animationTasks.indexOf(aTask);
|
||||||
|
if (index > -1) this.animationTasks.splice(index, 1);
|
||||||
|
if (!this.animationTasks.length)
|
||||||
|
this.endAnimations();
|
||||||
|
},
|
||||||
|
|
||||||
|
endAnimations : function()
|
||||||
|
{
|
||||||
|
if (!this.animationTimer) return;
|
||||||
|
window.clearInterval(this.animationTimer);
|
||||||
|
this.animationTimer = null;
|
||||||
|
},
|
||||||
|
|
||||||
|
animationCallback : function(aSelf)
|
||||||
|
{
|
||||||
|
// task should return true if it finishes.
|
||||||
|
aSelf.animationTasks = aSelf.animationTasks.filter(function(aTask) {
|
||||||
|
return !aTask();
|
||||||
|
});
|
||||||
|
if (!aSelf.animationTasks.length)
|
||||||
|
aSelf.endAnimations();
|
||||||
|
},
|
||||||
|
|
||||||
/* Initializing */
|
/* Initializing */
|
||||||
|
|
||||||
@ -1506,12 +1550,12 @@ catch(e) {
|
|||||||
var treeStyleTab = gBrowser.treeStyleTab;
|
var treeStyleTab = gBrowser.treeStyleTab;
|
||||||
if (gBrowser.getAttribute(treeStyleTab.kTABBAR_POSITION) != 'top') {
|
if (gBrowser.getAttribute(treeStyleTab.kTABBAR_POSITION) != 'top') {
|
||||||
treeStyleTab.autoHideMode = treeStyleTab.getTreePref(window.fullScreen ? 'tabbar.autoHide.mode.fullscreen' : 'tabbar.autoHide.mode' );
|
treeStyleTab.autoHideMode = treeStyleTab.getTreePref(window.fullScreen ? 'tabbar.autoHide.mode.fullscreen' : 'tabbar.autoHide.mode' );
|
||||||
treeStyleTab.endAutoHide();
|
treeStyleTab.endAutoHide();
|
||||||
treeStyleTab.autoHideMode = treeStyleTab.getTreePref(window.fullScreen ? 'tabbar.autoHide.mode' : 'tabbar.autoHide.mode.fullscreen' );
|
treeStyleTab.autoHideMode = treeStyleTab.getTreePref(window.fullScreen ? 'tabbar.autoHide.mode' : 'tabbar.autoHide.mode.fullscreen' );
|
||||||
if (window.fullScreen)
|
if (window.fullScreen)
|
||||||
treeStyleTab.checkTabsIndentOverflow();
|
treeStyleTab.checkTabsIndentOverflow();
|
||||||
if (treeStyleTab.autoHideMode != treeStyleTab.kAUTOHIDE_MODE_DISABLED)
|
if (treeStyleTab.autoHideMode != treeStyleTab.kAUTOHIDE_MODE_DISABLED)
|
||||||
treeStyleTab.startAutoHide();
|
treeStyleTab.startAutoHide();
|
||||||
}
|
}
|
||||||
]]>
|
]]>
|
||||||
)
|
)
|
||||||
@ -1541,6 +1585,7 @@ catch(e) {
|
|||||||
{
|
{
|
||||||
window.removeEventListener('unload', this, false);
|
window.removeEventListener('unload', this, false);
|
||||||
|
|
||||||
|
this.endAnimations();
|
||||||
this.destroyTabBrowser(gBrowser);
|
this.destroyTabBrowser(gBrowser);
|
||||||
|
|
||||||
this.endListenKeyEvents();
|
this.endListenKeyEvents();
|
||||||
@ -1713,12 +1758,12 @@ catch(e) {
|
|||||||
this.keyEventListening = false;
|
this.keyEventListening = false;
|
||||||
},
|
},
|
||||||
keyEventListening : false,
|
keyEventListening : false,
|
||||||
get shouldListenKeyEvents()
|
get shouldListenKeyEvents()
|
||||||
{
|
{
|
||||||
return this.getTreePref('tabbar.autoShow.accelKeyDown') ||
|
return this.getTreePref('tabbar.autoShow.accelKeyDown') ||
|
||||||
this.getTreePref('tabbar.autoShow.tabSwitch') ||
|
this.getTreePref('tabbar.autoShow.tabSwitch') ||
|
||||||
this.getTreePref('tabbar.autoShow.feedback');
|
this.getTreePref('tabbar.autoShow.feedback');
|
||||||
},
|
},
|
||||||
|
|
||||||
onTabbarResized : function(aEvent)
|
onTabbarResized : function(aEvent)
|
||||||
{
|
{
|
||||||
|
@ -2821,7 +2821,9 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
var delta = aIndent - startIndent;
|
var delta = aIndent - startIndent;
|
||||||
var delay = this.indentDelay;
|
var delay = this.indentDelay;
|
||||||
var startTime = Date.now();
|
var startTime = Date.now();
|
||||||
aTab.__treestyletab__updateTabIndentTimer = window.setInterval(function(aSelf) {
|
|
||||||
|
var self = this;
|
||||||
|
aTab.__treestyletab__updateTabIndentTask = function() {
|
||||||
var power = Math.min(1, (Date.now() - startTime) / delay);
|
var power = Math.min(1, (Date.now() - startTime) / delay);
|
||||||
var powerForStyle = Math.sin(90 * power * Math.PI / 180);
|
var powerForStyle = Math.sin(90 * power * Math.PI / 180);
|
||||||
var indent = (power == 1) ?
|
var indent = (power == 1) ?
|
||||||
@ -2834,14 +2836,19 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
aProp+':'+indent+'px !important;'
|
aProp+':'+indent+'px !important;'
|
||||||
);
|
);
|
||||||
|
|
||||||
if (power == 1) aSelf.stopTabIndentAnimation(aTab);
|
if (power == 1) {
|
||||||
}, 10, this);
|
delete aTab.__treestyletab__updateTabIndentTask;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
TreeStyleTabService.addAnimationTask(aTab.__treestyletab__updateTabIndentTask);
|
||||||
},
|
},
|
||||||
stopTabIndentAnimation : function(aTab)
|
stopTabIndentAnimation : function(aTab)
|
||||||
{
|
{
|
||||||
if (!aTab.__treestyletab__updateTabIndentTimer) return;
|
TreeStyleTabService.removeAnimationTask(aTab.__treestyletab__updateTabIndentTask);
|
||||||
window.clearInterval(aTab.__treestyletab__updateTabIndentTimer);
|
|
||||||
aTab.__treestyletab__updateTabIndentTimer = null;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
inheritTabIndent : function(aNewTab, aExistingTab)
|
inheritTabIndent : function(aNewTab, aExistingTab)
|
||||||
@ -3089,7 +3096,8 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
);
|
);
|
||||||
if (!aCollapsed) aTab.removeAttribute(this.kCOLLAPSED_DONE);
|
if (!aCollapsed) aTab.removeAttribute(this.kCOLLAPSED_DONE);
|
||||||
|
|
||||||
aTab.__treestyletab__updateTabCollapsedTimer = window.setInterval(function(aSelf) {
|
var self = this;
|
||||||
|
aTab.__treestyletab__updateTabCollapsedTask = function() {
|
||||||
var power = Math.min(1, (Date.now() - startTime) / delay);
|
var power = Math.min(1, (Date.now() - startTime) / delay);
|
||||||
var powerForStyle = Math.sin(90 * power * Math.PI / 180);
|
var powerForStyle = Math.sin(90 * power * Math.PI / 180);
|
||||||
var margin = (power == 1) ?
|
var margin = (power == 1) ?
|
||||||
@ -3107,25 +3115,29 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
);
|
);
|
||||||
|
|
||||||
if (power == 1) {
|
if (power == 1) {
|
||||||
aSelf.stopTabCollapseAnimation(aTab);
|
aTab.removeAttribute(self.kCOLLAPSING);
|
||||||
aTab.removeAttribute(aSelf.kCOLLAPSING);
|
|
||||||
aTab.setAttribute(
|
aTab.setAttribute(
|
||||||
'style',
|
'style',
|
||||||
aTab.getAttribute('style')
|
aTab.getAttribute('style')
|
||||||
.replace(regexp, '')
|
.replace(regexp, '')
|
||||||
.replace(aSelf.kOPACITY_RULE_REGEXP, '')
|
.replace(self.kOPACITY_RULE_REGEXP, '')
|
||||||
);
|
);
|
||||||
if (aCollapsed)
|
if (aCollapsed) {
|
||||||
aTab.setAttribute(aSelf.kCOLLAPSED_DONE, true);
|
aTab.setAttribute(self.kCOLLAPSED_DONE, true);
|
||||||
|
}
|
||||||
|
delete aTab.__treestyletab__updateTabCollapsedTask;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}, 10, this);
|
else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
TreeStyleTabService.addAnimationTask(aTab.__treestyletab__updateTabCollapsedTask);
|
||||||
},
|
},
|
||||||
kOPACITY_RULE_REGEXP : /opacity\s*:[^;]+;?/,
|
kOPACITY_RULE_REGEXP : /opacity\s*:[^;]+;?/,
|
||||||
stopTabCollapseAnimation : function(aTab)
|
stopTabCollapseAnimation : function(aTab)
|
||||||
{
|
{
|
||||||
if (!aTab.__treestyletab__updateTabCollapsedTimer) return;
|
TreeStyleTabService.removeAnimationTask(aTab.__treestyletab__updateTabCollapsedTask);
|
||||||
window.clearInterval(aTab.__treestyletab__updateTabCollapsedTimer);
|
|
||||||
aTab.__treestyletab__updateTabCollapsedTimer = null;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
collapseExpandTreesIntelligentlyFor : function(aTab, aJustNow)
|
collapseExpandTreesIntelligentlyFor : function(aTab, aJustNow)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user