[fusion-commits] r2529 - trunk/widgets/QuickPlot
svn_fusion at osgeo.org
svn_fusion at osgeo.org
Wed Feb 1 21:51:14 EST 2012
Author: liuar
Date: 2012-02-01 18:51:14 -0800 (Wed, 01 Feb 2012)
New Revision: 2529
Modified:
trunk/widgets/QuickPlot/PreviewDialog.js
Log:
Submit on behalf of Mars Wu
Fix ticket: http://trac.osgeo.org/mapguide/ticket/1943 - Quick Plot: Preview layout of portrait map is not proper
The reason for tis is the preview dialog is automatically adjusted to fit the browser window. But it considered only the "width", not the height because Then consider also the height when adjust the size of the preview dialog
Modified: trunk/widgets/QuickPlot/PreviewDialog.js
===================================================================
--- trunk/widgets/QuickPlot/PreviewDialog.js 2012-02-02 02:39:02 UTC (rev 2528)
+++ trunk/widgets/QuickPlot/PreviewDialog.js 2012-02-02 02:51:14 UTC (rev 2529)
@@ -49,11 +49,11 @@
width:400,
height: 400,
content: '<table border="0" cellspacing="0" cellpadding="0" id="PreviewContainer">' +
- ' <tr>' +
- ' <td>' +
- ' <iframe id="PreviewFrame" scrolling="no" frameborder="0" style="border: 0px; width: 400px; height: 300px;" src="about:blank"></iframe>' +
- ' </td>' +
- ' </tr>' +
+ ' <tr>' +
+ ' <td>' +
+ ' <iframe id="PreviewFrame" scrolling="no" frameborder="0" style="border: 0px; width: 400px; height: 300px;" src="about:blank"></iframe>' +
+ ' </td>' +
+ ' </tr>' +
'</table>'
});
@@ -141,22 +141,17 @@
var factor = 0.5;
this.previewContainer = $(this.innerDoc.getElementById("PreviewContainer"));
this.previewContainer.style.width = box.width * factor + "px";
- this.pictureContainer = $(this.innerDoc.getElementById("PictureContainer"));
- var pcBox = this.pictureContainer.getContentBoxSize();
+ this.resizePictureContainer();
- this.indicator = $(this.innerDoc.getElementById("ProgressIndicator"));
-
- var paperSize = this.captureInfo.paperSize;
- this.paperSize = paperSize;
-
- var ratio = paperSize.w / paperSize.h;
-
- // Resize the indicator
- this.indicator.style.width = pcBox.width + "px";
- this.indicator.style.height = pcBox.width / ratio + "px";
- // Set a explicit size to the container
- this.pictureContainer.style.width = this.indicator.style.width;
- this.pictureContainer.style.height = this.indicator.style.height;
+ // Verify if the priview container "overflows" the visible screen area
+ var containerBox = this.previewContainer.getContentBoxSize();
+ if (containerBox.height > box.height)
+ {
+ var overhead = $(this.innerDoc.getElementById("legalNotice")).getMarginBoxSize().height + $(this.innerDoc.getElementById("AnnotationContainer")).getMarginBoxSize().height + 4 * this.previewContainer.cellSpacing;
+ this.previewContainer.style.width = containerBox.width * box.height / containerBox.height - overhead + "px";
+ this.resizePictureContainer();
+ }
+
// Get the styles for the print picture
var rules = this.innerDoc.styleSheets[1].cssRules || this.innerDoc.styleSheets[1].rules;
this.previewStyle = rules[0];
@@ -220,6 +215,31 @@
}
},
+ resizePictureContainer: function()
+ {
+ this.innerDoc = this.previewFrame.contentWindow.document;
+
+ this.indicator = $(this.innerDoc.getElementById("ProgressIndicator"));
+ // Reset the size of the indicator first
+ this.indicator.style.width = "";
+ this.indicator.style.height = "";
+ // Reset the size of the picture container
+ this.pictureContainer = $(this.innerDoc.getElementById("PictureContainer"));
+ this.pictureContainer.style.width = "";
+ this.pictureContainer.style.height = "";
+
+ // Resize
+ var pcBox = this.pictureContainer.getContentBoxSize();
+ var ratio = this.captureInfo.paperSize.w / this.captureInfo.paperSize.h;
+
+ this.indicator.style.width = pcBox.width + "px";
+ this.indicator.style.height = pcBox.width / ratio + "px";
+
+ // Set an explicit size to the container
+ this.pictureContainer.style.width = this.indicator.style.width;
+ this.pictureContainer.style.height = this.indicator.style.height;
+ },
+
previewInnerLoaded: function()
{
//HACK: There is some state within these labels that gets invalidated in subsequent
@@ -289,15 +309,15 @@
// Set the print size
// NOTE: It works only with a 96 dpi device dpi
var deviceDpi = 96;
- var idealSize = {width:(this.paperSize.w / 25.4 - 2 * this.printMargin) * deviceDpi, height:(this.paperSize.h / 25.4 - 2 * this.printMargin) * deviceDpi};
+ var idealSize = {width:(this.captureInfo.paperSize.w / 25.4 - 2 * this.printMargin) * deviceDpi, height:(this.captureInfo.paperSize.h / 25.4 - 2 * this.printMargin) * deviceDpi};
// Get the size of the print frame
var docSize = $(this.innerDoc.body).getContentBoxSize();
var realHeight = idealSize.height - (docSize.height - size.height);
- var realWidth = realHeight * this.paperSize.w / this.paperSize.h;
+ var realWidth = realHeight * this.captureInfo.paperSize.w / this.captureInfo.paperSize.h;
if (realWidth > idealSize.width)
{
realWidth = idealSize.width;
- realHeight = realWidth / (this.paperSize.w / this.paperSize.h);
+ realHeight = realWidth / (this.captureInfo.paperSize.w / this.captureInfo.paperSize.h);
}
this.printStyle.style.width = realWidth + "px";
Property changes on: trunk/widgets/QuickPlot/PreviewDialog.js
___________________________________________________________________
Modified: svn:mergeinfo
- /sandbox/adsk/2.4j/widgets/QuickPlot/PreviewDialog.js:2486-2508
/sandbox/jxlib-3.0/widgets/QuickPlot/PreviewDialog.js:1957-2248
/trunk/widgets/QuickPlot/PreviewDialog.js:2469-2485
+ /sandbox/adsk/2.4j/widgets/QuickPlot/PreviewDialog.js:2486-2528
/sandbox/jxlib-3.0/widgets/QuickPlot/PreviewDialog.js:1957-2248
/trunk/widgets/QuickPlot/PreviewDialog.js:2469-2485
More information about the fusion-commits
mailing list