Commit 60ec04bc authored by Sergey.Luzyanin's avatar Sergey.Luzyanin Committed by Alexander.Trofimov

не подбираем размер автофигуры в определенных случаях.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@62839 954022d7-b5bf-4e40-9824-e11837661b57
parent e804d14a
...@@ -3669,6 +3669,7 @@ DrawingObjectsController.prototype = ...@@ -3669,6 +3669,7 @@ DrawingObjectsController.prototype =
{ {
content.Remove(dir, true, bRemoveOnlySelection) content.Remove(dir, true, bRemoveOnlySelection)
} }
target_text_object.checkExtentsByDocContent();
} }
} }
else if(this.selectedObjects.length > 0) else if(this.selectedObjects.length > 0)
......
...@@ -25,6 +25,7 @@ var APPROXIMATE_EPSILON3 = 5; ...@@ -25,6 +25,7 @@ var APPROXIMATE_EPSILON3 = 5;
var cToRad = Math.PI/(60000*180); var cToRad = Math.PI/(60000*180);
var cToDeg = 1/cToRad; var cToDeg = 1/cToRad;
var MAX_ITER_COUNT = 50;
var oGdLst = {}; var oGdLst = {};
oGdLst["_3cd4"]= 16200000; oGdLst["_3cd4"]= 16200000;
...@@ -1330,7 +1331,7 @@ Geometry.prototype= ...@@ -1330,7 +1331,7 @@ Geometry.prototype=
var dDelta = 0; var dDelta = 0;
var dWi = dTextWidth, dHi = dTextHeight, dWNext, dHNext; var dWi = dTextWidth, dHi = dTextHeight, dWNext, dHNext;
var oGeometry = ExecuteNoHistory(function(){return this.createDuplicate()}, this, []); var oGeometry = ExecuteNoHistory(function(){return this.createDuplicate()}, this, []);
var iter_Count = 0;
if(!isRealNumber(dGeometryWidth) && !isRealNumber(dGeometryHeight)) if(!isRealNumber(dGeometryWidth) && !isRealNumber(dGeometryHeight))
{ {
do do
...@@ -1341,9 +1342,10 @@ Geometry.prototype= ...@@ -1341,9 +1342,10 @@ Geometry.prototype=
dDelta = Math.max(Math.abs(dWNext - dWi), Math.abs(dHNext - dHi)); dDelta = Math.max(Math.abs(dWNext - dWi), Math.abs(dHNext - dHi));
dWi = dWNext; dWi = dWNext;
dHi = dHNext; dHi = dHNext;
++iter_Count;
} }
while(dDelta > EPSILON_TEXT_AUTOFIT); while(dDelta > EPSILON_TEXT_AUTOFIT && iter_Count < MAX_ITER_COUNT);
return {W: dWi, H: dHi}; return {W: dWi, H: dHi, bError: dDelta > EPSILON_TEXT_AUTOFIT};
} }
else if(isRealNumber(dGeometryWidth)) else if(isRealNumber(dGeometryWidth))
{ {
...@@ -1353,9 +1355,10 @@ Geometry.prototype= ...@@ -1353,9 +1355,10 @@ Geometry.prototype=
dHNext = dTextHeight - (oGeometry.rect.b - oGeometry.rect.t) + dHi; dHNext = dTextHeight - (oGeometry.rect.b - oGeometry.rect.t) + dHi;
dDelta = Math.abs(dHNext - dHi); dDelta = Math.abs(dHNext - dHi);
dHi = dHNext; dHi = dHNext;
++iter_Count;
} }
while(dDelta > EPSILON_TEXT_AUTOFIT); while(dDelta > EPSILON_TEXT_AUTOFIT && iter_Count < MAX_ITER_COUNT);
return {W: dGeometryWidth, H: dHi}; return {W: dGeometryWidth, H: dHi, bError: dDelta > EPSILON_TEXT_AUTOFIT};
} }
else else
{ {
...@@ -1365,9 +1368,10 @@ Geometry.prototype= ...@@ -1365,9 +1368,10 @@ Geometry.prototype=
dWNext = dTextWidth - (oGeometry.rect.r - oGeometry.rect.l) + dWi; dWNext = dTextWidth - (oGeometry.rect.r - oGeometry.rect.l) + dWi;
dDelta = Math.abs(dWNext - dWi); dDelta = Math.abs(dWNext - dWi);
dWi = dWNext; dWi = dWNext;
++iter_Count;
} }
while(dDelta > EPSILON_TEXT_AUTOFIT); while(dDelta > EPSILON_TEXT_AUTOFIT && iter_Count < MAX_ITER_COUNT);
return {W: dWi, H: dGeometryHeight}; return {W: dWi, H: dGeometryHeight, bError: dDelta > EPSILON_TEXT_AUTOFIT};
} }
} }
}; };
......
...@@ -358,6 +358,36 @@ function RecalculateDocContentByMaxLine(oDocContent, dMaxWidth, bNeedRecalcAllDr ...@@ -358,6 +358,36 @@ function RecalculateDocContentByMaxLine(oDocContent, dMaxWidth, bNeedRecalcAllDr
} }
function CheckExcelDrawingXfrm(xfrm)
{
var rot = isRealNumber(xfrm.rot) ? xfrm.rot : 0;
if (checkNormalRotate(rot))
{
if(xfrm.offX < 0)
{
xfrm.setOffX(0);
}
if(xfrm.offY < 0)
{
xfrm.setOffY(0);
}
}
else
{
var dPosX = xfrm.offX + xfrm.extX/2 - xfrm.extY/2;
var dPosY = xfrm.offY + xfrm.extY/2 - xfrm.extX/2;
if(dPosX < 0)
{
xfrm.setOffX(xfrm.offX - dPosX);
}
if(dPosY < 0)
{
xfrm.setOffY(xfrm.offY - dPosY);
}
}
};
function CShape() function CShape()
{ {
this.nvSpPr = null; this.nvSpPr = null;
...@@ -1864,6 +1894,13 @@ CShape.prototype = ...@@ -1864,6 +1894,13 @@ CShape.prototype =
default_style.ParaPr.Spacing.Before = 0; default_style.ParaPr.Spacing.Before = 0;
default_style.ParaPr.Spacing.After = 0; default_style.ParaPr.Spacing.After = 0;
default_style.ParaPr.Align = align_Center; default_style.ParaPr.Align = align_Center;
if(parent_objects.theme)
{
default_style.TextPr.RFonts.Ascii = {Name: "+mn-lt", Index: -1};
default_style.TextPr.RFonts.EastAsia = {Name: "+mn-ea", Index: -1};
default_style.TextPr.RFonts.CS = {Name: "+mn-cs", Index: -1};
default_style.TextPr.RFonts.HAnsi = {Name: "+mn-lt", Index: -1};
}
if (isRealObject(parent_objects.presentation) && isRealObject(parent_objects.presentation.defaultTextStyle) if (isRealObject(parent_objects.presentation) && isRealObject(parent_objects.presentation.defaultTextStyle)
&& isRealObject(parent_objects.presentation.defaultTextStyle.levels[level])) { && isRealObject(parent_objects.presentation.defaultTextStyle.levels[level])) {
var default_ppt_style = parent_objects.presentation.defaultTextStyle.levels[level]; var default_ppt_style = parent_objects.presentation.defaultTextStyle.levels[level];
...@@ -1874,7 +1911,7 @@ CShape.prototype = ...@@ -1874,7 +1911,7 @@ CShape.prototype =
var master_style; var master_style;
if (isRealObject(parent_objects.master) && isRealObject(parent_objects.master.txStyles)) { if (isRealObject(parent_objects.master) && isRealObject(parent_objects.master.txStyles)) {
var master_ppt_styles; var master_ppt_styles;
master_style = new CStyle("masterStyele", null, null, null, true); master_style = new CStyle("masterStyle", null, null, null, true);
if (this.isPlaceholder()) { if (this.isPlaceholder()) {
switch (this.getPlaceholderType()) { switch (this.getPlaceholderType()) {
case phType_ctrTitle: case phType_ctrTitle:
...@@ -2335,9 +2372,12 @@ CShape.prototype = ...@@ -2335,9 +2372,12 @@ CShape.prototype =
if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) { if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + l_ins + r_ins, oContentMetrics.contentH + t_ins + b_ins); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + l_ins + r_ins, oContentMetrics.contentH + t_ins + b_ins);
if(!oWH.bError)
{
this.extX = oWH.W; this.extX = oWH.W;
this.extY = oWH.H; this.extY = oWH.H;
} }
}
else { else {
this.extX = oContentMetrics.w + l_ins + r_ins; this.extX = oContentMetrics.w + l_ins + r_ins;
this.extY = oContentMetrics.contentH + t_ins + b_ins; this.extY = oContentMetrics.contentH + t_ins + b_ins;
...@@ -2347,9 +2387,12 @@ CShape.prototype = ...@@ -2347,9 +2387,12 @@ CShape.prototype =
else { else {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + t_ins + b_ins, oContentMetrics.contentH + l_ins + r_ins); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + t_ins + b_ins, oContentMetrics.contentH + l_ins + r_ins);
if(!oWH.bError)
{
this.extX = oWH.H; this.extX = oWH.H;
this.extY = oWH.W; this.extY = oWH.W;
} }
}
else { else {
this.extY = oContentMetrics.w + t_ins + b_ins; this.extY = oContentMetrics.w + t_ins + b_ins;
this.extX = oContentMetrics.contentH + l_ins + r_ins; this.extX = oContentMetrics.contentH + l_ins + r_ins;
...@@ -2363,9 +2406,11 @@ CShape.prototype = ...@@ -2363,9 +2406,11 @@ CShape.prototype =
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + l_ins + r_ins, oContentMetrics.contentH + t_ins + b_ins); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + l_ins + r_ins, oContentMetrics.contentH + t_ins + b_ins);
if(!oWH.bError) {
this.extX = oWH.W; this.extX = oWH.W;
this.extY = oWH.H; this.extY = oWH.H;
} }
}
else { else {
this.extX = oContentMetrics.w + l_ins + r_ins; this.extX = oContentMetrics.w + l_ins + r_ins;
this.extY = oContentMetrics.contentH + t_ins + b_ins; this.extY = oContentMetrics.contentH + t_ins + b_ins;
...@@ -2374,9 +2419,11 @@ CShape.prototype = ...@@ -2374,9 +2419,11 @@ CShape.prototype =
else { else {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + t_ins + b_ins, oContentMetrics.contentH + l_ins + r_ins); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + t_ins + b_ins, oContentMetrics.contentH + l_ins + r_ins);
if(!oWH.bError) {
this.extX = oWH.H; this.extX = oWH.H;
this.extY = oWH.W; this.extY = oWH.W;
} }
}
else { else {
this.extY = oContentMetrics.w + t_ins + b_ins; this.extY = oContentMetrics.w + t_ins + b_ins;
this.extX = oContentMetrics.contentH + l_ins + r_ins; this.extX = oContentMetrics.contentH + l_ins + r_ins;
...@@ -2388,9 +2435,11 @@ CShape.prototype = ...@@ -2388,9 +2435,11 @@ CShape.prototype =
if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) { if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + l_ins + r_ins, oContentMetrics.contentH + t_ins + b_ins); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + l_ins + r_ins, oContentMetrics.contentH + t_ins + b_ins);
if(!oWH.bError) {
this.extX = oWH.W; this.extX = oWH.W;
this.extY = oWH.H; this.extY = oWH.H;
} }
}
else { else {
this.extX = oContentMetrics.w + l_ins + r_ins; this.extX = oContentMetrics.w + l_ins + r_ins;
this.extY = oContentMetrics.contentH + t_ins + b_ins; this.extY = oContentMetrics.contentH + t_ins + b_ins;
...@@ -2399,9 +2448,11 @@ CShape.prototype = ...@@ -2399,9 +2448,11 @@ CShape.prototype =
else { else {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + t_ins + b_ins, oContentMetrics.contentH + l_ins + r_ins); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.w + t_ins + b_ins, oContentMetrics.contentH + l_ins + r_ins);
if(!oWH.bError) {
this.extX = oWH.H; this.extX = oWH.H;
this.extY = oWH.W; this.extY = oWH.W;
} }
}
else { else {
this.extY = oContentMetrics.w + t_ins + b_ins; this.extY = oContentMetrics.w + t_ins + b_ins;
this.extX = oContentMetrics.contentH + l_ins + r_ins; this.extX = oContentMetrics.contentH + l_ins + r_ins;
...@@ -2415,8 +2466,10 @@ CShape.prototype = ...@@ -2415,8 +2466,10 @@ CShape.prototype =
if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) { if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(undefined, oContentMetrics.contentH + t_ins + b_ins, this.extX, undefined); oWH = oGeometry.getNewWHByTextRect(undefined, oContentMetrics.contentH + t_ins + b_ins, this.extX, undefined);
if(!oWH.bError) {
this.extY = oWH.H; this.extY = oWH.H;
} }
}
else { else {
this.extY = oContentMetrics.contentH + t_ins + b_ins; this.extY = oContentMetrics.contentH + t_ins + b_ins;
} }
...@@ -2424,8 +2477,10 @@ CShape.prototype = ...@@ -2424,8 +2477,10 @@ CShape.prototype =
else { else {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.contentH + l_ins + b_ins, undefined, undefined, this.extY); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.contentH + l_ins + b_ins, undefined, undefined, this.extY);
if(!oWH.bError) {
this.extX = oWH.W; this.extX = oWH.W;
} }
}
else { else {
this.extX = oContentMetrics.contentH + l_ins + r_ins; this.extX = oContentMetrics.contentH + l_ins + r_ins;
} }
...@@ -2437,8 +2492,10 @@ CShape.prototype = ...@@ -2437,8 +2492,10 @@ CShape.prototype =
if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) { if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(undefined, oContentMetrics.contentH + t_ins + b_ins, this.extX, undefined); oWH = oGeometry.getNewWHByTextRect(undefined, oContentMetrics.contentH + t_ins + b_ins, this.extX, undefined);
if(!oWH.bError) {
this.extY = oWH.H; this.extY = oWH.H;
} }
}
else { else {
this.extY = oContentMetrics.contentH + t_ins + b_ins; this.extY = oContentMetrics.contentH + t_ins + b_ins;
} }
...@@ -2447,8 +2504,10 @@ CShape.prototype = ...@@ -2447,8 +2504,10 @@ CShape.prototype =
else { else {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.contentH + l_ins + r_ins, undefined, undefined, this.extY); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.contentH + l_ins + r_ins, undefined, undefined, this.extY);
if(!oWH.bError) {
this.extX = oWH.W; this.extX = oWH.W;
} }
}
else { else {
this.extX = oContentMetrics.contentH + l_ins + r_ins; this.extX = oContentMetrics.contentH + l_ins + r_ins;
} }
...@@ -2458,8 +2517,10 @@ CShape.prototype = ...@@ -2458,8 +2517,10 @@ CShape.prototype =
if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) { if (!(oBodyPr.vert === nVertTTvert || oBodyPr.vert === nVertTTvert270)) {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(oContentMetrics.contentH + l_ins + r_ins, undefined, undefined, this.extY); oWH = oGeometry.getNewWHByTextRect(oContentMetrics.contentH + l_ins + r_ins, undefined, undefined, this.extY);
if(!oWH.bError) {
this.extX = oWH.W; this.extX = oWH.W;
} }
}
else { else {
this.extX = oContentMetrics.contentH + l_ins + r_ins; this.extX = oContentMetrics.contentH + l_ins + r_ins;
} }
...@@ -2467,8 +2528,10 @@ CShape.prototype = ...@@ -2467,8 +2528,10 @@ CShape.prototype =
else { else {
if (oGeometry) { if (oGeometry) {
oWH = oGeometry.getNewWHByTextRect(undefined, oContentMetrics.contentH + t_ins + b_ins, this.extX, undefined); oWH = oGeometry.getNewWHByTextRect(undefined, oContentMetrics.contentH + t_ins + b_ins, this.extX, undefined);
if(!oWH.bError) {
this.extY = oWH.H; this.extY = oWH.H;
} }
}
else { else {
this.extY = oContentMetrics.contentH + t_ins + b_ins; this.extY = oContentMetrics.contentH + t_ins + b_ins;
} }
...@@ -2704,11 +2767,23 @@ CShape.prototype = ...@@ -2704,11 +2767,23 @@ CShape.prototype =
{ {
this.spPr.xfrm.setOffX(this.x); this.spPr.xfrm.setOffX(this.x);
this.spPr.xfrm.setOffY(this.y); this.spPr.xfrm.setOffY(this.y);
if(this.drawingBase)
{
CheckExcelDrawingXfrm(this.spPr.xfrm);
}
}
if(oMainGroup)
{
oMainGroup.updateCoordinatesAfterInternalResize();
} }
else
{
this.checkDrawingBaseCoords(); this.checkDrawingBaseCoords();
} }
}
}, },
checkDrawingBaseCoords: function() checkDrawingBaseCoords: function()
{ {
if(this.drawingBase && this.spPr && this.spPr.xfrm && !this.group) if(this.drawingBase && this.spPr && this.spPr.xfrm && !this.group)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment