Commit 7e68153a 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@54974 954022d7-b5bf-4e40-9824-e11837661b57
parent 1f215953
...@@ -1833,108 +1833,108 @@ DrawingObjectsController.prototype = ...@@ -1833,108 +1833,108 @@ DrawingObjectsController.prototype =
{ {
if(vert_axis_props.crossesRule === c_oAscCrossesRule.auto) if(vert_axis_props.crossesRule === c_oAscCrossesRule.auto)
{ {
val_ax.crossAx.setCrossesAt(null) val_ax.crossAx.setCrossesAt(null);
val_ax.crossAx.setCrosses(CROSSES_AUTO_ZERO); val_ax.crossAx.setCrosses(CROSSES_AUTO_ZERO);
} }
else if(vert_axis_props.crossesRule === c_oAscCrossesRule.value) else if(vert_axis_props.crossesRule === c_oAscCrossesRule.value)
{ {
if(isRealNumber(vert_axis_props.crosses)) if(isRealNumber(vert_axis_props.crosses))
{ {
val_ax.crossAx.setCrossesAt(vert_axis_props.crosses) val_ax.crossAx.setCrossesAt(vert_axis_props.crosses);
val_ax.crossAx.setCrosses(null); val_ax.crossAx.setCrosses(null);
} }
} }
else if(vert_axis_props.crossesRule === c_oAscCrossesRule.maxValue) else if(vert_axis_props.crossesRule === c_oAscCrossesRule.maxValue)
{ {
val_ax.crossAx.setCrossesAt(null) val_ax.crossAx.setCrossesAt(null);
val_ax.crossAx.setCrosses(CROSSES_MAX); val_ax.crossAx.setCrosses(CROSSES_MAX);
} }
} }
}
var hor_axis_props = chartSettings.getHorAxisProps(); var hor_axis_props = chartSettings.getHorAxisProps();
if(hor_axis_props) if(hor_axis_props)
{
var intervalBetweenTick = hor_axis_props.getIntervalBetweenTick();
var intervalBetweenLabelsRule = hor_axis_props.getIntervalBetweenLabelsRule();
var intervalBetweenLabels = hor_axis_props.getIntervalBetweenLabels();
var invertCatOrder = hor_axis_props.getInvertCatOrder();
var labelsAxisDistance = hor_axis_props.getLabelsAxisDistance();
var axisType = hor_axis_props.getAxisType();
var majorTickMark = hor_axis_props.getMajorTickMark();
var minorTickMark = hor_axis_props.getMinorTickMark();
var tickLabelsPos = hor_axis_props.getTickLabelsPos();
var crossesRule = hor_axis_props.getCrossesRule();
var crosses = hor_axis_props.getCrosses();
var labelsPosition = hor_axis_props.getLabelsPosition();
if(isRealNumber(intervalBetweenTick))
cat_ax.setTickMarkSkip(intervalBetweenTick);
if(isRealNumber(intervalBetweenLabelsRule))
{ {
var intervalBetweenTick = hor_axis_props.getIntervalBetweenTick(); if(intervalBetweenLabelsRule === c_oAscBetweenLabelsRule.auto)
var intervalBetweenLabelsRule = hor_axis_props.getIntervalBetweenLabelsRule();
var intervalBetweenLabels = hor_axis_props.getIntervalBetweenLabels();
var invertCatOrder = hor_axis_props.getInvertCatOrder();
var labelsAxisDistance = hor_axis_props.getLabelsAxisDistance();
var axisType = hor_axis_props.getAxisType();
var majorTickMark = hor_axis_props.getMajorTickMark();
var minorTickMark = hor_axis_props.getMinorTickMark();
var tickLabelsPos = hor_axis_props.getTickLabelsPos();
var crossesRule = hor_axis_props.getCrossesRule();
var crosses = hor_axis_props.getCrosses();
var labelsPosition = hor_axis_props.getLabelsPosition();
if(isRealNumber(intervalBetweenTick))
cat_ax.setTickMarkSkip(intervalBetweenTick);
if(isRealNumber(intervalBetweenLabelsRule))
{ {
if(intervalBetweenLabelsRule === c_oAscBetweenLabelsRule.auto) if(isRealNumber(cat_ax.tickLblSkip))
{ {
if(isRealNumber(cat_ax.tickLblSkip)) cat_ax.setTickLblSkip(null);
{
cat_ax.setTickLblSkip(null);
}
}
else if(intervalBetweenLabelsRule === c_oAscBetweenLabelsRule.manual && isRealNumber(intervalBetweenLabels))
{
cat_ax.setTickLblSkip(intervalBetweenLabels);
} }
} }
else if(intervalBetweenLabelsRule === c_oAscBetweenLabelsRule.manual && isRealNumber(intervalBetweenLabels))
if(!cat_ax.scaling)
cat_ax.setScaling(new CScaling());
scaling = cat_ax.scaling;
if(isRealBool(invertCatOrder))
scaling.setOrientation(invertCatOrder ? ORIENTATION_MAX_MIN : ORIENTATION_MIN_MAX);
if(isRealNumber(labelsAxisDistance))
cat_ax.setLblOffset(labelsAxisDistance);
if(isRealNumber(axisType))
{ {
//TODO cat_ax.setTickLblSkip(intervalBetweenLabels);
} }
}
if(!cat_ax.scaling)
cat_ax.setScaling(new CScaling());
scaling = cat_ax.scaling;
if(isRealBool(invertCatOrder))
scaling.setOrientation(invertCatOrder ? ORIENTATION_MAX_MIN : ORIENTATION_MIN_MAX);
if(isRealNumber(labelsAxisDistance))
cat_ax.setLblOffset(labelsAxisDistance);
if(isRealNumber(axisType))
{
//TODO
}
if(isRealNumber(majorTickMark) && isRealNumber(MENU_SETTINGS_TICK_MARK[majorTickMark])) if(isRealNumber(majorTickMark) && isRealNumber(MENU_SETTINGS_TICK_MARK[majorTickMark]))
cat_ax.setMajorTickMark(MENU_SETTINGS_TICK_MARK[majorTickMark]); cat_ax.setMajorTickMark(MENU_SETTINGS_TICK_MARK[majorTickMark]);
if(isRealNumber(minorTickMark) && isRealNumber(MENU_SETTINGS_TICK_MARK[minorTickMark])) if(isRealNumber(minorTickMark) && isRealNumber(MENU_SETTINGS_TICK_MARK[minorTickMark]))
cat_ax.setMinorTickMark(MENU_SETTINGS_TICK_MARK[minorTickMark]); cat_ax.setMinorTickMark(MENU_SETTINGS_TICK_MARK[minorTickMark]);
if(isRealNumber(tickLabelsPos) && isRealNumber(MENU_SETTINGS_LABELS_POS[tickLabelsPos])) if(isRealNumber(tickLabelsPos) && isRealNumber(MENU_SETTINGS_LABELS_POS[tickLabelsPos]))
cat_ax.setTickLblPos(MENU_SETTINGS_LABELS_POS[tickLabelsPos]); cat_ax.setTickLblPos(MENU_SETTINGS_LABELS_POS[tickLabelsPos]);
if(isRealNumber(crossesRule) && isRealObject(cat_ax.crossAx)) if(isRealNumber(crossesRule) && isRealObject(cat_ax.crossAx))
{
if(crossesRule === c_oAscCrossesRule.auto)
{ {
if(crossesRule === c_oAscCrossesRule.auto) cat_ax.crossAx.setCrossesAt(null);
{ cat_ax.crossAx.setCrosses(CROSSES_AUTO_ZERO);
cat_ax.crossAx.setCrossesAt(null) }
cat_ax.crossAx.setCrosses(CROSSES_AUTO_ZERO); else if(crossesRule === c_oAscCrossesRule.value)
} {
else if(crossesRule === c_oAscCrossesRule.value) if(isRealNumber(crosses))
{
if(isRealNumber(crosses))
{
cat_ax.crossAx.setCrossesAt(crosses)
cat_ax.crossAx.setCrosses(null);
}
}
else if(crossesRule === c_oAscCrossesRule.maxValue)
{ {
cat_ax.crossAx.setCrossesAt(null) cat_ax.crossAx.setCrossesAt(crosses);
cat_ax.crossAx.setCrosses(CROSSES_MAX); cat_ax.crossAx.setCrosses(null);
} }
} }
else if(crossesRule === c_oAscCrossesRule.maxValue)
if(isRealNumber(labelsPosition) && isRealObject(cat_ax.crossAx)) {
cat_ax.crossAx(labelsPosition === c_oAscLabelsPosition.byDivisions ? CROSS_BETWEEN_MID_CAT : CROSS_BETWEEN_BETWEEN) cat_ax.crossAx.setCrossesAt(null);
cat_ax.crossAx.setCrosses(CROSSES_MAX);
}
} }
if(isRealNumber(labelsPosition) && isRealObject(cat_ax.crossAx))
cat_ax.crossAx.setCrossBetween(labelsPosition === c_oAscLabelsPosition.byDivisions ? CROSS_BETWEEN_MID_CAT : CROSS_BETWEEN_BETWEEN);
} }
} }
......
...@@ -2741,7 +2741,7 @@ function CreateScatterChart(asc_chart) ...@@ -2741,7 +2741,7 @@ function CreateScatterChart(asc_chart)
pt.setVal(asc_series[i].Val.NumCache[j].val); pt.setVal(asc_series[i].Val.NumCache[j].val);
num_cache.addPt(pt); num_cache.addPt(pt);
} }
//if(parsedHeaders.bTop) //if(parsedHeaders.bTop)
//{ //{
// series.setCat(new CCat()); // series.setCat(new CCat());
// var cat = series.cat; // var cat = series.cat;
...@@ -2987,7 +2987,6 @@ function CreateStockChart(asc_chart) ...@@ -2987,7 +2987,6 @@ function CreateStockChart(asc_chart)
return chart_space; return chart_space;
} }
function CreateDefaultAxises(valFormatCode) function CreateDefaultAxises(valFormatCode)
{ {
var cat_ax = new CCatAx(); var cat_ax = new CCatAx();
......
...@@ -1008,6 +1008,14 @@ CTextBody.prototype = ...@@ -1008,6 +1008,14 @@ CTextBody.prototype =
{ {
this.parent && this.parent.Refresh_RecalcData2(pageIndex); this.parent && this.parent.Refresh_RecalcData2(pageIndex);
}, },
getContentOneStringSizes: function()
{
//TODO: потом переделать
this.content.Reset(0, 0, 20000, 20000);//выставляем большую ширину чтобы текст расчитался в одну строку.
this.content.Recalculate_Page(0, true);
return {w: this.content.Content[0].Lines[0].Ranges[0].W+0.1, h: this.content.Get_SummaryHeight()+0.1};
},
getRectWidth: function(maxWidth) getRectWidth: function(maxWidth)
{ {
......
...@@ -2556,9 +2556,9 @@ Format ...@@ -2556,9 +2556,9 @@ Format
<label>max value</label><input type="radio" name="crossesCat" value="maxValue" id="crossesMaxAxCatInput"> <label>max value</label><input type="radio" name="crossesCat" value="maxValue" id="crossesMaxAxCatInput">
<br> <br>
<label>Axis Position</label><br> <label>Axis Position</label><br>
<label>by divisions:</label><input type="radio" id="checkBoxByDivisionsInput" checked="checked"> <label>by divisions:</label><input type="radio" id="checkBoxByDivisionsInput" name="axis_pos_cat">
<br> <br>
<label>between divisions:</label><input type="radio" id="checkBoxBetweenDivisionsInput"> <label>between divisions:</label><input type="radio" id="checkBoxBetweenDivisionsInput" checked="checked" name="axis_pos_cat">
<div style="width: inherit; height: 1px; background: rgb(127,157,185)"></div> <div style="width: inherit; height: 1px; background: rgb(127,157,185)"></div>
<button id="valApplyCatAxisProps"> <button id="valApplyCatAxisProps">
Apply Props Apply Props
......
...@@ -3132,7 +3132,7 @@ ...@@ -3132,7 +3132,7 @@
else if($("#crossesCatAxValInput").attr("checked")) else if($("#crossesCatAxValInput").attr("checked"))
{ {
axis_settings.putCrossesRule(c_oAscCrossesRule.value); axis_settings.putCrossesRule(c_oAscCrossesRule.value);
axis_settings.putCrosses($("#crossesCatInput").attr("value")); axis_settings.putCrosses(parseFloat($("#crossesCatInput").attr("value")));
} }
else else
{ {
......
...@@ -2344,7 +2344,6 @@ CChartSpace.prototype.recalculateAxis = function() ...@@ -2344,7 +2344,6 @@ CChartSpace.prototype.recalculateAxis = function()
arr_strings.push(calc_value + ""); arr_strings.push(calc_value + "");
} }
} }
//расчитаем подписи для вертикальной оси найдем ширину максимальной и возьмем её удвоенную за ширину подписей верт оси //расчитаем подписи для вертикальной оси найдем ширину максимальной и возьмем её удвоенную за ширину подписей верт оси
val_ax.labels = new CValAxisLabels(this); val_ax.labels = new CValAxisLabels(this);
var max_width = 0; var max_width = 0;
...@@ -2373,7 +2372,8 @@ CChartSpace.prototype.recalculateAxis = function() ...@@ -2373,7 +2372,8 @@ CChartSpace.prototype.recalculateAxis = function()
val_ax.labels.arrLabels[i].tx.rich.content.Reset(0,0, max_width, 20000); val_ax.labels.arrLabels[i].tx.rich.content.Reset(0,0, max_width, 20000);
val_ax.labels.arrLabels[i].tx.rich.content.Recalculate_Page(0, true); val_ax.labels.arrLabels[i].tx.rich.content.Recalculate_Page(0, true);
} }
val_ax.labels.extX = max_width*2; var val_axis_labels_gap = val_ax.labels.arrLabels[0].tx.rich.content.Content[0].CompiledPr.Pr.TextPr.FontSize*25.4/72;
val_ax.labels.extX = max_width + val_axis_labels_gap;
//расчитаем подписи для горизонтальной оси //расчитаем подписи для горизонтальной оси
var ser = chart_object.series[0]; var ser = chart_object.series[0];
...@@ -2405,181 +2405,840 @@ CChartSpace.prototype.recalculateAxis = function() ...@@ -2405,181 +2405,840 @@ CChartSpace.prototype.recalculateAxis = function()
string_pts.push({val:i+1 + ""}); string_pts.push({val:i+1 + ""});
} }
} }
/*---------------------расчет позиции блока с подписями вертикальной оси-----------------------------------------------------------------------------*/
//расчитаем ширину интервала без учета горизонтальной оси; //расчитаем ширину интервала без учета горизонтальной оси;
var crosses = val_ax.crosses; var crosses;//номер категории в которой вертикалная ось пересекает горизонтальную;
if(crosses === CROSSES_AUTO_ZERO) if(val_ax.crosses === CROSSES_AUTO_ZERO || val_ax.crosses === CROSSES_MIN)
crosses = 1;
else if(val_ax.crosses === CROSSES_MAX)
crosses = string_pts.length;
else if(isRealNumber(val_ax.crossesAt))
{ {
crosses = 0; if(val_ax.crossesAt <= string_pts.length + 1 && val_ax.crossesAt > 0)
crosses = val_ax.crossesAt;
else if(val_ax.crossesAt <= 0)
crosses = 1;
else
crosses = string_pts.length;
} }
else else
{ crosses = 1;
crosses -=1;
} var cat_ax_orientation = cat_ax.scaling && isRealNumber(cat_ax.scaling.orientation) ? cat_ax.scaling.orientation : ORIENTATION_MIN_MAX;
var point_width = rect.w/string_pts.length; var point_width = rect.w/string_pts.length;
//смотрим выходят ли подписи верт. оси влево: TODO:вправо нужно потом рассмотреть var labels_pos = val_ax.tickLblPos;
var left_points_width = point_width*crosses;//общая ширина левых точек если считать что точки занимают все пространство var cross_between = isRealNumber(val_ax.crossBetween) ? val_ax.crossBetween : CROSS_BETWEEN_MID_CAT;
if(left_points_width < val_ax.labels.extX)//подписи верт. оси выходят за пределы области построения
{ var left_val_ax_labels_align = true;//приленгание подписей оси значений к левому краю.
point_width = (rect.w - val_ax.labels.extX)/(string_pts.length - crosses);//делим ширину оставшуюся после вычета ширины на количество оставшихся справа точек
val_ax.labels.x = rect.x; var intervals_count = cross_between === CROSS_BETWEEN_MID_CAT ? string_pts.length - 1 : string_pts.length;
} var point_interval = rect.w/intervals_count;//интервал между точками. Зависит от crossBetween, а также будет потом корректироваться в зависимости от подписей вертикальной и горизонтальной оси.
if(cross_between === CROSS_BETWEEN_MID_CAT)
point_interval = rect.w/(string_pts.length - 1);
else else
{ point_interval = rect.w/string_pts.length;
point_width = rect.w/string_pts.length;
val_ax.labels.x = rect.x + left_points_width - val_ax.labels.extX;
}
//проверим умещаются ли подписи горизонтальной оси в point_width var left_points_width, right_point_width;
cat_ax.labels = new CValAxisLabels(this); var arr_cat_labels_points = [];//массив середин подписей горизонтальной оси; i-й элемент - x-координата центра подписи категории с номером i;
var tick_lbl_skip = isRealNumber(cat_ax.tickLblSkip) ? cat_ax.tickLblSkip : 1; if(cat_ax_orientation === ORIENTATION_MIN_MAX)
var max_min_width = 0;
var max_max_width = 0;
for(i = 0; i < string_pts.length; ++i)
{ {
var dlbl = null; if(labels_pos === TICK_LABEL_POSITION_NEXT_TO || !isRealNumber(labels_pos)) //подписи рядом с осью
if(i%tick_lbl_skip === 0)
{ {
dlbl = new CDLbl(); if(val_ax.crosses === CROSSES_MAX)
dlbl.parent = cat_ax; {
dlbl.chart = this; left_val_ax_labels_align = false;
dlbl.spPr = cat_ax.spPr; val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
dlbl.txPr = cat_ax.txPr; point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
dlbl.tx = new CChartText(); val_ax.posX = val_ax.labels.x;
dlbl.tx.rich = CreateTextBodyFromString(string_pts[i].val, this.getDrawingDocument(), dlbl); if(cross_between === CROSS_BETWEEN_MID_CAT)
dlbl.recalculate(); {
var min_max = dlbl.tx.rich.content.Recalculate_MinMaxContentWidth(); for(i = 0; i < string_pts.length; ++i)
var max_min_content_width = min_max.Min; arr_cat_labels_points[i] = rect.x + point_interval*i;
if(max_min_content_width > max_min_width) }
max_min_width = max_min_content_width; else
if(min_max.Max > max_max_width) {
max_max_width = min_max.Max; for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = point_interval/2 + rect.x + point_interval*i;
}
}
else
{
left_points_width = point_interval*(crosses-1);//общая ширина левых точек если считать что точки занимают все пространство
if(left_points_width < val_ax.labels.extX)//подписи верт. оси выходят за пределы области построения
{
var right_intervals_count = intervals_count - (crosses-1);//количесво интервалов правее вертикальной оси
//скорректируем point_interval, поделив расстояние, которое осталось справа от подписей осей на количество интервалов справа
point_interval = (rect.w - val_ax.labels.extX)/right_intervals_count;
val_ax.labels.x = rect.x;
var start_point = val_ax.labels.x + val_ax.labels.extX - (crosses-1)*point_interval;//x-координата точки, где начинается собственно область диаграммы
if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = start_point + point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = point_interval/2 + start_point + point_interval*i;
}
}
else
{
val_ax.labels.x = rect.x + left_points_width - val_ax.labels.extX;
if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = point_interval/2 + rect.x + point_interval*i;
}
}
val_ax.posX = val_ax.labels.x + val_ax.labels.extX;
}
}
else if(labels_pos === TICK_LABEL_POSITION_LOW)//подписи слева от области построения
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
val_ax.labels.x = rect.x;
if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + val_ax.labels.extX + point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + val_ax.labels.extX + point_interval/2 + point_interval*i;
}
val_ax.posX = val_ax.labels.x + val_ax.labels.extX + point_interval*(crosses-1);;
}
else if(labels_pos === TICK_LABEL_POSITION_HIGH)//подписи справа от области построения
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
left_val_ax_labels_align = false;
if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = point_interval/2 + rect.x + point_interval*i;
}
val_ax.posX = rect.x + point_interval*(crosses-1);
}
else
{
val_ax.labels = null;
if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = point_interval/2 + rect.x + point_interval*i;
}
val_ax.posX = rect.x + point_interval*(crosses-1);
} }
cat_ax.labels.arrLabels.push(dlbl);
} }
if(max_min_width < point_width)//значит текст каждой из точек умещается в point_width else
{ {//то же самое, только зеркально отраженное
var max_height = 0; if(labels_pos === TICK_LABEL_POSITION_NEXT_TO || !isRealNumber(labels_pos)) //подписи рядом с осью
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
{ {
var content = cat_ax.labels.arrLabels[i].tx.rich.content; if(val_ax.crosses === CROSSES_MAX)
content.Set_ApplyToAll(true); {
content.Set_ParagraphAlign(align_Center); val_ax.labels.x = rect.x;
content.Set_ApplyToAll(false); point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
content.Reset(0, 0, point_width, 20000); if(cross_between === CROSS_BETWEEN_MID_CAT)
content.Recalculate_Page(0, true); {
var cur_height = content.Get_SummaryHeight(); for(i = 0; i < string_pts.length; ++i)
if(cur_height > max_height) arr_cat_labels_points[i] = rect.x + rect.w - point_interval*i;
max_height = cur_height; }
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + rect.w - point_interval/2 - point_interval*i;
}
val_ax.posX = val_ax.labels.x + val_ax.labels.extX;
}
else
{
left_val_ax_labels_align = false;
right_point_width = point_interval*(crosses-1);
if(right_point_width < val_ax.labels.extX)
{
val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
var left_points_interval_count = intervals_count - (crosses - 1);
point_interval = (val_ax.labels.x - rect.x)/left_points_interval_count;
var start_point_right = rect.x + point_interval*intervals_count;
if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = start_point_right - point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = start_point_right - point_interval/2 - point_interval*i;
}
}
else
{
val_ax.labels.x = rect.x + rect.w - right_point_width;
if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + rect.w - point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + rect.w - point_interval/2 - point_interval*i;
}
}
val_ax.posX = val_ax.labels.x;
}
} }
val_ax.labels.y = rect.y; else if(labels_pos === TICK_LABEL_POSITION_LOW)//подписи справа от области построения
val_ax.labels.extY = rect.h; {
left_val_ax_labels_align = false;
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
val_ax.labels.x = rect.x + rect.w - val_ax.labels.extX;
cat_ax.labels.extY = max_height + gap_hor_axis; if(cross_between === CROSS_BETWEEN_MID_CAT)
cat_ax.labels.x = val_ax.labels.x+val_ax.labels.extX - left_points_width; {
cat_ax.labels.extX = point_width*string_pts.length; for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = val_ax.labels.x - point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = val_ax.labels.x - point_interval/2 - point_interval*i;
}
val_ax.posX = rect.x + rect.w - point_interval*(crosses-1) - val_ax.labels.extX;
}
else if(labels_pos === TICK_LABEL_POSITION_HIGH)//подписи слева от области построения
{
point_interval = (rect.w - val_ax.labels.extX)/intervals_count;
val_ax.labels.x = rect.x;
var crosses_at = isRealNumber(cat_ax.crossesAt) ? cat_ax.crossesAt : arr_val[arr_val.length-1]; if(cross_between === CROSS_BETWEEN_MID_CAT)
var interval = arr_val[arr_val.length-1] - arr_val[0]; {
cat_ax.labels.y = val_ax.labels.y + val_ax.labels.extY - ((arr_val[arr_val.length-1] - crosses_at)/interval)*val_ax.labels.extY; for(i = 0; i < string_pts.length; ++i)
//посмотрим на сколько выходят подписи вниз за пределы ректа arr_cat_labels_points[i] = rect.x + rect.w - point_interval*i;
var gap = cat_ax.labels.y + cat_ax.labels.extY - (rect.y + rect.h); }
if(gap > 0) else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + rect.w - point_interval/2 - point_interval*i;
}
val_ax.posX = rect.x + rect.w - point_interval*(crosses-1);
}
else
{ {
val_ax.labels.extY *= ((rect.h - gap)/rect.h); val_ax.labels = null;
cat_ax.labels.y = val_ax.labels.y + val_ax.labels.extY - ((arr_val[arr_val.length-1] - crosses_at)/interval)*val_ax.labels.extY; if(cross_between === CROSS_BETWEEN_MID_CAT)
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + rect.w - point_interval*i;
}
else
{
for(i = 0; i < string_pts.length; ++i)
arr_cat_labels_points[i] = rect.x + rect.w - point_interval/2 - point_interval*i;
}
val_ax.posX = rect.x + rect.w - point_interval*(crosses-1);
} }
}
cat_ax.xPoints = []; var diagram_width = point_interval*intervals_count;//размер области с самой диаграммой позже будет корректироватся;
for(i = 0; i <cat_ax.labels.arrLabels.length; ++i) var max_cat_label_width = diagram_width / string_pts.length; // максимальная ширина подписи горизонтальной оси;
cat_ax.labels = null;
var b_rotated = false;//флаг означает, что водписи не уместились в отведенное для них пространство и их пришлось перевернуть.
//проверим умещаются ли подписи горизонтальной оси в point_interval
if(TICK_LABEL_POSITION_NONE !== cat_ax.tickLblPos) //будем корректировать вертикальные подписи только если есть горизонтальные
{
cat_ax.labels = new CValAxisLabels(this);
var tick_lbl_skip = isRealNumber(cat_ax.tickLblSkip) ? cat_ax.tickLblSkip : 1;
var max_min_width = 0;
var max_max_width = 0;
for(i = 0; i < string_pts.length; ++i)
{ {
cat_ax.labels.arrLabels[i].setPosition(cat_ax.labels.x + point_width*i, cat_ax.labels.y + gap_hor_axis); var dlbl = null;
cat_ax.xPoints.push({pos: cat_ax.labels.x + point_width*(i+0.5), val: i}); if(i%tick_lbl_skip === 0)
{
dlbl = new CDLbl();
dlbl.parent = cat_ax;
dlbl.chart = this;
dlbl.spPr = cat_ax.spPr;
dlbl.txPr = cat_ax.txPr;
dlbl.tx = new CChartText();
dlbl.tx.rich = CreateTextBodyFromString(string_pts[i].val, this.getDrawingDocument(), dlbl);
dlbl.recalculate();
var min_max = dlbl.tx.rich.content.Recalculate_MinMaxContentWidth();
var max_min_content_width = min_max.Min;
if(max_min_content_width > max_min_width)
max_min_width = max_min_content_width;
if(min_max.Max > max_max_width)
max_max_width = min_max.Max;
}
cat_ax.labels.arrLabels.push(dlbl);
} }
var stake_offset = isRealNumber(cat_ax.lblOffset) ? cat_ax.lblOffset/100 : 1;
var labels_offset = cat_ax.labels.arrLabels[0].tx.rich.content.Content[0].CompiledPr.Pr.TextPr.FontSize*(25.4/72)*stake_offset;
if(max_min_width < max_cat_label_width)//значит текст каждой из точек умещается в point_width
{
var max_height = 0;
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
{
if(cat_ax.labels.arrLabels[i])
{
var content = cat_ax.labels.arrLabels[i].tx.rich.content;
content.Set_ApplyToAll(true);
content.Set_ParagraphAlign(align_Center);
content.Set_ApplyToAll(false);
content.Reset(0, 0, max_cat_label_width, 20000);
content.Recalculate_Page(0, true);
var cur_height = content.Get_SummaryHeight();
if(cur_height > max_height)
max_height = cur_height;
}
}
var dist = val_ax.labels.extY/(val_ax.labels.arrLabels.length-1); cat_ax.labels.extY = max_height + labels_offset;
for(i = 0; i < val_ax.labels.arrLabels.length; ++i) if(cross_between === CROSS_BETWEEN_MID_CAT) //корректируем позиции центров подписей горизонтальной оси, положение вертикальной оси и её подписей
{
var left_gap_point, right_gap_point;
if(cat_ax_orientation === ORIENTATION_MIN_MAX)
{
var first_label_left_gap = cat_ax.labels.arrLabels[0].tx.rich.getMaxContentWidth(max_cat_label_width)/2;//на сколько вправа выходит первая подпись
var last_labels_right_gap = cat_ax.labels.arrLabels[cat_ax.labels.arrLabels.length - 1] ? cat_ax.labels.arrLabels[cat_ax.labels.arrLabels.length - 1].tx.rich.getMaxContentWidth(max_cat_label_width)/2 : 0;
//смотрим, выходит ли подпись первой категориии выходит за пределы области построения
left_gap_point = arr_cat_labels_points[0] - first_label_left_gap;
if(rect.x > left_gap_point)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси, если они есть
{
val_ax.labels.x = rect.x + (val_ax.labels.x - left_gap_point)/(rect.x + rect.w - left_gap_point);
}
//скорректируем point_interval
point_interval *= (rect.x + rect.w - left_gap_point)/(rect.x + rect.w - left_gap_point);
//скорректируем arr_cat_labels_points
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - left_gap_point)/(rect.x + rect.w - left_gap_point);
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + (val_ax.posX - left_gap_point)/(rect.x + rect.w - left_gap_point);
}
//смотри выходит ли подпись последней категории за пределы области построения
right_gap_point = arr_cat_labels_points[arr_cat_labels_points.length - 1] + last_labels_right_gap;
if(right_gap_point > rect.x + rect.w)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси
{
val_ax.labels.x = rect.x + (val_ax.labels.x - rect.x)/(right_gap_point - rect.x);
}
//скорректируем point_interval
point_interval *= (right_gap_point - rect.x)/(rect.x + rect.w - rect.x);
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - rect.x)/(right_gap_point - rect.x);
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + (val_ax.posX - rect.x)/(right_gap_point - rect.x);
}
}
else
{
var last_label_left_gap = cat_ax.labels.arrLabels[cat_ax.labels.arrLabels.length - 1] ? cat_ax.labels.arrLabels[cat_ax.labels.arrLabels.length - 1].tx.rich.getMaxContentWidth(max_cat_label_width)/2 : 0;
var first_label_right_gap = cat_ax.labels.arrLabels[0].tx.rich.getMaxContentWidth(max_cat_label_width)/2;
left_gap_point = arr_cat_labels_points[arr_cat_labels_points.length - 1] - last_label_left_gap;
right_gap_point = arr_cat_labels_points[0] + first_label_right_gap;
if(rect.x > left_gap_point)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси, если они есть
{
val_ax.labels.x = rect.x + (val_ax.labels.x - left_gap_point)/(rect.x + rect.w - left_gap_point);
}
//скорректируем point_interval
point_interval *= (rect.x + rect.w - left_gap_point)/(rect.x + rect.w - left_gap_point);
//скорректируем arr_cat_labels_points
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - left_gap_point)/(rect.x + rect.w - left_gap_point);
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + rect.x + (val_ax.posX - left_gap_point)/(rect.x + rect.w - left_gap_point);
}
if(right_gap_point > rect.x + rect.w)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси
{
val_ax.labels.x = rect.x + (val_ax.labels.x - rect.x)/(right_gap_point - rect.x);
}
//скорректируем point_interval
point_interval *= (right_gap_point - rect.x)/(rect.x + rect.w - rect.x);
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - rect.x)/(right_gap_point - rect.x);
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + (val_ax.posX - rect.x)/(right_gap_point - rect.x);
}
}
}
}
else
{ {
val_ax.labels.arrLabels[i].setPosition(val_ax.labels.x, val_ax.labels.y + dist*(val_ax.labels.arrLabels.length - i -1) b_rotated = true;
-val_ax.labels.arrLabels[i].tx.rich.content.Get_SummaryHeight()/2); //пока сделаем без обрезки
val_ax.yPoints[i].pos = val_ax.labels.y + dist*(val_ax.labels.arrLabels.length - i -1); var arr_left_points = [];
var arr_right_points = [];
var max_rotated_height = 0;
//смотрим на сколько подписи горизонтальной оси выходят влево за пределы области построения
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
{
if(cat_ax.labels.arrLabels[i])
{
//сначала расчитаем высоту и ширину подписи так чтобы она умещалась в одну строку
var wh = cat_ax.labels.arrLabels[i].tx.rich.getContentOneStringSizes();
arr_left_points[i] = arr_cat_labels_points[i] - (wh.w*Math.cos(Math.PI/4) + wh.h*Math.sin(Math.PI/4) - wh.h*Math.sin(Math.PI/4)/2);//вычитаем из точки привязки ширину получившейся подписи
arr_right_points[i] = arr_cat_labels_points[i] + wh.h*Math.sin(Math.PI/4)/2;
var h2 = wh.w*Math.sin(Math.PI/4) + wh.h*Math.cos(Math.PI/4);
if(h2 > max_rotated_height)
max_rotated_height = h2;
}
else
{//подписи нет
arr_left_points[i] = arr_cat_labels_points[i];
arr_right_points[i] = arr_cat_labels_points[i];
}
}
cat_ax.labels.extY = max_rotated_height + labels_offset;
//
left_gap_point = Math.min.apply(Math, arr_left_points);
right_gap_point = Math.max.apply(Math, arr_right_points);
if(ORIENTATION_MIN_MAX === cat_ax_orientation)
{
if(rect.x > left_gap_point)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси, если они есть
{
val_ax.labels.x = rect.x + (val_ax.labels.x - left_gap_point)*(rect.w/(rect.x + rect.w - left_gap_point));
}
//скорректируем point_interval
point_interval *= rect.w/(rect.x + rect.w - left_gap_point);
//скорректируем arr_cat_labels_points
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - left_gap_point)*(rect.w/(rect.x + rect.w - left_gap_point));
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + (val_ax.posX - left_gap_point)*(rect.w/(rect.x + rect.w - left_gap_point));
}
//смотри выходит ли подпись последней категории за пределы области построения
if(right_gap_point > rect.x + rect.w)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси
{
val_ax.labels.x = rect.x + (val_ax.labels.x - rect.x)*(rect.w/(right_gap_point - rect.x));
}
//скорректируем point_interval
point_interval *= (right_gap_point - rect.x)/(rect.x + rect.w - rect.x);
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - rect.x)*(rect.w/(right_gap_point - rect.x));
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + (val_ax.posX - rect.x)*(rect.w/(right_gap_point - rect.x));
}
}
else
{
if(rect.x > left_gap_point)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси, если они есть
{
val_ax.labels.x = rect.x + (val_ax.labels.x - left_gap_point)*(rect.w/(rect.x + rect.w - left_gap_point));
}
//скорректируем point_interval
point_interval *= (rect.w)/(rect.x + rect.w - left_gap_point);
//скорректируем arr_cat_labels_points
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - left_gap_point)*(rect.w/(rect.x + rect.w - left_gap_point));
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + (val_ax.posX - left_gap_point)*(rect.w/(rect.x + rect.w - left_gap_point));
}
if(right_gap_point > rect.x + rect.w)
{
if(val_ax.labels)//скорректируем позицию подписей вертикальной оси
{
val_ax.labels.x = rect.x + (val_ax.labels.x - rect.x)*(rect.w/(right_gap_point - rect.x));
}
//скорректируем point_interval
point_interval *= (right_gap_point - rect.x)/(rect.x + rect.w - rect.x);
for(i = 0; i < arr_cat_labels_points.length; ++i)
{
arr_cat_labels_points[i] = rect.x + (arr_cat_labels_points[i] - rect.x)(rect.w/(right_gap_point - rect.x));
}
//скорректируем позицию вертикальной оси
val_ax.posX = rect.x + (val_ax.posX - rect.x)*(rect.w/(right_gap_point - rect.x));
}
}
} }
} }
//расчет позиции блока с подписями горизонтальной оси
var cat_labels_align_bottom = true;
/*-----------------------------------------------------------------------*/
var crosses_val_ax;//значение на ветикальной оси в котором её пересекает горизонтальная
if(cat_ax.crosses === CROSSES_AUTO_ZERO)
{
if(arr_val[0] <=0 && arr_val[arr_val.length-1] >= 0)
crosses_val_ax = 0;
else if(arr_val[arr_val.length-1] < 0)
crosses_val_ax = arr_val[arr_val.length-1];
else
crosses_val_ax = arr_val[0];
}
else if(cat_ax.crosses === CROSSES_MIN)
{
crosses_val_ax = arr_val[0];
}
else if(cat_ax.crosses === CROSSES_MAX)
{
crosses_val_ax = arr_val[arr_val.length - 1];
}
else if(isRealNumber(cat_ax.crossesAt) && cat_ax.crossesAt >= arr_val[0] && cat_ax.crossesAt <= arr_val[arr_val.length - 1])
{
//сделаем провеку на попадание в интервал
if(cat_ax.crossesAt >= arr_val[0] && cat_ax.crossesAt <= arr_val[arr_val.length - 1])
crosses_val_ax = cat_ax.crossesAt;
}
else else
{ //ведем себя как в случае (cat_ax.crosses === CROSSES_AUTO_ZERO)
if(arr_val[0] <=0 && arr_val[arr_val.length-1] >= 0)
crosses_val_ax = 0;
else if(arr_val[arr_val.length-1] < 0)
crosses_val_ax = arr_val[arr_val.length-1];
else
crosses_val_ax = arr_val[0];
}
var val_ax_orientation = val_ax.scaling && isRealNumber(val_ax.scaling.orientation) ? val_ax.scaling.orientation : ORIENTATION_MIN_MAX;
var hor_labels_pos = cat_ax.tickLblPos;
var arr_val_labels_points = [];//массив середин подписей вертикальной оси; i-й элемент - y-координата центра подписи i-огто значения;
var unit_height = rect.h/(arr_val[arr_val.length - 1] - arr_val[0]);//высота единицы измерения на вертикальной оси
if(val_ax_orientation === ORIENTATION_MIN_MAX)
{ {
//Пока сделаем без обрезки текста if(hor_labels_pos === TICK_LABEL_POSITION_NEXT_TO || !isRealNumber(hor_labels_pos))
var min_x = rect.x + rect.w;
var max_height = 0;
var cur_height;
for(i = cat_ax.labels.arrLabels.length - 1; i > -1; --i)
{ {
cur_height = cat_ax.labels.arrLabels[i].tx.rich.content.Recalculate_MinMaxContentWidth().Max/Math.sqrt(2); if(cat_ax.crosses === CROSSES_MAX)
var cur_left = + rect.x + rect.w - cur_height - (cat_ax.labels.arrLabels.length - 1 - i)*point_width - point_width/2; {
if(cur_left < min_x) cat_labels_align_bottom = false;//в данном случае подписи будут выравниваться по верхнему краю блока с подписями
min_x = cur_left; cat_ax.labels.y = rect.y;
unit_height = (rect.h - cat_ax.labels.extY)/(arr_val[arr_val.length - 1] - arr_val[0]);
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = rect.y + rect.h - (arr_val[i] - arr_val[0])*unit_height;
cat_ax.posY = cat_ax.labels.y + cat_ax.labels.extY;
}
else
{
var bottom_points_height = (crosses_val_ax - arr_val[0])*unit_height;//высота области под горизонтальной осью
if(bottom_points_height < cat_ax.labels.extY)
{
var top_points_height = rect.h - cat_ax.labels.extY;
cat_ax.labels.y = rect.y + rect.h - cat_ax.labels.extY;
unit_height = (cat_ax.labels.y - rect.y)/(arr_val[arr_val.length-1]-crosses_val_ax);
if(cur_height > max_height) var bottom_point = rect.y + unit_height*(arr_val[arr_val.length - 1] - arr_val[0]);
max_height = cur_height; for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = bottom_point - (arr_val[i] - arr_val[0])*unit_height;
}
else
{
cat_ax.labels.y = rect.y + (arr_val[arr_val.length-1] - crosses_val_ax)*unit_height;
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = rect.y + rect.h - (arr_val[i] - arr_val[0])*unit_height;
}
cat_ax.posY = cat_ax.labels.y;
}
} }
if(min_x < rect.x) else if(hor_labels_pos === TICK_LABEL_POSITION_LOW)
{ {
point_width -= (rect.x - min_x)/string_pts.length; cat_ax.labels.y = rect.y + rect.h - cat_ax.labels.extY;
left_points_width = point_width*crosses; unit_height = (rect.h - cat_ax.labels.extY)/(arr_val[arr_val.length - 1] - arr_val[0]);
val_ax.labels.x = rect.x + rect.w - point_width*(string_pts.length - crosses) - val_ax.labels.extX;
cat_ax.labels.x = rect.x; var bottom_point = rect.y + unit_height*(arr_val[arr_val.length - 1] - arr_val[0]);
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = bottom_point - (arr_val[i] - arr_val[0])*unit_height;
cat_ax.posY = cat_ax.labels.y - (crosses_val_ax - arr_val[0])*unit_height;
}
else if(hor_labels_pos === TICK_LABEL_POSITION_HIGH)
{
cat_labels_align_bottom = false;
cat_ax.labels.y = rect.y;
unit_height = (rect.h - cat_ax.labels.extY)/(arr_val[arr_val.length - 1] - arr_val[0]);
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = rect.y + rect.h - (arr_val[i] - arr_val[0])*unit_height;
cat_ax.posY = rect.y + rect.h + cat_ax.labels.extY - (crosses_val_ax - arr_val[0])*unit_height;
} }
else else
{ {
cat_ax.labels.x = min_x > rect.x + rect.w - point_width*string_pts.length ? rect.x + rect.w - point_width*string_pts.length : min_x; //подписей осей нет
cat_ax.labels = null;
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = rect.y + rect.h - (arr_val[i] - arr_val[0])*unit_height;
cat_ax.posY = rect.y + rect.h - (crosses_val_ax - arr_val[0])*unit_height;
} }
val_ax.labels.y = rect.y; }
val_ax.labels.extY = rect.h; else
{//зеркально отражаем
if(hor_labels_pos === TICK_LABEL_POSITION_NEXT_TO || !isRealNumber(hor_labels_pos))
{
if(cat_ax.crosses === CROSSES_MAX)
{
cat_ax.labels.y = rect.y + rect.h - cat_ax.labels.extY;
unit_height = (rect.h - cat_ax.labels.extY)/(arr_val[arr_val.length - 1] - arr_val[0]);
var crosses_at = isRealNumber(cat_ax.crossesAt) ? cat_ax.crossesAt : arr_val[arr_val.length-1]; for(i = 0; i < arr_val.length; ++i)
var interval = arr_val[arr_val.length-1] - arr_val[0]; arr_val_labels_points[i] = rect.y + (arr_val[i] - arr_val[0])*unit_height;
cat_ax.labels.y = val_ax.labels.y + val_ax.labels.extY - ((arr_val[arr_val.length-1] - crosses_at)/interval)*val_ax.labels.extY;
cat_ax.labels.extX = rect.x + rect.w - cat_ax.labels.x; }
cat_ax.labels.extY = max_height + gap_hor_axis; else
{
cat_labels_align_bottom = false;
var top_points_height = (crosses_val_ax - arr_val[0])*unit_height;
if(top_points_height < cat_ax.labels.extY)
{
cat_ax.labels.y = rect.y;
var bottom_points_height = rect.h - cat_ax.labels.extY;
unit_height = bottom_points_height/(arr_val[arr_val.length - 1] - crosses_val_ax);
//посмотрим на сколько выходят подписи вниз за пределы ректа var top_point = rect.y + rect.h - unit_height*(arr_val[arr_val.length-1] - arr_val[0]);
var gap = cat_ax.labels.y + cat_ax.labels.extY - (rect.y + rect.h); for(i = 0; i < arr_val.length; ++i)
if(gap > 0) arr_val_labels_points[i] = top_point + (arr_val[i] - arr_val[0])*unit_height;
{ }
val_ax.labels.extY *=((rect.h - gap)/rect.h); else
cat_ax.labels.y = val_ax.labels.y + val_ax.labels.extY - ((arr_val[arr_val.length-1] - crosses_at)/interval)*val_ax.labels.extY; {
cat_ax.labels.y = rect.y + unit_height*crosses_val_ax;
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = rect.y + (arr_val[i] - arr_val[0])*unit_height;
}
}
} }
else if(hor_labels_pos === TICK_LABEL_POSITION_LOW)
{
cat_labels_align_bottom = false;
cat_ax.labels.y = rect.y;
unit_height = (rect.h - cat_ax.labels.extY)/(arr_val[arr_val.length-1] - arr_val[0]);
var top_point = rect.y + rect.h - unit_height*(arr_val[arr_val.length-1] - arr_val[0]);
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = top_point + (arr_val[i] - arr_val[0])*unit_height;
var dist = val_ax.labels.extY/(val_ax.labels.arrLabels.length-1); }
for(i = 0; i < val_ax.labels.arrLabels.length; ++i) else if(hor_labels_pos === TICK_LABEL_POSITION_HIGH)
{ {
val_ax.labels.arrLabels[i].setPosition(val_ax.labels.x, val_ax.labels.y + dist*(val_ax.labels.arrLabels.length - i -1) cat_ax.labels.y = rect.y + rect.h - cat_ax.labels.extY;
-val_ax.labels.arrLabels[i].tx.rich.content.Get_SummaryHeight()/2); unit_height = (rect.h - cat_ax.labels.extY)/(arr_val[arr_val.length-1] - arr_val[0]);
val_ax.yPoints[i].pos = val_ax.labels.y + dist*(val_ax.labels.arrLabels.length - i -1); for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = rect.y + (arr_val[i] - arr_val[0])*unit_height;
} }
else
{//подписей осей нет
cat_ax.labels = null;
for(i = 0; i < arr_val.length; ++i)
arr_val_labels_points[i] = rect.y + (arr_val[i] - arr_val[0])*unit_height;
}
}
//запишем в оси необходимую информацию для отрисовщика plotArea и выставим окончательные позиции для подписей
if(val_ax.labels)
{
val_ax.labels.y = Math.min.apply(Math, arr_val_labels_points);
val_ax.labels.extY = Math.max.apply(Math, arr_val_labels_points) - Math.min.apply(Math, arr_val_labels_points);
cat_ax.xPoints = []; var text_align = left_val_ax_labels_align ? align_Right : align_Left;//на самом деле получилось, что наоборот
for(i = cat_ax.labels.arrLabels.length - 1; i > -1 ; --i) var vert_axis_labels_gap = val_ax.labels.extX - max_width;
var labels_x_pos = left_val_ax_labels_align ? val_ax.labels.x : val_ax.labels.x + vert_axis_labels_gap;
for(i = 0; i < val_ax.labels.arrLabels.length; ++i)
{ {
var max_width = cat_ax.labels.arrLabels[i].tx.rich.content.Recalculate_MinMaxContentWidth().Max; val_ax.labels.arrLabels[i].tx.rich.content.Set_ApplyToAll(true);
cat_ax.labels.arrLabels[i].tx.rich.content.Reset(0, 0, max_width, 20000); val_ax.labels.arrLabels[i].tx.rich.content.Set_ParagraphAlign(text_align);
cat_ax.labels.arrLabels[i].tx.rich.content.Recalculate_Page(0, true); val_ax.labels.arrLabels[i].tx.rich.content.Set_ApplyToAll(false);
var x1 = rect.x + rect.w - (cat_ax.labels.arrLabels.length - 1 - i)*point_width - gap_hor_axis/Math.sqrt(2)- point_width/2; val_ax.labels.arrLabels[i].tx.rich.content.Reset(0, 0, max_width, 2000);
var y1 = cat_ax.labels.y + gap_hor_axis/Math.sqrt(2); val_ax.labels.arrLabels[i].setPosition(labels_x_pos, arr_val_labels_points[i] - val_ax.labels.arrLabels[i].tx.rich.content.Get_SummaryHeight()/2);
var xc = x1 - max_width/(2*Math.sqrt(2));
var yc = y1 - max_width/(2*Math.sqrt(2));
var t = cat_ax.labels.arrLabels[i].transformText;
t.Reset();
global_MatrixTransformer.TranslateAppend(t, -max_width/2, 0);
global_MatrixTransformer.RotateRadAppend(t, Math.PI/4);
global_MatrixTransformer.TranslateAppend(t, xc, yc + max_width/2);
global_MatrixTransformer.MultiplyAppend(t, this.getTransformMatrix());
cat_ax.xPoints.push({pos:rect.x + rect.w - (cat_ax.labels.arrLabels.length - 1 - i)*point_width - point_width/2, val: i});
} }
} }
val_ax.posX = val_ax.labels.x + val_ax.labels.extX; val_ax.yPoints = [];
cat_ax.posY = cat_ax.labels.y; for(i = 0; i < arr_val_labels_points.length; ++i)
{
val_ax.yPoints[i] = {val:arr_val[i], pos: arr_val_labels_points[i]};
}
cat_ax.xPoints = [];
for(i = 0; i <arr_cat_labels_points.length; ++i)
{
cat_ax.xPoints[i] = {val: i, pos: arr_cat_labels_points[i]};
}
if(cat_ax.labels)
{
if(!b_rotated)//подписи не повернутые
{
if(cat_ax_orientation === ORIENTATION_MIN_MAX)
{
cat_ax.labels.x = arr_cat_labels_points[0] - max_cat_label_width/2;
}
else
{
cat_ax.labels.x = arr_cat_labels_points[arr_cat_labels_points.length-1] - max_cat_label_width/2;
}
cat_ax.labels.extX = max_cat_label_width*string_pts.length;
if(cat_labels_align_bottom)
{
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
{
if(cat_ax.labels.arrLabels[i])
{
cat_ax.labels.arrLabels[i].tx.rich.content.Set_ApplyToAll(true);
cat_ax.labels.arrLabels[i].tx.rich.content.Set_ParagraphAlign(align_Center);
cat_ax.labels.arrLabels[i].tx.rich.content.Set_ApplyToAll(false);
cat_ax.labels.arrLabels[i].tx.rich.content.Reset(0, 0, max_cat_label_width, 2000);
cat_ax.labels.arrLabels[i].tx.rich.content.Recalculate_Page(0, true);
cat_ax.labels.arrLabels[i].setPosition(arr_cat_labels_points[i] - max_cat_label_width/2, cat_ax.labels.y + labels_offset);
}
}
}
else
{
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
{
if(cat_ax.labels.arrLabels[i])
{
cat_ax.labels.arrLabels[i].tx.rich.content.Set_ApplyToAll(true);
cat_ax.labels.arrLabels[i].tx.rich.content.Set_ParagraphAlign(align_Center);
cat_ax.labels.arrLabels[i].tx.rich.content.Set_ApplyToAll(false);
cat_ax.labels.arrLabels[i].tx.rich.content.Reset(0, 0, max_cat_label_width, 2000);
cat_ax.labels.arrLabels[i].tx.rich.content.Recalculate_Page(0, true);
cat_ax.labels.arrLabels[i].setPosition(arr_cat_labels_points[i] - max_cat_label_width/2, cat_ax.labels.y + cat_ax.labels.extY - labels_offset - cat_ax.labels.arrLabels[i].tx.rich.content.Get_SummaryHeight());
}
}
}
}
else
{
var left_x, right_x;
var w2, h2, x1, xc, yc, y0;
if(cat_labels_align_bottom)
{
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
{
if(cat_ax.labels.arrLabels[i])
{
var label_text_transform = cat_ax.labels.arrLabels[i].transformText;
var wh = cat_ax.labels.arrLabels[i].tx.rich.getContentOneStringSizes();//Todo: не расчитывать больше контент
w2 = wh.w*Math.cos(Math.PI/4) + wh.h*Math.sin(Math.PI/4);
h2 = wh.w*Math.sin(Math.PI/4) + wh.h*Math.cos(Math.PI/4);
x1 = arr_cat_labels_points[i] + wh.h*Math.sin(Math.PI/4);
y0 = cat_ax.labels.y + labels_offset;
xc = x1 - w2/2;
yc = y0 + h2/2;
label_text_transform.Reset();
global_MatrixTransformer.TranslateAppend(label_text_transform, -wh.w/2, -wh.h/2);
global_MatrixTransformer.RotateRadAppend(label_text_transform, Math.PI/4);//TODO
global_MatrixTransformer.TranslateAppend(label_text_transform, xc, yc);
global_MatrixTransformer.MultiplyAppend(label_text_transform,this.transform);
if(!isRealNumber(left_x))
{
left_x = xc - w2;
right_x = xc + w2;
}
else
{
if(xc - w2 < left_x)
left_x = xc - w2;
if(xc + w2 > right_x)
right_x = xc + w2;
}
}
}
}
else
{
for(i = 0; i < cat_ax.labels.arrLabels.length; ++i)
{
if(cat_ax.labels.arrLabels[i])
{
var label_text_transform = cat_ax.labels.arrLabels[i].transformText;
var wh = cat_ax.labels.arrLabels[i].tx.rich.getContentOneStringSizes();//Todo: не расчитывать больше контент
w2 = wh.w*Math.cos(Math.PI/4) + wh.h*Math.sin(Math.PI/4);
h2 = wh.w*Math.sin(Math.PI/4) + wh.h*Math.cos(Math.PI/4);
x1 = arr_cat_labels_points[i] - wh.h*Math.sin(Math.PI/4);
y0 = cat_ax.labels.y + cat_ax.labels.extY - labels_offset;
xc = x1 + w2/2;
yc = y0 - h2/2;
label_text_transform.Reset();
global_MatrixTransformer.TranslateAppend(label_text_transform, -wh.w/2, -wh.h/2);
global_MatrixTransformer.RotateRadAppend(label_text_transform, Math.PI/4);//TODO
global_MatrixTransformer.TranslateAppend(label_text_transform, xc, yc);
global_MatrixTransformer.MultiplyAppend(label_text_transform,this.transform);
if(!isRealNumber(left_x))
{
left_x = xc - w2;
right_x = xc + w2;
}
else
{
if(xc - w2 < left_x)
left_x = xc - w2;
if(xc + w2 > right_x)
right_x = xc + w2;
}
}
}
}
cat_ax.labels.x = left_x;
cat_ax.labels.extX = right_x - left_x;
}
}
cat_ax.xPoints.sort(function(a, b){return a.val - b.val}); cat_ax.xPoints.sort(function(a, b){return a.val - b.val});
val_ax.yPoints.sort(function(a, b){return a.val - b.val}); val_ax.yPoints.sort(function(a, b){return a.val - b.val});
...@@ -2838,7 +3497,6 @@ CChartSpace.prototype.recalculateAxis = function() ...@@ -2838,7 +3497,6 @@ CChartSpace.prototype.recalculateAxis = function()
} }
}; };
CChartSpace.prototype.getAllSeries = function() CChartSpace.prototype.getAllSeries = function()
{ {
//TODO:Переделать когда будем поддерживать насколько вложенных чартов //TODO:Переделать когда будем поддерживать насколько вложенных чартов
......
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