cb7c87c2f8
git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@4057 599a83e7-65a4-db11-8015-0010dcdd6dc2
218 lines
6.3 KiB
JavaScript
218 lines
6.3 KiB
JavaScript
/*
|
|
"getBoxObjectFor()" compatibility library for Firefox 3.6 or later
|
|
|
|
Usage:
|
|
// use instead of HTMLDocument.getBoxObjectFor(HTMLElement)
|
|
var boxObject = window['piro.sakura.ne.jp']
|
|
.boxObject
|
|
.getBoxObjectFor(HTMLElement);
|
|
|
|
lisence: The MIT License, Copyright (c) 2009 SHIMODA "Piro" Hiroshi
|
|
http://www.cozmixng.org/repos/piro/fx3-compatibility-lib/trunk/license.txt
|
|
original:
|
|
http://www.cozmixng.org/repos/piro/fx3-compatibility-lib/trunk/boxObject.js
|
|
*/
|
|
(function() {
|
|
const currentRevision = 3;
|
|
|
|
if (!('piro.sakura.ne.jp' in window)) window['piro.sakura.ne.jp'] = {};
|
|
|
|
var loadedRevision = 'boxObject' in window['piro.sakura.ne.jp'] ?
|
|
window['piro.sakura.ne.jp'].boxObject.revision :
|
|
0 ;
|
|
if (loadedRevision && loadedRevision > currentRevision) {
|
|
return;
|
|
}
|
|
|
|
var Cc = Components.classes;
|
|
var Ci = Components.interfaces;
|
|
|
|
window['piro.sakura.ne.jp'].boxObject = {
|
|
revision : currentRevision,
|
|
|
|
getBoxObjectFor : function(aNode, aUnify)
|
|
{
|
|
return ('getBoxObjectFor' in aNode.ownerDocument) ?
|
|
this.getBoxObjectFromBoxObjectFor(aNode, aUnify) :
|
|
this.getBoxObjectFromClientRectFor(aNode, aUnify) ;
|
|
},
|
|
|
|
getBoxObjectFromBoxObjectFor : function(aNode, aUnify)
|
|
{
|
|
var boxObject = aNode.ownerDocument.getBoxObjectFor(aNode);
|
|
var box = {
|
|
x : boxObject.x,
|
|
y : boxObject.y,
|
|
width : boxObject.width,
|
|
height : boxObject.height,
|
|
screenX : boxObject.screenX,
|
|
screenY : boxObject.screenY
|
|
};
|
|
if (!aUnify) return box;
|
|
|
|
var style = this._getComputedStyle(aNode);
|
|
box.left = box.x - this._getPropertyPixelValue(style, 'border-left-width');
|
|
box.top = box.y - this._getPropertyPixelValue(style, 'border-top-width');
|
|
if (style.getPropertyValue('position') == 'fixed') {
|
|
box.left -= frame.scrollX;
|
|
box.top -= frame.scrollY;
|
|
}
|
|
box.right = box.left + box.width;
|
|
box.bottom = box.top + box.height;
|
|
|
|
return box;
|
|
},
|
|
|
|
getBoxObjectFromClientRectFor : function(aNode, aUnify)
|
|
{
|
|
var box = {
|
|
x : 0,
|
|
y : 0,
|
|
width : 0,
|
|
height : 0,
|
|
screenX : 0,
|
|
screenY : 0
|
|
};
|
|
try {
|
|
var zoom = this.getZoom(aNode.ownerDocument.defaultView);
|
|
|
|
var rect = aNode.getBoundingClientRect();
|
|
if (aUnify) {
|
|
box.left = rect.left;
|
|
box.top = rect.top;
|
|
box.right = rect.right;
|
|
box.bottom = rect.bottom;
|
|
}
|
|
|
|
var style = this._getComputedStyle(aNode);
|
|
var frame = aNode.ownerDocument.defaultView;
|
|
|
|
// "x" and "y" are offset positions of the "padding-box" from the document top-left edge.
|
|
box.x = rect.left + this._getPropertyPixelValue(style, 'border-left-width');
|
|
box.y = rect.top + this._getPropertyPixelValue(style, 'border-top-width');
|
|
if (style.getPropertyValue('position') != 'fixed') {
|
|
box.x += frame.scrollX;
|
|
box.y += frame.scrollY;
|
|
}
|
|
|
|
// "width" and "height" are sizes of the "border-box".
|
|
box.width = rect.right-rect.left;
|
|
box.height = rect.bottom-rect.top;
|
|
|
|
// "screenX" and "screenY" are absolute positions of the "border-box".
|
|
box.screenX = rect.left * zoom;
|
|
box.screenY = rect.top * zoom;
|
|
var owner = aNode;
|
|
while (true)
|
|
{
|
|
owner = this._getFrameOwnerFromFrame(frame);
|
|
frame = owner.ownerDocument.defaultView;
|
|
zoom = this.getZoom(frame);
|
|
|
|
let style = this._getComputedStyle(owner);
|
|
box.screenX += this._getPropertyPixelValue(style, 'border-left-width') * zoom;
|
|
box.screenY += this._getPropertyPixelValue(style, 'border-top-width') * zoom;
|
|
|
|
if (!owner) {
|
|
box.screenX += frame.screenX;
|
|
box.screenY += frame.screenY;
|
|
break;
|
|
}
|
|
if (owner.ownerDocument instanceof Ci.nsIDOMXULDocument) {
|
|
let ownerBox = owner.ownerDocument.getBoxObjectFor(owner);
|
|
box.screenX += ownerBox.screenX;
|
|
box.screenY += ownerBox.screenY;
|
|
break;
|
|
}
|
|
|
|
let ownerRect = owner.getBoundingClientRect();
|
|
box.screenX += ownerRect.left * zoom;
|
|
box.screenY += ownerRect.top * zoom;
|
|
}
|
|
}
|
|
catch(e) {
|
|
}
|
|
|
|
for (let i in box)
|
|
{
|
|
box[i] = Math.round(box[i]);
|
|
}
|
|
|
|
return box;
|
|
},
|
|
|
|
_getComputedStyle : function(aNode)
|
|
{
|
|
return aNode.ownerDocument.defaultView.getComputedStyle(aNode, null);
|
|
},
|
|
|
|
_getPropertyPixelValue : function(aStyle, aProperty)
|
|
{
|
|
return parseInt(aStyle.getPropertyValue(aProperty).replace('px', ''));
|
|
},
|
|
|
|
_getFrameOwnerFromFrame : function(aFrame)
|
|
{
|
|
var parentItem = aFrame
|
|
.QueryInterface(Ci.nsIInterfaceRequestor)
|
|
.getInterface(Ci.nsIWebNavigation)
|
|
.QueryInterface(Ci.nsIDocShell)
|
|
.QueryInterface(Ci.nsIDocShellTreeNode)
|
|
.QueryInterface(Ci.nsIDocShellTreeItem)
|
|
.parent;
|
|
var isChrome = parentItem.itemType == parentItem.typeChrome;
|
|
var parentDocument = parentItem
|
|
.QueryInterface(Ci.nsIWebNavigation)
|
|
.document;
|
|
var nodes = parentDocument.evaluate(
|
|
'/descendant::*[contains(" frame FRAME iframe IFRAME browser tabbrowser ", concat(" ", local-name(), " "))]',
|
|
parentDocument,
|
|
null,
|
|
Ci.nsIDOMXPathResult.ORDERED_NODE_SNAPSHOT_TYPE,
|
|
null
|
|
);
|
|
for (let i = 0, maxi = nodes.snapshotLength; i < maxi; i++)
|
|
{
|
|
let owner = nodes.snapshotItem(i);
|
|
if (isChrome && owner.wrappedJSObject) owner = owner.wrappedJSObject;
|
|
if (owner.localName == 'tabbrowser') {
|
|
let tabs = owner.mTabContainer.childNodes;
|
|
for (let i = 0, maxi = tabs.length; i < maxi; i++)
|
|
{
|
|
let browser = tabs[i].linkedBrowser;
|
|
if (browser.contentWindow == aFrame)
|
|
return browser;
|
|
}
|
|
}
|
|
else if (owner.contentWindow == aFrame) {
|
|
return owner;
|
|
}
|
|
}
|
|
return null;
|
|
},
|
|
|
|
Prefs : Cc['@mozilla.org/preferences;1']
|
|
.getService(Ci.nsIPrefBranch)
|
|
.QueryInterface(Ci.nsIPrefBranch2),
|
|
|
|
getZoom : function(aFrame)
|
|
{
|
|
try {
|
|
if (!this.Prefs.getBoolPref('browser.zoom.full'))
|
|
return 1;
|
|
}
|
|
catch(e) {
|
|
return 1;
|
|
}
|
|
var markupDocumentViewer = aFrame.top
|
|
.QueryInterface(Ci.nsIInterfaceRequestor)
|
|
.getInterface(Ci.nsIWebNavigation)
|
|
.QueryInterface(Ci.nsIDocShell)
|
|
.contentViewer
|
|
.QueryInterface(Ci.nsIMarkupDocumentViewer);
|
|
return markupDocumentViewer.fullZoom;
|
|
}
|
|
|
|
};
|
|
})();
|