Commit c90b84ff authored by Anna.Pavlova's avatar Anna.Pavlova Committed by Alexander.Trofimov

delimiter /separator

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@49610 954022d7-b5bf-4e40-9824-e11837661b57
parent 1f307b24
...@@ -106,9 +106,10 @@ CMathBase.prototype = ...@@ -106,9 +106,10 @@ CMathBase.prototype =
//this.TxtPrp = new CMathTextPrp(); //this.TxtPrp = new CMathTextPrp();
this.TxtPrp.Merge(txtPrp); this.TxtPrp.Merge(txtPrp);
var tPrp = this.getTxtPrp();
for(var i=0; i < this.nRow; i++) for(var i=0; i < this.nRow; i++)
for(var j = 0; j < this.nCol; j++) for(var j = 0; j < this.nCol; j++)
this.elements[i][j].setTxtPrp(this.getTxtPrp()); this.elements[i][j].setTxtPrp(tPrp);
}, },
setOwnTPrp: function(txtPrp) setOwnTPrp: function(txtPrp)
{ {
......
...@@ -3174,83 +3174,180 @@ CMathContent.prototype = ...@@ -3174,83 +3174,180 @@ CMathContent.prototype =
break; break;
case 84: case 84:
var delim = this.addMComponent(MATH_DELIMITER); var delim = this.addMComponent(MATH_DELIMITER);
/*var props =
{
begChr: {type: BRACKET_SQUARE_RIGHT},
endChr: {type: BRACKET_SQUARE_LEFT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};*/
var props = var props =
{ {
begChr: {type: PARENTHESIS_LEFT}, begChr: {type: PARENTHESIS_LEFT},
endChr: {type: PARENTHESIS_RIGHT}, endChr: {type: PARENTHESIS_RIGHT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1 column: 1
}; };
delim.init(props); delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
/*var delim = this.addMComponent(9);
delim.init(0, 4, 0, 1);
delim.fillPlaceholders();*/
break; break;
case 85: case 85:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(2, 4, 0, 1); var props =
{
begChr: {type: BRACKET_SQUARE_LEFT},
endChr: {type: BRACKET_SQUARE_RIGHT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 86: case 86:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(1, 4, 0, 1); var props =
{
begChr: {type: BRACKET_CURLY_LEFT},
endChr: {type: BRACKET_CURLY_RIGHT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 87: case 87:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(3, 4, 0, 1); var props =
{
begChr: {type: BRACKET_ANGLE_LEFT},
endChr: {type: BRACKET_ANGLE_RIGHT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 88: case 88:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(4, 4, 0, 1); var props =
{
begChr: {type: HALF_SQUARE_LEFT},
endChr: {type: HALF_SQUARE_RIGHT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 89: case 89:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(4, 4, 2, 3); var props =
{
begChr: {type: HALF_SQUARE_LEFT_UPPER},
endChr: {type: HALF_SQUARE_RIGHT_UPPER},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 90: case 90:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(5, 4, 0, 1); var props =
{
begChr: {type: DELIMITER_LINE},
endChr: {type: DELIMITER_LINE},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 91: case 91:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(6, 4, 0, 1); var props =
{
begChr: {type: DELIMITER_DOUBLE_LINE},
endChr: {type: DELIMITER_DOUBLE_LINE},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 92: case 92:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(2, 4, 0, 0); var props =
{
begChr: {type: BRACKET_SQUARE_LEFT},
endChr: {type: BRACKET_SQUARE_LEFT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 93: case 93:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(2, 4, 1, 1); var props =
{
begChr: {type: BRACKET_SQUARE_RIGHT},
endChr: {type: BRACKET_SQUARE_RIGHT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 94: case 94:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(2, 4, 1, 0); var props =
{
begChr: {type: BRACKET_SQUARE_RIGHT},
endChr: {type: BRACKET_SQUARE_LEFT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 95: case 95:
var delim = this.addMComponent(9); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(7, 4, 0, 1); var props =
{
begChr: {type: WHITE_SQUARE_LEFT},
endChr: {type: WHITE_SQUARE_RIGHT},
shapeType: DELIMITER_SHAPE_MATH,
column: 1
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 96: case 96:
var delim = this.addMComponent(10); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(0, 2); var props =
{
begChr: {type: PARENTHESIS_LEFT},
sepChr: {type: BRACKET_ANGLE_LEFT},
endChr: {type: BRACKET_CURLY_RIGHT},
column: 2
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
case 97: case 97:
var delim = this.addMComponent(10); var delim = this.addMComponent(MATH_DELIMITER);
delim.init(1, 2); var props =
{
begChr: {type: PARENTHESIS_LEFT},
sepChr: {type: BRACKET_ANGLE_LEFT},
endChr: {type: BRACKET_CURLY_RIGHT},
column: 5
};
delim.init(props);
delim.fillPlaceholders(); delim.fillPlaceholders();
break; break;
break;
case 98: case 98:
var delim = this.addMComponent(10); var delim = this.addMComponent(10);
delim.init(3, 2); delim.init(3, 2);
......
...@@ -60,17 +60,17 @@ var BRACKET_ANGLE_LEFT = 6; ...@@ -60,17 +60,17 @@ var BRACKET_ANGLE_LEFT = 6;
var BRACKET_ANGLE_RIGHT = 7; var BRACKET_ANGLE_RIGHT = 7;
var HALF_SQUARE_LEFT = 8; var HALF_SQUARE_LEFT = 8;
var HALF_SQUARE_RIGHT = 9; var HALF_SQUARE_RIGHT = 9;
var HALF_SQUARE_LEFT_LOWER = 10; var HALF_SQUARE_LEFT_UPPER = 10;
var HALF_SQUARE_RIGHT_LOWER = 11; var HALF_SQUARE_RIGHT_UPPER = 11;
var HALF_SQUARE_LEFT_UPPER = 12; var DELIMITER_LINE = 12;
var HALF_SQUARE_RIGHT_UPPER = 13; var DELIMITER_DOUBLE_LINE = 13;
var DELIMITER_LINE = 14; var WHITE_SQUARE_LEFT = 14;
var DELIMITER_DOUBLE_LINE = 15; var WHITE_SQUARE_RIGHT = 15;
var DELIMITER_LOCATION_TOP = 0; var DELIMITER_LOCATION_TOP = 0;
var DELIMITER_LOCATION_BOTTOM = 1; var DELIMITER_LOCATION_BOTTOM = 1;
var DELIMITER_LOCATION_LEFT = 2; var DELIMITER_LOCATION_LEFT = 2;
var DELIMITER_LOCATION_RIGHT = 2; var DELIMITER_LOCATION_RIGHT = 3;
var DELIMITER_TURN_0 = 0; var DELIMITER_TURN_0 = 0;
var DELIMITER_TURN_180 = 1; var DELIMITER_TURN_180 = 1;
var DELIMITER_TURN_MIRROR_0 = 2; var DELIMITER_TURN_MIRROR_0 = 2;
......
var BEGINNING_CHR = 0;
var SEPARATOR_CHR = 1;
var ENDING_CHR = 2;
var TOP_CHR = 3;
var BOTTOM_CHR = 4;
function CGlyphOperator() function CGlyphOperator()
{ {
this.loc = null; this.loc = null;
this.turn = null; this.turn = null;
this.size = null;
this.measure = 0;
this.penW = 1; // px
this.TxtPrp = new CMathTextPrp();
}
CGlyphOperator.prototype.init = function(props)
{
// location
// 0 - up
// 1 - down
// 2 - left
// 3 - right
// turn
// 0 - 0
// 1 - Pi
// 2 - Pi/2
// 3 - 3*Pi/2
this.loc = props.location;
this.turn = props.turn;
}
CGlyphOperator.prototype.fixSize = function(measure)
{
var sizeGlyph = this.calcSize(measure);
var width, height, center;
//var betta = this.getTxtPrp().FontSize/36;
var bHor = this.loc == 0 || this.loc == 1;
if(bHor)
{
width = sizeGlyph.width;
height = sizeGlyph.height;
center = height/2;
this.measure = measure > width ? measure : width;
}
else
{
width = sizeGlyph.height;
height = sizeGlyph.width;
// baseLine смещен чуть вверх, чтобы текст при вставке в скобки располагался по центру, относительно высоты скобок
// плейсхолдер из-за этого располагается чуть выше, как в Ворде
//center = height/2 - 1.234722222222222*betta;
center = height/2;
this.measure = measure > height ? measure : height;
}
this.size = {width: width, height: height, center: center};
}
CGlyphOperator.prototype.draw_other = function() // с выравниванием к краю (относительно аргумента)
{
var coord = this.calcCoord(this.measure);
var X = coord.XX, Y = coord.YY,
W = this.size.width, H = this.size.height,
glW, glH;
var bHor = this.loc == 0 || this.loc == 1;
if(bHor)
{
glW = coord.W;
glH = coord.H;
}
else
{
glW = coord.H;
glH = coord.W;
}
var shW = (W - glW)/ 2, // выравниваем глиф по длине
shH = (H - glH)/2; // при повороте на 90 градусовы
if(this.loc == 0)
{
a1 = 1; b1 = 0; c1 = shW;
a2 = 0; b2 = 1; c2 = 0;
}
else if(this.loc == 1)
{
a1 = 1; b1 = 0; c1 = shW;
a2 = 0; b2 = 1; c2 = H - glH;
}
else if(this.loc == 2)
{
a1 = 0; b1 = 1; c1 = 0;
a2 = 1; b2 = 0; c2 = shH;
}
else
{
a1 = 0; b1 = 1; c1 = W - glW;
a2 = 1; b2 = 0; c2 = shH;
}
if(this.turn == 1)
{
a1 *= -1; b1 *= -1; c1 += glW;
}
else if(this.turn == 2)
{
a2 *= -1; b2 *= -1; c2 += glH;
}
else if(this.turn == 3)
{
a1 *= -1; b1 *= -1; c1 += glW;
a2 *= -1; b2 *= -1; c2 += glH;
}
var shW = (W - glW)/ 2, // выравниваем глиф по длине
shH = (H - glH)/2; // при повороте на 90 градусовы
// A*x + B*y + C = 0
if(bHor)
{
a1 = 1; b1 = 0; c1 = shW;
a2 = 0; b2 = 1; c2 = 0;
}
else
{
a1 = 0; b1 = 1; c1 = 0;
a2 = 1; b2 = 0; c2 = shH;
}
if(this.turn == 1)
{
a1 *= -1; b1 *= -1; c1 = W;
}
else if(this.turn == 2)
{
a2 *= -1; b2 *= -1; c2 = H;
}
else if(this.turn == 3)
{
a1 *= -1; b1 *= -1; c1 = W;
a2 *= -1; b2 *= -1; c2 = H;
}
// смещение
var gpX = 0,
gpY = 0;
if(this.loc == 1)
gpY = this.penW*25.4/96;
if(this.loc == 3)
gpX = - this.penW*25.4/96;
var XX = new Array(),
YY = new Array();
var x = this.pos.x;
y = this.pos.y;
for(var i = 0; i < X.length; i++)
{
XX[i] = x + X[i]*a1 + Y[i]*b1 + c1 + gpX;
YY[i] = y + X[i]*a2 + Y[i]*b2 + c2 + gpY;
}
for(var i = 0; i < YY.length; i++)
{
console.log("YY["+ i + "] = "+ YY[i]);
}
var intGrid = MathControl.pGraph.GetIntegerGrid();
MathControl.pGraph.SetIntegerGrid(false);
MathControl.pGraph.p_width(this.penW*1000);
MathControl.pGraph.b_color1(0,0,0, 255);
MathControl.pGraph._s();
this.drawPath(XX,YY);
MathControl.pGraph.df();
MathControl.pGraph.SetIntegerGrid(intGrid);
}
CGlyphOperator.prototype.getCoordinateGlyph = function()
{
var coord = this.calcCoord(this.measure);
var X = coord.XX, Y = coord.YY,
W = this.size.width, H = this.size.height;
var bHor = this.loc == 0 || this.loc == 1;
var glW = 0, glH = 0;
if(bHor)
{
glW = coord.W;
glH = coord.H;
}
else
{
glW = coord.H;
glH = coord.W;
}
var shW = (W - glW)/ 2, // выравниваем глиф по длине
shH = (H - glH)/2; // при повороте на 90 градусовы
// A*x + B*y + C = 0
if(bHor)
{
a1 = 1; b1 = 0; c1 = 0;
a2 = 0; b2 = 1; c2 = shH;
}
else
{
a1 = 0; b1 = 1; c1 = shW;
a2 = 1; b2 = 0; c2 = 0;
}
/*var shW = 0,
shH = 0;
if(bHor)
{
a1 = 1; b1 = 0; c1 = 0;
a2 = 0; b2 = 1; c2 = 0;
}
else
{
a1 = 0; b1 = 1; c1 = 0;
a2 = 1; b2 = 0; c2 = 0;
}*/
if(this.turn == 1)
{
a1 *= -1; b1 *= -1; c1 = W - c1; //c1 = W - c1;
}
else if(this.turn == 2)
{
a2 *= -1; b2 *= -1; c2 = H - c2;
}
else if(this.turn == 3)
{
a1 *= -1; b1 *= -1; c1 = W - c1;
a2 *= -1; b2 *= -1; c2 = H - c2;
}
var gpX = 0,
gpY = 0;
if(this.loc == 3)
gpX = - this.penW*25.4/96;
var XX = new Array(),
YY = new Array();
for(var i = 0; i < X.length; i++)
{
XX[i] = X[i]*a1 + Y[i]*b1 + c1 + gpX;
YY[i] = X[i]*a2 + Y[i]*b2 + c2 + gpY;
}
return {XX: XX, YY: YY, Width: glW, Height: glH};
}
CGlyphOperator.prototype.draw = function(XX, YY)
{
var intGrid = MathControl.pGraph.GetIntegerGrid();
MathControl.pGraph.SetIntegerGrid(false);
MathControl.pGraph.p_width(this.penW*1000);
MathControl.pGraph.b_color1(0,0,0, 255);
MathControl.pGraph._s();
this.drawPath(XX,YY);
MathControl.pGraph.df();
MathControl.pGraph.SetIntegerGrid(intGrid);
}
CGlyphOperator.prototype.getTxtPrp = function()
{
return this.TxtPrp;
}
CGlyphOperator.prototype.setTxtPrp = function(txtPrp)
{
this.TxtPrp.Merge(txtPrp);
}
function old_CGlyphOperator()
{
this.loc = null;
this.turn = null;
this.coord = null; this.coord = null;
this.size = null; this.size = null;
this.measure = 0; this.measure = 0;
...@@ -12,7 +317,7 @@ function CGlyphOperator() ...@@ -12,7 +317,7 @@ function CGlyphOperator()
this.TxtPrp = new CMathTextPrp(); this.TxtPrp = new CMathTextPrp();
} }
/*CGlyphOperator.prototype.setLocation = function(loc, turn) /*old_CGlyphOperator.prototype.setLocation = function(loc, turn)
{ {
// location // location
...@@ -31,7 +336,7 @@ function CGlyphOperator() ...@@ -31,7 +336,7 @@ function CGlyphOperator()
this.loc = loc; this.loc = loc;
this.turn = turn; this.turn = turn;
}*/ }*/
CGlyphOperator.prototype.init = function(props) old_CGlyphOperator.prototype.init = function(props)
{ {
// location // location
...@@ -50,17 +355,17 @@ CGlyphOperator.prototype.init = function(props) ...@@ -50,17 +355,17 @@ CGlyphOperator.prototype.init = function(props)
this.loc = props.location; this.loc = props.location;
this.turn = props.turn; this.turn = props.turn;
} }
CGlyphOperator.prototype.setPosition = function(pos) old_CGlyphOperator.prototype.setPosition = function(pos)
{ {
this.pos = pos; this.pos = pos;
//this.pos = {x: pos.x, y : pos.y - this.size.center}; //this.pos = {x: pos.x, y : pos.y - this.size.center};
} }
CGlyphOperator.prototype.fixSize = function(measure) old_CGlyphOperator.prototype.fixSize = function(measure)
{ {
var sizeGlyph = this.calcSize(measure); var sizeGlyph = this.calcSize(measure);
var width, height, center; var width, height, center;
var betta = this.getTxtPrp().FontSize/36; //var betta = this.getTxtPrp().FontSize/36;
var bHor = this.loc == 0 || this.loc == 1; var bHor = this.loc == 0 || this.loc == 1;
if(bHor) if(bHor)
...@@ -78,14 +383,14 @@ CGlyphOperator.prototype.fixSize = function(measure) ...@@ -78,14 +383,14 @@ CGlyphOperator.prototype.fixSize = function(measure)
// baseLine смещен чуть вверх, чтобы текст при вставке в скобки располагался по центру, относительно высоты скобок // baseLine смещен чуть вверх, чтобы текст при вставке в скобки располагался по центру, относительно высоты скобок
// плейсхолдер из-за этого располагается чуть выше, как в Ворде // плейсхолдер из-за этого располагается чуть выше, как в Ворде
center = height/2 - 1.234722222222222*betta; //center = height/2 - 1.234722222222222*betta;
//center = height/2; center = height/2;
this.measure = measure > height ? measure : height; this.measure = measure > height ? measure : height;
} }
this.size = {width: width, height: height, center: center}; this.size = {width: width, height: height, center: center};
} }
CGlyphOperator.prototype.draw_other = function() // с выравниванием к краю (относительно аргумента) old_CGlyphOperator.prototype.draw_other = function() // с выравниванием к краю (относительно аргумента)
{ {
var coord = this.calcCoord(this.measure); var coord = this.calcCoord(this.measure);
...@@ -130,18 +435,109 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание ...@@ -130,18 +435,109 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание
a2 = 1; b2 = 0; c2 = shH; a2 = 1; b2 = 0; c2 = shH;
} }
if(this.turn == 1) if(this.turn == 1)
{ {
a1 *= -1; b1 *= -1; c1 += glW; a1 *= -1; b1 *= -1; c1 += glW;
} }
else if(this.turn == 2) else if(this.turn == 2)
{
a2 *= -1; b2 *= -1; c2 += glH;
}
else if(this.turn == 3)
{
a1 *= -1; b1 *= -1; c1 += glW;
a2 *= -1; b2 *= -1; c2 += glH;
}
var shW = (W - glW)/ 2, // выравниваем глиф по длине
shH = (H - glH)/2; // при повороте на 90 градусовы
// A*x + B*y + C = 0
if(bHor)
{
a1 = 1; b1 = 0; c1 = shW;
a2 = 0; b2 = 1; c2 = 0;
}
else
{
a1 = 0; b1 = 1; c1 = 0;
a2 = 1; b2 = 0; c2 = shH;
}
if(this.turn == 1)
{
a1 *= -1; b1 *= -1; c1 = W;
}
else if(this.turn == 2)
{
a2 *= -1; b2 *= -1; c2 = H;
}
else if(this.turn == 3)
{
a1 *= -1; b1 *= -1; c1 = W;
a2 *= -1; b2 *= -1; c2 = H;
}
// смещение
var gpX = 0,
gpY = 0;
if(this.loc == 1)
gpY = this.penW*25.4/96;
if(this.loc == 3)
gpX = - this.penW*25.4/96;
var XX = new Array(),
YY = new Array();
var x = this.pos.x;
y = this.pos.y;
for(var i = 0; i < X.length; i++)
{
XX[i] = x + X[i]*a1 + Y[i]*b1 + c1 + gpX;
YY[i] = y + X[i]*a2 + Y[i]*b2 + c2 + gpY;
}
for(var i = 0; i < YY.length; i++)
{
console.log("YY["+ i + "] = "+ YY[i]);
}
var intGrid = MathControl.pGraph.GetIntegerGrid();
MathControl.pGraph.SetIntegerGrid(false);
MathControl.pGraph.p_width(this.penW*1000);
MathControl.pGraph.b_color1(0,0,0, 255);
MathControl.pGraph._s();
this.drawPath(XX,YY);
MathControl.pGraph.df();
MathControl.pGraph.SetIntegerGrid(intGrid);
}
old_CGlyphOperator.prototype.old_draw = function()
{
var coord = this.calcCoord(this.measure);
var X = coord.XX, Y = coord.YY,
W = this.size.width, H = this.size.height;
var bHor = this.loc == 0 || this.loc == 1;
var glW = 0, glH = 0;
if(bHor)
{ {
a2 *= -1; b2 *= -1; c2 += glH; glW = coord.W;
glH = coord.H;
} }
else if(this.turn == 3) else
{ {
a1 *= -1; b1 *= -1; c1 += glW; glW = coord.H;
a2 *= -1; b2 *= -1; c2 += glH; glH = coord.W;
} }
var shW = (W - glW)/ 2, // выравниваем глиф по длине var shW = (W - glW)/ 2, // выравниваем глиф по длине
...@@ -162,25 +558,21 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание ...@@ -162,25 +558,21 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание
if(this.turn == 1) if(this.turn == 1)
{ {
a1 *= -1; b1 *= -1; c1 = W; a1 *= -1; b1 *= -1; c1 = W - c1;
} }
else if(this.turn == 2) else if(this.turn == 2)
{ {
a2 *= -1; b2 *= -1; c2 = H; a2 *= -1; b2 *= -1; c2 = H - c2;
} }
else if(this.turn == 3) else if(this.turn == 3)
{ {
a1 *= -1; b1 *= -1; c1 = W; a1 *= -1; b1 *= -1; c1 = W - c1;
a2 *= -1; b2 *= -1; c2 = H; a2 *= -1; b2 *= -1; c2 = H - c2;
} }
// смещение
var gpX = 0, var gpX = 0,
gpY = 0; gpY = 0;
if(this.loc == 1)
gpY = this.penW*25.4/96;
if(this.loc == 3) if(this.loc == 3)
gpX = - this.penW*25.4/96; gpX = - this.penW*25.4/96;
...@@ -196,11 +588,6 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание ...@@ -196,11 +588,6 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание
YY[i] = y + X[i]*a2 + Y[i]*b2 + c2 + gpY; YY[i] = y + X[i]*a2 + Y[i]*b2 + c2 + gpY;
} }
for(var i = 0; i < YY.length; i++)
{
console.log("YY["+ i + "] = "+ YY[i]);
}
var intGrid = MathControl.pGraph.GetIntegerGrid(); var intGrid = MathControl.pGraph.GetIntegerGrid();
MathControl.pGraph.SetIntegerGrid(false); MathControl.pGraph.SetIntegerGrid(false);
...@@ -214,7 +601,7 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание ...@@ -214,7 +601,7 @@ CGlyphOperator.prototype.draw_other = function() // с выравнивание
MathControl.pGraph.SetIntegerGrid(intGrid); MathControl.pGraph.SetIntegerGrid(intGrid);
} }
CGlyphOperator.prototype.draw = function() old_CGlyphOperator.prototype.getCoordinateGlyph = function()
{ {
var coord = this.calcCoord(this.measure); var coord = this.calcCoord(this.measure);
...@@ -222,7 +609,8 @@ CGlyphOperator.prototype.draw = function() ...@@ -222,7 +609,8 @@ CGlyphOperator.prototype.draw = function()
W = this.size.width, H = this.size.height; W = this.size.width, H = this.size.height;
var bHor = this.loc == 0 || this.loc == 1; var bHor = this.loc == 0 || this.loc == 1;
var glW = 0, glH = 0;
/*var glW = 0, glH = 0;
if(bHor) if(bHor)
{ {
...@@ -236,7 +624,10 @@ CGlyphOperator.prototype.draw = function() ...@@ -236,7 +624,10 @@ CGlyphOperator.prototype.draw = function()
} }
var shW = (W - glW)/ 2, // выравниваем глиф по длине var shW = (W - glW)/ 2, // выравниваем глиф по длине
shH = (H - glH)/2; // при повороте на 90 градусовы shH = (H - glH)/2; // при повороте на 90 градусовы*/
var shW = 0,
shH = 0;
// A*x + B*y + C = 0 // A*x + B*y + C = 0
...@@ -274,15 +665,16 @@ CGlyphOperator.prototype.draw = function() ...@@ -274,15 +665,16 @@ CGlyphOperator.prototype.draw = function()
var XX = new Array(), var XX = new Array(),
YY = new Array(); YY = new Array();
var x = this.pos.x;
y = this.pos.y;
for(var i = 0; i < X.length; i++) for(var i = 0; i < X.length; i++)
{ {
XX[i] = x + X[i]*a1 + Y[i]*b1 + c1 + gpX; XX[i] = X[i]*a1 + Y[i]*b1 + c1 + gpX;
YY[i] = y + X[i]*a2 + Y[i]*b2 + c2 + gpY; YY[i] = X[i]*a2 + Y[i]*b2 + c2 + gpY;
} }
return {XX: XX, YY: YY, Width: coord.W, Height: coord.H};
}
old_CGlyphOperator.prototype.drawGlyph = function(XX, YY)
{
var intGrid = MathControl.pGraph.GetIntegerGrid(); var intGrid = MathControl.pGraph.GetIntegerGrid();
MathControl.pGraph.SetIntegerGrid(false); MathControl.pGraph.SetIntegerGrid(false);
...@@ -294,29 +686,29 @@ CGlyphOperator.prototype.draw = function() ...@@ -294,29 +686,29 @@ CGlyphOperator.prototype.draw = function()
MathControl.pGraph.df(); MathControl.pGraph.df();
MathControl.pGraph.SetIntegerGrid(intGrid); MathControl.pGraph.SetIntegerGrid(intGrid);
} }
CGlyphOperator.prototype.IsJustDraw = function() old_CGlyphOperator.prototype.IsJustDraw = function()
{ {
return true; return true;
} }
CGlyphOperator.prototype.relate = function(parent) old_CGlyphOperator.prototype.relate = function(parent)
{ {
this.Parent = parent; this.Parent = parent;
} }
CGlyphOperator.prototype.Resize = function() old_CGlyphOperator.prototype.Resize = function()
{ {
this.fixSize(); //?? this.fixSize(); //??
} }
CGlyphOperator.prototype.getTxtPrp = function() old_CGlyphOperator.prototype.getTxtPrp = function()
{ {
return this.TxtPrp; return this.TxtPrp;
} }
CGlyphOperator.prototype.setTxtPrp = function(txtPrp) old_CGlyphOperator.prototype.setTxtPrp = function(txtPrp)
{ {
this.TxtPrp.Merge(txtPrp); this.TxtPrp.Merge(txtPrp);
} }
function old_CDelimiter() /// ECMA: group characters function old_CDelimiter() /// ECMA: group characters
{ {
// location // location
...@@ -592,7 +984,7 @@ old_CDelimiter.prototype.Resize = function() ...@@ -592,7 +984,7 @@ old_CDelimiter.prototype.Resize = function()
this.recalculateSize(); this.recalculateSize();
} }
function GetOperator(chr) function GetGlyph(chr, location)
{ {
var operator; var operator;
...@@ -644,6 +1036,7 @@ function GetOperator(chr) ...@@ -644,6 +1036,7 @@ function GetOperator(chr)
var props = var props =
{ {
location: DELIMITER_LOCATION_LEFT, location: DELIMITER_LOCATION_LEFT,
//location: location,
turn: DELIMITER_TURN_0 turn: DELIMITER_TURN_0
}; };
operator.init(props); operator.init(props);
...@@ -654,13 +1047,14 @@ function GetOperator(chr) ...@@ -654,13 +1047,14 @@ function GetOperator(chr)
var props = var props =
{ {
location: DELIMITER_LOCATION_RIGHT, location: DELIMITER_LOCATION_RIGHT,
//location: location,
turn: DELIMITER_TURN_180 turn: DELIMITER_TURN_180
}; };
operator.init(props); operator.init(props);
} }
else if( chr.value === "<" || chr.type === BRACKET_SQUARE_LEFT) else if( chr.value === "<" || chr.type === BRACKET_ANGLE_LEFT)
{ {
operator = new CSquareBracket(); operator = new COperatorAngleBracket();
var props = var props =
{ {
location: DELIMITER_LOCATION_LEFT, location: DELIMITER_LOCATION_LEFT,
...@@ -668,9 +1062,9 @@ function GetOperator(chr) ...@@ -668,9 +1062,9 @@ function GetOperator(chr)
}; };
operator.init(props); operator.init(props);
} }
else if( chr.value === ">" || chr.type === BRACKET_SQUARE_RIGHT) else if( chr.value === ">" || chr.type === BRACKET_ANGLE_RIGHT)
{ {
operator = new CSquareBracket(); operator = new COperatorAngleBracket();
var props = var props =
{ {
location: DELIMITER_LOCATION_RIGHT, location: DELIMITER_LOCATION_RIGHT,
...@@ -678,6 +1072,86 @@ function GetOperator(chr) ...@@ -678,6 +1072,86 @@ function GetOperator(chr)
}; };
operator.init(props); operator.init(props);
} }
else if(chr.value === "|" || chr.type === DELIMITER_LINE)
{
operator = new COperatorLine();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_0
};
operator.init(props);
}
else if(chr.value === "" || chr.type === HALF_SQUARE_LEFT)
{
operator = new CHalfSquareBracket();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_0
};
operator.init(props);
}
else if(chr.value === "" || chr.type == HALF_SQUARE_RIGHT)
{
operator = new CHalfSquareBracket();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_180
};
operator.init(props);
}
else if(chr.value === "" || chr.type == HALF_SQUARE_LEFT_UPPER)
{
operator = new CHalfSquareBracket();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_MIRROR_0
};
operator.init(props);
}
else if(chr.value === "" || chr.type == HALF_SQUARE_RIGHT_UPPER)
{
operator = new CHalfSquareBracket();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_MIRROR_180
};
operator.init(props);
}
else if(chr.value === "" || chr.type == DELIMITER_DOUBLE_LINE)
{
operator = new COperatorDoubleLine();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_MIRROR_180
};
operator.init(props);
}
else if(chr.value === "" || chr.type == WHITE_SQUARE_LEFT)
{
operator = new CWhiteSquareBracket();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_0
};
operator.init(props);
}
else if(chr.value === "" || chr.type == WHITE_SQUARE_RIGHT)
{
operator = new CWhiteSquareBracket();
var props =
{
location: DELIMITER_LOCATION_LEFT,
turn: DELIMITER_TURN_180
};
operator.init(props);
}
else if( chr.value === "" || chr.type === BRACKET_EMPTY) else if( chr.value === "" || chr.type === BRACKET_EMPTY)
operator = -1; operator = -1;
else else
...@@ -3435,14 +3909,18 @@ CDelimiter.prototype.init = function(props) ...@@ -3435,14 +3909,18 @@ CDelimiter.prototype.init = function(props)
else else
this.grow = true; this.grow = true;
this.begOper = GetOperator(props.begChr); this.begOper = new COperator ( GetGlyph(props.begChr, BEGINNING_CHR) );
this.endOper = GetOperator(props.endChr); this.endOper = new COperator ( GetGlyph(props.endChr, ENDING_CHR) );
this.sepOper = new COperator ( GetGlyph(props.sepChr, SEPARATOR_CHR) );
this.sepOper = GetOperator(props.sepChr); var tPrp = this.getTxtPrp();
this.begOper.setTxtPrp(tPrp);
this.sepOper.setTxtPrp(tPrp);
this.endOper.setTxtPrp(tPrp);
if(props.shape == "match") if(props.shape == "match" || props.shapeType == DELIMITER_SHAPE_MATH)
this.shape = DELIMITER_SHAPE_MATH; this.shape = DELIMITER_SHAPE_MATH;
else if(props.shape == "centered") else if(props.shape == "centered" || props.shapeType == DELIMITER_SHAPE_CENTERED)
this.shape = DELIMITER_SHAPE_CENTERED; this.shape = DELIMITER_SHAPE_CENTERED;
else else
this.shape = DELIMITER_SHAPE_CENTERED; this.shape = DELIMITER_SHAPE_CENTERED;
...@@ -3483,37 +3961,73 @@ CDelimiter.prototype.recalculateSize = function() ...@@ -3483,37 +3961,73 @@ CDelimiter.prototype.recalculateSize = function()
} }
} }
if(this.begOper !== -1) this.begOper.fixSize(height);
width += this.begOper.size.width;
height = (height < this.begOper.size.height) ? this.begOper.size.height : height;
this.endOper.fixSize(height);
width += this.endOper.size.width;
height = (height < this.endOper.size.height) ? this.endOper.size.height : height;
this.sepOper.fixSize(height);
width += (this.nCol - 1)*this.sepOper.size.width;
height = (height < this.sepOper.size.height) ? this.sepOper.size.height : height;
/*if(this.begOper !== -1)
{ {
this.begOper.fixSize(height); this.begOper.fixSize(height);
width += this.begOper.size.width; width += this.begOper.size.width;
if(height < this.begOper.size.height)
{
center = this.begOper.size.center;
height = this.begOper.size.height;
}
//height = (height < this.begOper.size.height) ? this.begOper.size.height : height;
//center = (center < this.begOper.size.center) ? this.begOper.size.center : center;
} }
if(this.endOper !== -1) if(this.endOper !== -1)
{ {
this.endOper.fixSize(height); this.endOper.fixSize(height);
width += this.endOper.size.width; width += this.endOper.size.width;
//height = (height < this.endOper.size.height) ? this.endOper.size.height : height;
//center = (center < this.endOper.size.center) ? this.endOper.size.center : center;
if(height < this.endOper.size.height)
{
center = this.endOper.size.center;
height = this.endOper.size.height;
}
} }
if(this.sepOper !== -1) if(this.sepOper !== -1)
{ {
this.sepOper.fixSize(height); this.sepOper.fixSize(height);
width += (this.nCol - 1)*this.sepOper.size.width; width += (this.nCol - 1)*this.sepOper.size.width;
}
height = (height < this.sepOper.size.height) ? this.sepOper.size.height : height;
center = (center < this.sepOper.size.center) ? this.sepOper.size.center : center;
}*/
this.size = {width: width, height: height, center: center}; this.size = {width: width, height: height, center: center};
} }
CDelimiter.prototype.align = function(element) CDelimiter.prototype.alignOperator = function(height)
{ {
var align = 0; var align = 0;
if(this.size.height > element.size.height) if(this.size.height > height)
{ {
if(this.shape == DELIMITER_SHAPE_CENTERED) if(this.shape == DELIMITER_SHAPE_CENTERED)
align = this.size.center - element.size.center; align = this.size.center - height/2;
else if(this.shape == DELIMITER_SHAPE_MATH) else if(this.shape == DELIMITER_SHAPE_MATH)
{ {
var ascent = this.size.center, var ascent = this.size.center,
descent = this.size.height - this.size.center; descent = this.size.height - height/2;
var k = ascent/descent; var k = ascent/descent;
...@@ -3522,48 +4036,60 @@ CDelimiter.prototype.align = function(element) ...@@ -3522,48 +4036,60 @@ CDelimiter.prototype.align = function(element)
else if(k > 0.8) else if(k > 0.8)
k = 0.8; k = 0.8;
align = ascent - element.size.height/2 * k; align = this.size.center - height*k;
} }
} }
return align; return align;
} }
CDelimiter.prototype.setPosition = function(pos) CDelimiter.prototype.setPosition = function(position)
{ {
this.pos = {x: pos.x, y: pos.y - this.size.center}; this.pos = {x: position.x, y: position.y - this.size.center};
var x = this.pos.x,
y = this.pos.y;
var pos = {x: x, y: y + this.align(this.begOper)};
this.begOper.setPosition([pos]);
x += this.begOper.size.width;
var content = this.elements[0][0];
pos = {x: x, y: y + this.align(content)};
content.setPosition(pos);
/*if(this.begOper !== -1) x += content.size.width;
{
var position = { x: this.pos.x, y: this.pos.y + this.align(this.begOper) };
this.begOper.setPosition(position);
}
if(this.sepOper !== -1) var Positions = new Array();
for(var j = 1 ; j < this.nCol; j++)
{ {
var position = { x: this.pos.x, y: this.pos.y + this.align(this.sepOper) }; pos = {x: x, y: y + this.align(this.sepOper)};
this.sepOper.setPosition(position); Positions.push(pos);
} x += this.sepOper.size.width;
if(this.endOper !== -1) content = this.elements[0][j];
{ pos = {x: x, y: y + this.align(content)};
var position = { x: this.pos.x, y: this.pos.y + this.align(this.endOper) }; content.setPosition(pos);
this.endOper.setPosition(position); x += content.size.width;
} }
for(var j = 0; j < this.nCol; j++) this.sepOper.setPosition(Positions);
{
var position = pos = {x: x, y: y + this.align(this.endOper)};
{ this.endOper.setPosition([pos]);
x: this.pos.x,
y: this.pos.y + this.align(this.elements[0][j])
};
/*for(var j = 0; j < this.nCol; j++)
{
var align = this.size.center - this.elements[0][j].size.center;
var position = { x: x1, y: y1 + align};
//var position = { x: x1, y: y1 };
this.elements[0][j].setPosition(position); this.elements[0][j].setPosition(position);
}*/
x1 += this.elements[0][j].size.width;
if(this.sepOper !== -1)
x1 += this.sepOper.size.width;
}*/
} }
CDelimiter.prototype.findDisposition = function(pos) CDelimiter.prototype.findDisposition = function(pos)
{ {
...@@ -3571,13 +4097,148 @@ CDelimiter.prototype.findDisposition = function(pos) ...@@ -3571,13 +4097,148 @@ CDelimiter.prototype.findDisposition = function(pos)
} }
CDelimiter.prototype.draw = function() CDelimiter.prototype.draw = function()
{ {
/*
var x1 = this.pos.x,
y1 = this.pos.y;
if(this.begOper !== -1) if(this.begOper !== -1)
this.begOper.draw(); {
if(this.endOper !== -1) var begCoord = this.begOper.getCoordinateGlyph();
this.endOper.draw(); var begPos = {x: x1, y: y1 + this.alignOperator(begCoord.H)};
this.drawOperator(begPos, begCoord, this.begOper);
x1 += this.begOper.size.width;
}
if(this.sepOper !== -1) if(this.sepOper !== -1)
{
var sepCoord = this.sepOper.getCoordinateGlyph();
for(var j = 0; j < this.nCol-1; j++)
{
var sepPos = {x: x1 + this.elements[0][j].size.width, y: y1};
this.drawOperator(sepPos, sepCoord, this.sepOper);
x1 += this.sepOper.size.width + this.elements[0][j].size.width;
}
x1 += this.elements[0][this.nCol-1].size.width;
}
else
{
for(var j = 0; j < this.nCol; j++)
x1 += this.elements[0][j].size.width;
}
if(this.endOper !== -1)
{
var endCoord = this.endOper.getCoordinateGlyph();
var endPos = {x: x1, y: y1};
this.drawOperator(endPos, endCoord, this.endOper);
}*/
this.begOper.draw();
this.sepOper.draw(); this.sepOper.draw();
this.endOper.draw();
for(var j = 0; j < this.nCol; j++) for(var j = 0; j < this.nCol; j++)
this.elements[0][j].draw(); this.elements[0][j].draw();
} }
CDelimiter.prototype.drawOperator = function(pos, coord, glyph)
{
var X = new Array(),
Y = new Array();
for(var i = 0; i < coord.XX.length; i++)
{
X[i] = pos.x + coord.XX[i];
Y[i] = pos.y + coord.YY[i];
}
glyph.drawGlyph(X, Y);
}
CDelimiter.prototype.align = function(element)
{
var align = 0;
if(!element.IsJustDraw())
align = this.size.center - element.size.center;
else
align = (this.size.height - element.size.height)/2;
return align;
}
function COperator(glyph)
{
this.glyph = glyph;
this.positions = null;
this.coordGlyph = null;
this.size = {width: 0, height: 0};
}
COperator.prototype.draw = function()
{
if(this.glyph !== -1)
{
var lng = this.coordGlyph.XX.length;
for(var i = 0; i < this.positions.length; i++)
{
var X = new Array(),
Y = new Array();
for(var j = 0; j < lng; j++)
{
X.push(this.positions[i].x + this.coordGlyph.XX[j]);
Y.push(this.positions[i].y + this.coordGlyph.YY[j]);
}
this.glyph.draw(X, Y);
}
}
}
COperator.prototype.fixSize = function(measure)
{
if(this.glyph !== -1)
{
this.glyph.fixSize(measure);
var dims = this.glyph.getCoordinateGlyph();
this.coordGlyph = {XX: dims.XX, YY: dims.YY};
var width = this.glyph.size.width > dims.Width ? this.glyph.size.width : dims.Width,
height = this.glyph.size.height > dims.Height ? this.glyph.size.height : dims.Height;
this.size = { width: width, height: height, center: height/2};
}
}
COperator.prototype.setPosition = function(positions)
{
this.positions = positions;
}
COperator.prototype.IsJustDraw = function()
{
return true;
}
COperator.prototype.Resize = function()
{
if(this.glyph !== -1)
{
var bHor = this.glyph.loc == 0 || this.glyph.loc == 1;
if(bHor)
this.fixSize(this.size.width);
else
this.fixSize(this.size.height);
}
}
COperator.prototype.relate = function(parent)
{
this.Parent = parent;
}
COperator.prototype.setTxtPrp = function(txtPrp)
{
if(this.glyph !== -1)
this.glyph.setTxtPrp(txtPrp);
}
\ No newline at end of file
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