Commit 3d0912d6 authored by Dmitry.Vikulov's avatar Dmitry.Vikulov Committed by Alexander.Trofimov

Исправлена проблема с отрисовкой объектов при первом открытии таблицы

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@47286 954022d7-b5bf-4e40-9824-e11837661b57
parent 46e41827
...@@ -5,1263 +5,1312 @@ ...@@ -5,1263 +5,1312 @@
* Date: 13/08/2012 * Date: 13/08/2012
*/ */
//----------------------------------------------------------------------------------- //-----------------------------------------------------------------------------------
// Chart interface // Global drawing pointers
//----------------------------------------------------------------------------------- //-----------------------------------------------------------------------------------
// Global drawing pointers
var DrawingObject = null;
var DrawingObjectLayer = null;
if ( !window["Asc"] ) { // Для вставки диаграмм в Word
window["Asc"] = {};
}
function isObject(what) {
return ( what && (typeof(what) == "object") );
}
function convertFormula(formula, ws) {
var range = null;
if (formula && ws) { var DrawingObject = null;
var ref3D = parserHelp.is3DRef(formula, 0); var DrawingObjectLayer = null;
if (!ref3D[0])
range = ws.model.getRange2(formula.toUpperCase()); if ( !window["Asc"] ) { // Для вставки диаграмм в Word
else { window["Asc"] = {};
var resultRef = parserHelp.parse3DRef(formula); }
if (null !== resultRef) {
var ws = ws.model.workbook.getWorksheetByName(resultRef.sheet); function isObject(what) {
if (ws) return ( what && (typeof(what) == "object") );
range = ws.getRange2(resultRef.range); }
}
function convertFormula(formula, ws) {
var range = null;
if (formula && ws) {
var ref3D = parserHelp.is3DRef(formula, 0);
if (!ref3D[0])
range = ws.model.getRange2(formula.toUpperCase());
else {
var resultRef = parserHelp.parse3DRef(formula);
if (null !== resultRef) {
var ws = ws.model.workbook.getWorksheetByName(resultRef.sheet);
if (ws)
range = ws.getRange2(resultRef.range);
} }
} }
return range; }
} return range;
}
//-----------------------------------------------------------------------------------
// Интерфейс < Excel - Word >
//-----------------------------------------------------------------------------------
function CChartData(bWordContext, chart) {
var _this = this;
// Интерфейс < Excel - Word > _this.Id = bWordContext ? g_oIdCounter.Get_NewId() : "";
function CChartData(bWordContext, chart) { _this.img = chart ? chart.img : "";
_this.width = chart ? chart.width : c_oAscChartDefines.defaultChartWidth;
_this.height = chart ? chart.height : c_oAscChartDefines.defaultChartHeight;
_this.bChartEditor = chart ? chart.bChartEditor : true;
var _this = this; _this.type = chart ? chart.type : "";
_this.subType = chart ? chart.subType : c_oAscChartSubType.normal;
if ( chart ) {
_this.header = { title: chart.header.title, subTitle: chart.header.subTitle, bDefaultTitle: chart.header.bDefaultTitle };
_this.range = { interval: chart.range.interval, rows: chart.range.rows, columns: chart.range.columns };
_this.xAxis = { title: chart.xAxis.title, bDefaultTitle: chart.xAxis.bDefaultTitle, bShow: chart.xAxis.bShow, bGrid: chart.xAxis.bGrid };
_this.yAxis = { title: chart.yAxis.title, bDefaultTitle: chart.yAxis.bDefaultTitle, bShow: chart.yAxis.bShow, bGrid: chart.yAxis.bGrid };
_this.legend = { position: chart.legend.position, bShow: chart.legend.bShow, bOverlay: chart.legend.bOverlay };
}
else {
_this.header = { title: "", subTitle: "", bDefaultTitle: false };
_this.range = { interval: bWordContext ? "" : "Sheet1!A1:C3", rows: false, columns: true };
_this.xAxis = { title: "", bDefaultTitle: false, bShow: true, bGrid: true };
_this.yAxis = { title: "", bDefaultTitle: false, bShow: true, bGrid: true };
_this.legend = { position: c_oAscChartLegend.right, bShow: true, bOverlay: false };
}
_this.bShowValue = chart ? chart.bShowValue : false;
_this.bShowBorder = chart ? chart.bShowBorder : true;
_this.styleId = chart ? chart.styleId : c_oAscChartStyle.Standart;
_this.data = [];
_this.themeColors = [];
if ( chart ) {
for (var row = 0; row < chart.data.length; row++) {
_this.Id = bWordContext ? g_oIdCounter.Get_NewId() : ""; var values = [];
_this.img = chart ? chart.img : ""; for (var col = 0; col < chart.data[row].length; col++) {
_this.width = chart ? chart.width : c_oAscChartDefines.defaultChartWidth;
_this.height = chart ? chart.height : c_oAscChartDefines.defaultChartHeight;
_this.bChartEditor = chart ? chart.bChartEditor : true;
_this.type = chart ? chart.type : ""; var item = {};
_this.subType = chart ? chart.subType : c_oAscChartSubType.normal; item.numFormatStr = chart.data[row][col].numFormatStr;
item.isDateTimeFormat = chart.data[row][col].isDateTimeFormat;
if ( chart ) { item.value = chart.data[row][col].value;
_this.header = { title: chart.header.title, subTitle: chart.header.subTitle, bDefaultTitle: chart.header.bDefaultTitle }; values.push(item);
_this.range = { interval: chart.range.interval, rows: chart.range.rows, columns: chart.range.columns }; }
_this.xAxis = { title: chart.xAxis.title, bDefaultTitle: chart.xAxis.bDefaultTitle, bShow: chart.xAxis.bShow, bGrid: chart.xAxis.bGrid }; _this.data.push(values);
_this.yAxis = { title: chart.yAxis.title, bDefaultTitle: chart.yAxis.bDefaultTitle, bShow: chart.yAxis.bShow, bGrid: chart.yAxis.bGrid };
_this.legend = { position: chart.legend.position, bShow: chart.legend.bShow, bOverlay: chart.legend.bOverlay };
} }
else {
_this.header = { title: "", subTitle: "", bDefaultTitle: false };
_this.range = { interval: bWordContext ? "" : "Sheet1!A1:C3", rows: false, columns: true };
_this.xAxis = { title: "", bDefaultTitle: false, bShow: true, bGrid: true };
_this.yAxis = { title: "", bDefaultTitle: false, bShow: true, bGrid: true };
_this.legend = { position: c_oAscChartLegend.right, bShow: true, bOverlay: false };
}
_this.bShowValue = chart ? chart.bShowValue : false; for (var i = 0; i < chart.themeColors.length; i++) {
_this.bShowBorder = chart ? chart.bShowBorder : true; _this.themeColors.push(chart.themeColors[i]);
_this.styleId = chart ? chart.styleId : c_oAscChartStyle.Standart; }
}
_this.data = [];
_this.themeColors = []; //-----------------------------------------------------------------------------------
// Methods
//-----------------------------------------------------------------------------------
_this.clone = function() {
function clone(o) {
if ( !o || "object" !== typeof o ) {
return o;
}
var c = "function" === typeof o.pop ? [] : {};
var p, v;
for ( p in o ) {
if ( o.hasOwnProperty(p) ) {
v = o[p];
if ( v && "object" === typeof v ) {
c[p] = clone(v);
}
else c[p] = v;
}
}
return c;
}
return clone(_this);
}
_this.serializeChart = function() {
var chart = {};
if ( chart ) { chart["img"] = _this.img;
for (var row = 0; row < chart.data.length; row++) { chart["width"] = _this.width;
chart["height"] = _this.height;
chart["type"] = _this.type;
chart["subType"] = _this.subType;
chart["bShowValue"] = _this.bShowValue;
chart["bShowBorder"] = _this.bShowBorder;
chart["styleId"] = _this.styleId;
chart["bChartEditor"] = _this.bChartEditor;
chart["header"] = {};
chart["header"]["title"] = _this.header.title;
chart["header"]["subTitle"] = _this.header.subTitle;
chart["header"]["bDefaultTitle"] = _this.header.bDefaultTitle;
chart["range"] = {};
chart["range"]["interval"] = _this.range.interval;
chart["range"]["rows"] = _this.range.rows;
chart["range"]["columns"] = _this.range.columns;
chart["xAxis"] = {};
chart["xAxis"]["title"] = _this.xAxis.title;
chart["xAxis"]["bDefaultTitle"] = _this.xAxis.bDefaultTitle;
chart["xAxis"]["bShow"] = _this.xAxis.bShow;
chart["xAxis"]["bGrid"] = _this.xAxis.bGrid;
chart["yAxis"] = {};
chart["yAxis"]["title"] = _this.yAxis.title;
chart["yAxis"]["bDefaultTitle"] = _this.yAxis.bDefaultTitle;
chart["yAxis"]["bShow"] = _this.yAxis.bShow;
chart["yAxis"]["bGrid"] = _this.yAxis.bGrid;
chart["legend"] = {};
chart["legend"]["position"] = _this.legend.position;
chart["legend"]["bShow"] = _this.legend.bShow;
chart["legend"]["bOverlay"] = _this.legend.bOverlay;
var values = []; if ( _this.data ) {
for (var col = 0; col < chart.data[row].length; col++) { chart["data"] = [];
for (var row = 0; row < _this.data.length; row++) {
var values = [];
for (var col = 0; col < _this.data[row].length; col++) {
var item = {}; var item = {};
item.numFormatStr = chart.data[row][col].numFormatStr; item["numFormatStr"] = _this.data[row][col].numFormatStr;
item.isDateTimeFormat = chart.data[row][col].isDateTimeFormat; item["isDateTimeFormat"] = _this.data[row][col].isDateTimeFormat;
item.value = chart.data[row][col].value; item["value"] = _this.data[row][col].value;
values.push(item); values.push(item);
} }
_this.data.push(values); chart["data"].push(values);
} }
}
if ( _this.themeColors ) {
chart["themeColors"] = [];
for (var i = 0; i < chart.themeColors.length; i++) { for (var i = 0; i < _this.themeColors.length; i++) {
_this.themeColors.push(chart.themeColors[i]); chart["themeColors"].push(_this.themeColors[i]);
} }
} }
//-----------------------------------------------------------------------------------
// Methods
//-----------------------------------------------------------------------------------
_this.clone = function() { return chart;
}
function clone(o) {
if ( !o || "object" !== typeof o ) { _this.deserializeChart = function(chart) {
return o;
}
var c = "function" === typeof o.pop ? [] : {};
var p, v;
for ( p in o ) {
if ( o.hasOwnProperty(p) ) {
v = o[p];
if ( v && "object" === typeof v ) {
c[p] = clone(v);
}
else c[p] = v;
}
}
return c;
}
return clone(_this); _this.img = chart["img"];
} _this.width = chart["width"];
_this.height = chart["height"];
_this.serializeChart = function() { _this.type = chart["type"];
_this.subType = chart["subType"];
_this.bShowValue = chart["bShowValue"];
_this.bShowBorder = chart["bShowBorder"];
_this.styleId = chart["styleId"];
_this.bChartEditor = chart["bChartEditor"];
var chart = {}; _this.header.title = chart["header"]["title"];
_this.header.subTitle = chart["header"]["subTitle"];
_this.header.bDefaultTitle = chart["range"]["bDefaultTitle"];
chart["img"] = _this.img; _this.range.interval = chart["range"]["interval"];
chart["width"] = _this.width; _this.range.rows = chart["range"]["rows"];
chart["height"] = _this.height; _this.range.columns = chart["range"]["columns"];
chart["type"] = _this.type;
chart["subType"] = _this.subType;
chart["bShowValue"] = _this.bShowValue;
chart["bShowBorder"] = _this.bShowBorder;
chart["styleId"] = _this.styleId;
chart["bChartEditor"] = _this.bChartEditor;
chart["header"] = {}; _this.xAxis.title = chart["xAxis"]["title"];
chart["header"]["title"] = _this.header.title; _this.xAxis.bDefaultTitle = chart["xAxis"]["bDefaultTitle"];
chart["header"]["subTitle"] = _this.header.subTitle; _this.xAxis.bShow = chart["xAxis"]["bShow"];
chart["header"]["bDefaultTitle"] = _this.header.bDefaultTitle; _this.xAxis.bGrid = chart["xAxis"]["bGrid"];
chart["range"] = {};
chart["range"]["interval"] = _this.range.interval;
chart["range"]["rows"] = _this.range.rows;
chart["range"]["columns"] = _this.range.columns;
chart["xAxis"] = {};
chart["xAxis"]["title"] = _this.xAxis.title;
chart["xAxis"]["bDefaultTitle"] = _this.xAxis.bDefaultTitle;
chart["xAxis"]["bShow"] = _this.xAxis.bShow;
chart["xAxis"]["bGrid"] = _this.xAxis.bGrid;
chart["yAxis"] = {};
chart["yAxis"]["title"] = _this.yAxis.title;
chart["yAxis"]["bDefaultTitle"] = _this.yAxis.bDefaultTitle;
chart["yAxis"]["bShow"] = _this.yAxis.bShow;
chart["yAxis"]["bGrid"] = _this.yAxis.bGrid;
chart["legend"] = {};
chart["legend"]["position"] = _this.legend.position;
chart["legend"]["bShow"] = _this.legend.bShow;
chart["legend"]["bOverlay"] = _this.legend.bOverlay;
if ( _this.data ) {
chart["data"] = [];
for (var row = 0; row < _this.data.length; row++) {
var values = [];
for (var col = 0; col < _this.data[row].length; col++) {
var item = {};
item["numFormatStr"] = _this.data[row][col].numFormatStr;
item["isDateTimeFormat"] = _this.data[row][col].isDateTimeFormat;
item["value"] = _this.data[row][col].value;
values.push(item);
}
chart["data"].push(values);
}
}
if ( _this.themeColors ) { _this.yAxis.title = chart["yAxis"]["title"];
chart["themeColors"] = []; _this.yAxis.bDefaultTitle = chart["yAxis"]["bDefaultTitle"];
_this.yAxis.bShow = chart["yAxis"]["bShow"];
for (var i = 0; i < _this.themeColors.length; i++) { _this.yAxis.bGrid = chart["yAxis"]["bGrid"];
chart["themeColors"].push(_this.themeColors[i]);
_this.legend.position = chart["legend"]["position"];
_this.legend.bShow = chart["legend"]["bShow"];
_this.legend.bOverlay = chart["legend"]["bOverlay"];
if ( chart["data"] ) {
_this.data = [];
for (var row = 0; row < chart["data"].length; row++) {
var values = [];
for (var col = 0; col < chart["data"][row].length; col++) {
var item = {};
item.numFormatStr = chart["data"][row][col]["numFormatStr"];
item.isDateTimeFormat = chart["data"][row][col]["isDateTimeFormat"];
item.value = chart["data"][row][col]["value"];
values.push(item);
} }
_this.data.push(values);
} }
}
if ( chart["themeColors"] ) {
_this.themeColors = [];
return chart; for (var i = 0; i < chart["themeColors"].length; i++) {
_this.themeColors.push(chart["themeColors"][i]);
}
} }
}
_this.readFromDrawingObject = function(object) {
_this.deserializeChart = function(chart) { if ( object && object.isChart() ) {
_this.img = chart["img"]; // Доп. параметры
_this.width = chart["width"]; _this.img = object.image.src;
_this.height = chart["height"]; _this.width = object.image.width;
_this.height = object.image.height;;
_this.type = chart["type"]; _this.type = object.chart.type;
_this.subType = chart["subType"]; _this.subType = object.chart.subType;
_this.bShowValue = chart["bShowValue"]; _this.bShowValue = object.chart.bShowValue;
_this.bShowBorder = chart["bShowBorder"]; _this.bShowBorder = object.chart.bShowBorder;
_this.styleId = chart["styleId"]; _this.styleId = object.chart.styleId;
_this.bChartEditor = chart["bChartEditor"]; _this.bChartEditor = object.chart.bChartEditor;
_this.header.title = chart["header"]["title"]; _this.header.title = object.chart.header.title;
_this.header.subTitle = chart["header"]["subTitle"]; _this.header.subTitle = object.chart.header.subTitle;
_this.header.bDefaultTitle = chart["range"]["bDefaultTitle"]; _this.header.bDefaultTitle = object.chart.header.bDefaultTitle;
_this.range.interval = chart["range"]["interval"]; _this.range.interval = object.chart.range.interval;
_this.range.rows = chart["range"]["rows"]; _this.range.rows = object.chart.range.rows;
_this.range.columns = chart["range"]["columns"]; _this.range.columns = object.chart.range.columns;
_this.xAxis.title = chart["xAxis"]["title"]; _this.xAxis.title = object.chart.xAxis.title;
_this.xAxis.bDefaultTitle = chart["xAxis"]["bDefaultTitle"]; _this.xAxis.bDefaultTitle = object.chart.xAxis.bDefaultTitle;
_this.xAxis.bShow = chart["xAxis"]["bShow"]; _this.xAxis.bShow = object.chart.xAxis.bShow;
_this.xAxis.bGrid = chart["xAxis"]["bGrid"]; _this.xAxis.bGrid = object.chart.xAxis.bGrid;
_this.yAxis.title = chart["yAxis"]["title"]; _this.yAxis.title = object.chart.yAxis.title;
_this.yAxis.bDefaultTitle = chart["yAxis"]["bDefaultTitle"]; _this.yAxis.bDefaultTitle = object.chart.yAxis.bDefaultTitle;
_this.yAxis.bShow = chart["yAxis"]["bShow"]; _this.yAxis.bShow = object.chart.yAxis.bShow;
_this.yAxis.bGrid = chart["yAxis"]["bGrid"]; _this.yAxis.bGrid = object.chart.yAxis.bGrid;
_this.legend.position = chart["legend"]["position"]; _this.legend.position = object.chart.legend.position;
_this.legend.bShow = chart["legend"]["bShow"]; _this.legend.bShow = object.chart.legend.bShow;
_this.legend.bOverlay = chart["legend"]["bOverlay"]; _this.legend.bOverlay = object.chart.legend.bOverlay;
if ( chart["data"] ) { _this.data = [];
_this.data = []; if ( object.chart.range.intervalObject ) {
var bbox = object.chart.range.intervalObject.getBBox0();
for (var row = 0; row < chart["data"].length; row++) {
for (var row = bbox.r1; row <= bbox.r2; row++) {
var values = []; var values = [];
for (var col = 0; col < chart["data"][row].length; col++) { for (var col = bbox.c1; col <= bbox.c2; col++) {
var cell = object.chart.range.intervalObject.worksheet.getCell(new CellAddress(row, col, 0));
var item = {}; var item = {};
item.numFormatStr = chart["data"][row][col]["numFormatStr"]; item.numFormatStr = cell.getNumFormatStr();
item.isDateTimeFormat = chart["data"][row][col]["isDateTimeFormat"]; item.isDateTimeFormat = cell.getNumFormat().isDateTimeFormat();
item.value = chart["data"][row][col]["value"]; item.value = cell.getValue();
values.push(item); values.push(item);
} }
_this.data.push(values); _this.data.push(values);
} }
} }
if ( chart["themeColors"] ) {
_this.themeColors = [];
for (var i = 0; i < chart["themeColors"].length; i++) {
_this.themeColors.push(chart["themeColors"][i]);
}
}
}
_this.readFromDrawingObject = function(object) {
if ( object && object.isChart() ) {
// Доп. параметры
_this.img = object.image.src;
_this.width = object.image.width;
_this.height = object.image.height;;
_this.type = object.chart.type;
_this.subType = object.chart.subType;
_this.bShowValue = object.chart.bShowValue;
_this.bShowBorder = object.chart.bShowBorder;
_this.styleId = object.chart.styleId;
_this.bChartEditor = object.chart.bChartEditor;
_this.header.title = object.chart.header.title;
_this.header.subTitle = object.chart.header.subTitle;
_this.header.bDefaultTitle = object.chart.header.bDefaultTitle;
_this.range.interval = object.chart.range.interval;
_this.range.rows = object.chart.range.rows;
_this.range.columns = object.chart.range.columns;
_this.xAxis.title = object.chart.xAxis.title;
_this.xAxis.bDefaultTitle = object.chart.xAxis.bDefaultTitle;
_this.xAxis.bShow = object.chart.xAxis.bShow;
_this.xAxis.bGrid = object.chart.xAxis.bGrid;
_this.yAxis.title = object.chart.yAxis.title;
_this.yAxis.bDefaultTitle = object.chart.yAxis.bDefaultTitle;
_this.yAxis.bShow = object.chart.yAxis.bShow;
_this.yAxis.bGrid = object.chart.yAxis.bGrid;
_this.legend.position = object.chart.legend.position;
_this.legend.bShow = object.chart.legend.bShow;
_this.legend.bOverlay = object.chart.legend.bOverlay;
_this.data = [];
if ( object.chart.range.intervalObject ) {
var bbox = object.chart.range.intervalObject.getBBox0();
for (var row = bbox.r1; row <= bbox.r2; row++) {
var values = [];
for (var col = bbox.c1; col <= bbox.c2; col++) {
var cell = object.chart.range.intervalObject.worksheet.getCell(new CellAddress(row, col, 0));
var item = {};
item.numFormatStr = cell.getNumFormatStr();
item.isDateTimeFormat = cell.getNumFormat().isDateTimeFormat();
item.value = cell.getValue();
values.push(item);
}
_this.data.push(values);
}
}
}
} }
}
_this.Get_Id = function() {
return this.Id;
}
_this.Write_ToBinary2 = function(Writer) {
_this.Get_Id = function() { var _this = this;
return this.Id; Writer.WriteLong(historyitem_type_Chart);
} Writer.WriteString2( _this.Id );
Writer.WriteString2( _this.img );
Writer.WriteLong( _this.width );
Writer.WriteLong( _this.height );
Writer.WriteString2( _this.type );
Writer.WriteString2( _this.subType );
Writer.WriteBool( _this.bShowValue );
Writer.WriteBool( _this.bShowBorder );
Writer.WriteLong( _this.styleId );
Writer.WriteBool( _this.bChartEditor );
_this.Write_ToBinary2 = function(Writer) { Writer.WriteString2( _this.header.title );
Writer.WriteString2( _this.header.subTitle );
var _this = this; Writer.WriteBool( _this.header.bDefaultTitle );
Writer.WriteLong(historyitem_type_Chart);
Writer.WriteString2( _this.Id );
Writer.WriteString2( _this.img );
Writer.WriteLong( _this.width );
Writer.WriteLong( _this.height );
Writer.WriteString2( _this.type );
Writer.WriteString2( _this.subType );
Writer.WriteBool( _this.bShowValue );
Writer.WriteBool( _this.bShowBorder );
Writer.WriteLong( _this.styleId );
Writer.WriteBool( _this.bChartEditor );
Writer.WriteString2( _this.header.title ); Writer.WriteString2( _this.range.interval );
Writer.WriteString2( _this.header.subTitle ); Writer.WriteBool( _this.range.rows );
Writer.WriteBool( _this.header.bDefaultTitle ); Writer.WriteBool( _this.range.columns );
Writer.WriteString2( _this.range.interval );
Writer.WriteBool( _this.range.rows );
Writer.WriteBool( _this.range.columns );
Writer.WriteString2( _this.xAxis.title );
Writer.WriteBool( _this.xAxis.bDefaultTitle );
Writer.WriteBool( _this.xAxis.bShow );
Writer.WriteBool( _this.xAxis.bGrid );
Writer.WriteString2( _this.yAxis.title );
Writer.WriteBool( _this.yAxis.bDefaultTitle );
Writer.WriteBool( _this.yAxis.bShow );
Writer.WriteBool( _this.yAxis.bGrid );
Writer.WriteString2( _this.legend.position );
Writer.WriteBool( _this.legend.bShow );
Writer.WriteBool( _this.legend.bOverlay );
/* Writer.WriteString2( _this.xAxis.title );
* numFormatStr Writer.WriteBool( _this.xAxis.bDefaultTitle );
* isDateTimeFormat Writer.WriteBool( _this.xAxis.bShow );
* value Writer.WriteBool( _this.xAxis.bGrid );
*/
var rowsCount = _this.data.length; Writer.WriteString2( _this.yAxis.title );
Writer.WriteLong( rowsCount ); Writer.WriteBool( _this.yAxis.bDefaultTitle );
Writer.WriteBool( _this.yAxis.bShow );
Writer.WriteBool( _this.yAxis.bGrid );
for (var i = 0; i < rowsCount; i++) { Writer.WriteString2( _this.legend.position );
Writer.WriteBool( _this.legend.bShow );
Writer.WriteBool( _this.legend.bOverlay );
/*
* numFormatStr
* isDateTimeFormat
* value
*/
var rowsCount = _this.data.length;
Writer.WriteLong( rowsCount );
for (var i = 0; i < rowsCount; i++) {
var colsCount = _this.data[i].length;
Writer.WriteLong( colsCount );
var colsCount = _this.data[i].length; for (var j = 0; j < colsCount; j++) {
Writer.WriteLong( colsCount );
Writer.WriteString2( _this.data[i][j].numFormatStr );
for (var j = 0; j < colsCount; j++) { Writer.WriteBool( _this.data[i][j].isDateTimeFormat );
Writer.WriteString2( _this.data[i][j].value );
Writer.WriteString2( _this.data[i][j].numFormatStr );
Writer.WriteBool( _this.data[i][j].isDateTimeFormat );
Writer.WriteString2( _this.data[i][j].value );
}
} }
} }
}
_this.Read_FromBinary2 = function(Reader) { _this.Read_FromBinary2 = function(Reader) {
var _this = this;
_this.Id = Reader.GetString2();
_this.img = Reader.GetString2();
_this.width = Reader.GetLong();
_this.height = Reader.GetLong();
_this.type = Reader.GetString2();
_this.subType = Reader.GetString2();
_this.bShowValue = Reader.GetBool();
_this.bShowBorder = Reader.GetBool();
_this.styleId = Reader.GetLong();
_this.bChartEditor = Reader.GetBool();
_this.header.title = Reader.GetString2();
_this.header.subTitle = Reader.GetString2();
_this.header.bDefaultTitle = Reader.GetBool();
var _this = this; _this.range.interval = Reader.GetString2();
_this.Id = Reader.GetString2(); _this.range.rows = Reader.GetBool();
_this.img = Reader.GetString2(); _this.range.columns = Reader.GetBool();
_this.width = Reader.GetLong();
_this.height = Reader.GetLong();
_this.type = Reader.GetString2();
_this.subType = Reader.GetString2();
_this.bShowValue = Reader.GetBool();
_this.bShowBorder = Reader.GetBool();
_this.styleId = Reader.GetLong();
_this.bChartEditor = Reader.GetBool();
_this.header.title = Reader.GetString2(); _this.xAxis.title = Reader.GetString2();
_this.header.subTitle = Reader.GetString2(); _this.xAxis.bDefaultTitle = Reader.GetBool();
_this.header.bDefaultTitle = Reader.GetBool(); _this.xAxis.bShow = Reader.GetBool();
_this.xAxis.bGrid = Reader.GetBool();
_this.range.interval = Reader.GetString2();
_this.range.rows = Reader.GetBool();
_this.range.columns = Reader.GetBool();
_this.xAxis.title = Reader.GetString2();
_this.xAxis.bDefaultTitle = Reader.GetBool();
_this.xAxis.bShow = Reader.GetBool();
_this.xAxis.bGrid = Reader.GetBool();
_this.yAxis.title = Reader.GetString2();
_this.yAxis.bDefaultTitle = Reader.GetBool();
_this.yAxis.bShow = Reader.GetBool();
_this.yAxis.bGrid = Reader.GetBool();
_this.legend.position = Reader.GetString2();
_this.legend.bShow = Reader.GetBool();
_this.legend.bOverlay = Reader.GetBool();
/* _this.yAxis.title = Reader.GetString2();
* numFormatStr _this.yAxis.bDefaultTitle = Reader.GetBool();
* isDateTimeFormat _this.yAxis.bShow = Reader.GetBool();
* value _this.yAxis.bGrid = Reader.GetBool();
*/
_this.data = []; _this.legend.position = Reader.GetString2();
var rowsCount = Reader.GetLong(); _this.legend.bShow = Reader.GetBool();
_this.legend.bOverlay = Reader.GetBool();
for (var i = 0; i < rowsCount; i++) {
var values = [];
var colsCount = Reader.GetLong();
for (var j = 0; j < colsCount; j++) {
var item = {};
item.numFormatStr = Reader.GetString2();
item.isDateTimeFormat = Reader.GetBool();
item.value = Reader.GetString2();
values.push(item);
}
_this.data.push(values);
}
CollaborativeEditing.Add_NewObject( _this );
}
_this.Save_Changes = function(data, Writer) {
_this.Write_ToBinary2(Writer);
}
_this.Load_Changes = function(Reader) {
Reader.GetLong(); // historyitem_type_Chart
_this.Read_FromBinary2(Reader);
}
_this.Refresh_RecalcData = function(data) { /*
} * numFormatStr
* isDateTimeFormat
_this.Undo = function(data) { * value
} */
_this.Redo = function(data) { _this.data = [];
} var rowsCount = Reader.GetLong();
for (var i = 0; i < rowsCount; i++) {
_this.putToHistory = function() { var values = [];
var cloneChart = _this.clone(); var colsCount = Reader.GetLong();
History.Add( _this, { chart: cloneChart } );
for (var j = 0; j < colsCount; j++) {
var item = {};
item.numFormatStr = Reader.GetString2();
item.isDateTimeFormat = Reader.GetBool();
item.value = Reader.GetString2();
values.push(item);
}
_this.data.push(values);
} }
CollaborativeEditing.Add_NewObject( _this );
if ( bWordContext )
g_oTableId.Add( _this, _this.Id );
} }
function asc_CChartStyle() { _this.Save_Changes = function(data, Writer) {
this.style = null; _this.Write_ToBinary2(Writer);
this.imageUrl = null;
} }
asc_CChartStyle.prototype = { _this.Load_Changes = function(Reader) {
asc_getStyle: function() { return this.style; }, Reader.GetLong(); // historyitem_type_Chart
asc_setStyle: function(style) { this.style = style; }, _this.Read_FromBinary2(Reader);
asc_getImageUrl: function() { return this.imageUrl; },
asc_setImageUrl: function(imageUrl) { this.imageUrl = imageUrl; }
} }
window["Asc"].asc_CChartStyle = asc_CChartStyle; _this.Refresh_RecalcData = function(data) {
window["Asc"]["asc_CChartStyle"] = asc_CChartStyle; }
prot = asc_CChartStyle.prototype;
_this.Undo = function(data) {
}
_this.Redo = function(data) {
}
_this.putToHistory = function() {
var cloneChart = _this.clone();
History.Add( _this, { chart: cloneChart } );
}
if ( bWordContext )
g_oTableId.Add( _this, _this.Id );
}
//-----------------------------------------------------------------------------------
// Chart style
//-----------------------------------------------------------------------------------
prot["asc_getStyle"] = prot.asc_getStyle; function asc_CChartStyle() {
prot["asc_setStyle"] = prot.asc_setStyle; this.style = null;
this.imageUrl = null;
}
prot["asc_getImageUrl"] = prot.asc_getImageUrl; asc_CChartStyle.prototype = {
prot["asc_setImageUrl"] = prot.asc_setImageUrl; asc_getStyle: function() { return this.style; },
asc_setStyle: function(style) { this.style = style; },
function asc_CChart(object) {
asc_getImageUrl: function() { return this.imageUrl; },
var bCopy = isObject(object); asc_setImageUrl: function(imageUrl) { this.imageUrl = imageUrl; }
}
this.bChartEditor = bCopy ? object.bChartEditor : false; //{ asc_CChartStyle export
this.type = bCopy ? object.type : null; window["Asc"].asc_CChartStyle = asc_CChartStyle;
this.subType = bCopy ? object.subType : null; window["Asc"]["asc_CChartStyle"] = asc_CChartStyle;
prot = asc_CChartStyle.prototype;
this.bShowValue = bCopy ? object.bShowValue : false;
this.bShowBorder = bCopy ? object.bShowBorder : true;
this.styleId = bCopy ? object.styleId : c_oAscChartStyle.Standart;
this.header = bCopy ? new asc_CChartHeader(object.header) : new asc_CChartHeader(); prot["asc_getStyle"] = prot.asc_getStyle;
this.range = bCopy ? new asc_CChartRange(object.range) : new asc_CChartRange(); prot["asc_setStyle"] = prot.asc_setStyle;
this.xAxis = bCopy ? new asc_CChartAxisX(object.xAxis) : new asc_CChartAxisX(); prot["asc_getImageUrl"] = prot.asc_getImageUrl;
this.yAxis = bCopy ? new asc_CChartAxisY(object.yAxis) : new asc_CChartAxisY(); prot["asc_setImageUrl"] = prot.asc_setImageUrl;
//}
this.legend = bCopy ? new asc_CChartLegend(object.legend) : new asc_CChartLegend();
//-----------------------------------------------------------------------------------
this.series = []; // Chart
if ( bCopy ) { //-----------------------------------------------------------------------------------
for (var i = 0; i < object.series.length; i++) {
var ser = new asc_CChartSeria(); function asc_CChart(object) {
ser.asc_setTitle(object.series[i].Tx); var bCopy = isObject(object);
if (object.series[i].Val && object.series[i].Val.Formula)
ser.asc_setValFormula(object.series[i].Val.Formula); this.bChartEditor = bCopy ? object.bChartEditor : false;
if (object.series[i].xVal && object.series[i].xVal.Formula) this.type = bCopy ? object.type : null;
ser.asc_setxValFormula(object.series[i].xVal.Formula); this.subType = bCopy ? object.subType : null;
if (object.series[i].Marker) {
ser.asc_setMarkerSize(object.series[i].Marker.Size); this.bShowValue = bCopy ? object.bShowValue : false;
ser.asc_setMarkerSymbol(object.series[i].Marker.Symbol); this.bShowBorder = bCopy ? object.bShowBorder : true;
} this.styleId = bCopy ? object.styleId : c_oAscChartStyle.Standart;
ser.asc_setOutlineColor(object.series[i].OutlineColor);
this.series.push(ser); this.header = bCopy ? new asc_CChartHeader(object.header) : new asc_CChartHeader();
this.range = bCopy ? new asc_CChartRange(object.range) : new asc_CChartRange();
this.xAxis = bCopy ? new asc_CChartAxisX(object.xAxis) : new asc_CChartAxisX();
this.yAxis = bCopy ? new asc_CChartAxisY(object.yAxis) : new asc_CChartAxisY();
this.legend = bCopy ? new asc_CChartLegend(object.legend) : new asc_CChartLegend();
this.series = [];
if ( bCopy ) {
for (var i = 0; i < object.series.length; i++) {
var ser = new asc_CChartSeria();
ser.asc_setTitle(object.series[i].Tx);
if (object.series[i].Val && object.series[i].Val.Formula)
ser.asc_setValFormula(object.series[i].Val.Formula);
if (object.series[i].xVal && object.series[i].xVal.Formula)
ser.asc_setxValFormula(object.series[i].xVal.Formula);
if (object.series[i].Marker) {
ser.asc_setMarkerSize(object.series[i].Marker.Size);
ser.asc_setMarkerSymbol(object.series[i].Marker.Symbol);
} }
ser.asc_setOutlineColor(object.series[i].OutlineColor);
this.series.push(ser);
} }
this.Properties = {
bChartEditor: 0,
type: 1,
subType: 2,
bShowValue: 3,
bShowBorder: 4,
styleId: 5,
header: 6,
range: 7,
xAxis: 8,
yAxis: 9,
legend: 10,
series: 11
};
} }
this.Properties = {
bChartEditor: 0,
type: 1,
subType: 2,
bShowValue: 3,
bShowBorder: 4,
styleId: 5,
header: 6,
range: 7,
xAxis: 8,
yAxis: 9,
legend: 10,
series: 11
};
}
asc_CChart.prototype = { asc_CChart.prototype = {
asc_getType: function() { return this.type; }, asc_getType: function() { return this.type; },
asc_setType: function(type) { this.type = type; }, asc_setType: function(type) { this.type = type; },
asc_getSubType: function() { return this.subType; }, asc_getSubType: function() { return this.subType; },
asc_setSubType: function(subType) { this.subType = subType; }, asc_setSubType: function(subType) { this.subType = subType; },
asc_getStyleId: function() { return this.styleId; }, asc_getStyleId: function() { return this.styleId; },
asc_setStyleId: function(styleId) { this.styleId = styleId; }, asc_setStyleId: function(styleId) { this.styleId = styleId; },
asc_getShowValueFlag: function() { return this.bShowValue; }, asc_getShowValueFlag: function() { return this.bShowValue; },
asc_setShowValueFlag: function(show) { this.bShowValue = show; }, asc_setShowValueFlag: function(show) { this.bShowValue = show; },
asc_getShowBorderFlag: function() { return this.bShowBorder; }, asc_getShowBorderFlag: function() { return this.bShowBorder; },
asc_setShowBorderFlag: function(show) { this.bShowBorder = show; }, asc_setShowBorderFlag: function(show) { this.bShowBorder = show; },
asc_getHeader: function() { return this.header; }, asc_getHeader: function() { return this.header; },
asc_setHeader: function(headerObj) { this.header = headerObj; }, asc_setHeader: function(headerObj) { this.header = headerObj; },
asc_getRange: function() { return this.range; }, asc_getRange: function() { return this.range; },
asc_setRange: function(rangeObj) { this.range = rangeObj; }, asc_setRange: function(rangeObj) { this.range = rangeObj; },
asc_getXAxis: function() { return this.xAxis; }, asc_getXAxis: function() { return this.xAxis; },
asc_setXAxis: function(axisObj) { this.xAxis = axisObj; }, asc_setXAxis: function(axisObj) { this.xAxis = axisObj; },
asc_getYAxis: function() { return this.yAxis; }, asc_getYAxis: function() { return this.yAxis; },
asc_setYAxis: function(axisObj) { this.yAxis = axisObj; }, asc_setYAxis: function(axisObj) { this.yAxis = axisObj; },
asc_getLegend: function() { return this.legend; }, asc_getLegend: function() { return this.legend; },
asc_setLegend: function(legendObj) { this.legend = legendObj; }, asc_setLegend: function(legendObj) { this.legend = legendObj; },
asc_getSeria: function(index) { return (index < this.series.length) ? this.series[index] : null; }, asc_getSeria: function(index) { return (index < this.series.length) ? this.series[index] : null; },
asc_setSeria: function(seriaObj) { if (seriaObj) this.series.push(seriaObj); }, asc_setSeria: function(seriaObj) { if (seriaObj) this.series.push(seriaObj); },
asc_removeSeries: function() { this.series = []; }, asc_removeSeries: function() { this.series = []; },
asc_getChartEditorFlag: function() { return this.bChartEditor; }, asc_getChartEditorFlag: function() { return this.bChartEditor; },
asc_setChartEditorFlag: function(value) { this.bChartEditor = value; }, asc_setChartEditorFlag: function(value) { this.bChartEditor = value; },
rebuildSeries: function() {
var _t = this;
var bbox = _t.range.intervalObject.getBBox0();
_t.series = [];
var nameIndex = 1;
rebuildSeries: function() { if (_t.range.rows) {
var _t = this; for (var i = bbox.r1; i <= bbox.r2; i++) {
var bbox = _t.range.intervalObject.getBBox0(); var ser = new window["Asc"]["asc_CChartSeria"];
_t.series = [];
var nameIndex = 1;
if (_t.range.rows) {
for (var i = bbox.r1; i <= bbox.r2; i++) {
var ser = new window["Asc"]["asc_CChartSeria"];
var startCell = new CellAddress(i, bbox.c1, 0); var startCell = new CellAddress(i, bbox.c1, 0);
var endCell = new CellAddress(i, bbox.c2, 0); var endCell = new CellAddress(i, bbox.c2, 0);
if (startCell && endCell) { if (startCell && endCell) {
if (startCell.getID() == endCell.getID()) if (startCell.getID() == endCell.getID())
ser.Val.Formula = startCell.getID(); ser.Val.Formula = startCell.getID();
else { else {
ser.Val.Formula = ( !rx_test_ws_name.test(_t.range.intervalObject.worksheet.sName) ? "'" +_t.range.intervalObject.worksheet.sName+ "'" : _t.range.intervalObject.worksheet.sName ) ser.Val.Formula = ( !rx_test_ws_name.test(_t.range.intervalObject.worksheet.sName) ? "'" +_t.range.intervalObject.worksheet.sName+ "'" : _t.range.intervalObject.worksheet.sName )
+ "!" + startCell.getID() + ":" + endCell.getID(); + "!" + startCell.getID() + ":" + endCell.getID();
}
}
ser.Tx = "Series" + nameIndex;
_t.series.push(ser);
nameIndex++;
} }
}
ser.Tx = "Series" + nameIndex;
_t.series.push(ser);
nameIndex++;
} }
else { }
for (var i = bbox.c1; i <= bbox.c2; i++) { else {
var ser = new window["Asc"]["asc_CChartSeria"]; for (var i = bbox.c1; i <= bbox.c2; i++) {
var ser = new window["Asc"]["asc_CChartSeria"];
var startCell = new CellAddress(bbox.r1, i, 0); var startCell = new CellAddress(bbox.r1, i, 0);
var endCell = new CellAddress(bbox.r2, i, 0); var endCell = new CellAddress(bbox.r2, i, 0);
if (startCell && endCell) { if (startCell && endCell) {
if (startCell.getID() == endCell.getID()) if (startCell.getID() == endCell.getID())
ser.Val.Formula = startCell.getID(); ser.Val.Formula = startCell.getID();
else { else {
ser.Val.Formula = ( !rx_test_ws_name.test(_t.range.intervalObject.worksheet.sName) ? "'" +_t.range.intervalObject.worksheet.sName+ "'" : _t.range.intervalObject.worksheet.sName ) ser.Val.Formula = ( !rx_test_ws_name.test(_t.range.intervalObject.worksheet.sName) ? "'" +_t.range.intervalObject.worksheet.sName+ "'" : _t.range.intervalObject.worksheet.sName )
+ "!" + startCell.getID() + ":" + endCell.getID(); + "!" + startCell.getID() + ":" + endCell.getID();
} }
}
ser.Tx = "Series" + nameIndex;
_t.series.push(ser);
nameIndex++;
} }
ser.Tx = "Series" + nameIndex;
_t.series.push(ser);
nameIndex++;
} }
}, }
},
// For collaborative editing
getType: function() { // For collaborative editing
return UndoRedoDataTypes.ChartData; getType: function() {
}, return UndoRedoDataTypes.ChartData;
},
getProperties: function() { getProperties: function() {
return this.Properties; return this.Properties;
}, },
getProperty: function(nType) { getProperty: function(nType) {
switch (nType) { switch (nType) {
case this.Properties.bChartEditor: return this.bChartEditor; break; case this.Properties.bChartEditor: return this.bChartEditor; break;
case this.Properties.type: return this.type; break; case this.Properties.type: return this.type; break;
case this.Properties.subType: return this.subType; break; case this.Properties.subType: return this.subType; break;
case this.Properties.bShowValue: return this.bShowValue; break; case this.Properties.bShowValue: return this.bShowValue; break;
case this.Properties.bShowBorder: return this.bShowBorder; break; case this.Properties.bShowBorder: return this.bShowBorder; break;
case this.Properties.styleId: return this.styleId; break; case this.Properties.styleId: return this.styleId; break;
case this.Properties.header: return this.header; break; case this.Properties.header: return this.header; break;
case this.Properties.range: return this.range; break; case this.Properties.range: return this.range; break;
case this.Properties.xAxis: return this.xAxis; break; case this.Properties.xAxis: return this.xAxis; break;
case this.Properties.yAxis: return this.yAxis; break; case this.Properties.yAxis: return this.yAxis; break;
case this.Properties.legend: return this.legend; break; case this.Properties.legend: return this.legend; break;
case this.Properties.series: return this.series; break; case this.Properties.series: return this.series; break;
} }
}, },
setProperty: function(nType, value) { setProperty: function(nType, value) {
switch (nType) { switch (nType) {
case this.Properties.bChartEditor: this.bChartEditor = value; break; case this.Properties.bChartEditor: this.bChartEditor = value; break;
case this.Properties.type: this.type = value; break; case this.Properties.type: this.type = value; break;
case this.Properties.subType: this.subType = value; break; case this.Properties.subType: this.subType = value; break;
case this.Properties.bShowValue: this.bShowValue = value; break; case this.Properties.bShowValue: this.bShowValue = value; break;
case this.Properties.bShowBorder: this.bShowBorder = value; break; case this.Properties.bShowBorder: this.bShowBorder = value; break;
case this.Properties.styleId: this.styleId = value; break; case this.Properties.styleId: this.styleId = value; break;
case this.Properties.header: this.header = value; break; case this.Properties.header: this.header = value; break;
case this.Properties.range: this.range = value; break; case this.Properties.range: this.range = value; break;
case this.Properties.xAxis: this.xAxis = value; break; case this.Properties.xAxis: this.xAxis = value; break;
case this.Properties.yAxis: this.yAxis = value; break; case this.Properties.yAxis: this.yAxis = value; break;
case this.Properties.legend: this.legend = value; break; case this.Properties.legend: this.legend = value; break;
case this.Properties.series: this.series = value; break; case this.Properties.series: this.series = value; break;
}
} }
} }
}
//{ asc_CChart export
window["Asc"].asc_CChart = asc_CChart;
window["Asc"]["asc_CChart"] = asc_CChart;
prot = asc_CChart.prototype;
window["Asc"].asc_CChart = asc_CChart; prot["asc_getType"] = prot.asc_getType;
window["Asc"]["asc_CChart"] = asc_CChart; prot["asc_setType"] = prot.asc_setType;
prot = asc_CChart.prototype;
prot["asc_getType"] = prot.asc_getType;
prot["asc_setType"] = prot.asc_setType;
prot["asc_getSubType"] = prot.asc_getSubType;
prot["asc_setSubType"] = prot.asc_setSubType;
prot["asc_getStyleId"] = prot.asc_getStyleId; prot["asc_getSubType"] = prot.asc_getSubType;
prot["asc_setStyleId"] = prot.asc_setStyleId; prot["asc_setSubType"] = prot.asc_setSubType;
prot["asc_getShowValueFlag"] = prot.asc_getShowValueFlag; prot["asc_getStyleId"] = prot.asc_getStyleId;
prot["asc_setShowValueFlag"] = prot.asc_setShowValueFlag; prot["asc_setStyleId"] = prot.asc_setStyleId;
prot["asc_getShowBorderFlag"] = prot.asc_getShowBorderFlag;
prot["asc_setShowBorderFlag"] = prot.asc_setShowBorderFlag;
prot["asc_getHeader"] = prot.asc_getHeader;
prot["asc_setHeader"] = prot.asc_setHeader;
prot["asc_getRange"] = prot.asc_getRange; prot["asc_getShowValueFlag"] = prot.asc_getShowValueFlag;
prot["asc_setRange"] = prot.asc_setRange; prot["asc_setShowValueFlag"] = prot.asc_setShowValueFlag;
prot["asc_getXAxis"] = prot.asc_getXAxis; prot["asc_getShowBorderFlag"] = prot.asc_getShowBorderFlag;
prot["asc_setXAxis"] = prot.asc_setXAxis; prot["asc_setShowBorderFlag"] = prot.asc_setShowBorderFlag;
prot["asc_getYAxis"] = prot.asc_getYAxis; prot["asc_getHeader"] = prot.asc_getHeader;
prot["asc_setYAxis"] = prot.asc_setYAxis; prot["asc_setHeader"] = prot.asc_setHeader;
prot["asc_getLegend"] = prot.asc_getLegend; prot["asc_getRange"] = prot.asc_getRange;
prot["asc_setLegend"] = prot.asc_setLegend; prot["asc_setRange"] = prot.asc_setRange;
prot["asc_getSeria"] = prot.asc_getSeria;
prot["asc_setSeria"] = prot.asc_setSeria;
prot["asc_removeSeries"] = prot.asc_removeSeries;
prot["asc_getChartEditorFlag"] = prot.asc_getChartEditorFlag;
prot["asc_setChartEditorFlag"] = prot.asc_setChartEditorFlag;
// Chart range
function asc_CChartRange(object) {
var bCopy = isObject(object);
this.interval = bCopy ? object.interval : "";
this.intervalObject = bCopy ? object.intervalObject : null;
this.rows = bCopy ? object.rows : false;
this.columns = bCopy ? object.columns : true;
this.Properties = {
interval: 0,
rows: 1,
columns: 2
};
}
asc_CChartRange.prototype = { prot["asc_getXAxis"] = prot.asc_getXAxis;
prot["asc_setXAxis"] = prot.asc_setXAxis;
asc_getInterval: function() { return this.interval; }, prot["asc_getYAxis"] = prot.asc_getYAxis;
asc_setInterval: function(interval) { this.interval = interval; }, prot["asc_setYAxis"] = prot.asc_setYAxis;
asc_getRowsFlag: function() { return this.rows; }, prot["asc_getLegend"] = prot.asc_getLegend;
asc_setRowsFlag: function(value) { prot["asc_setLegend"] = prot.asc_setLegend;
this.rows = value;
this.columns = !value;
},
asc_getColumnsFlag: function() { return this.columns; },
asc_setColumnsFlag: function(value) {
this.rows = !value;
this.columns = value;
},
// For collaborative editing
getType: function() {
return UndoRedoDataTypes.ChartRange;
},
getProperties: function() { prot["asc_getSeria"] = prot.asc_getSeria;
return this.Properties; prot["asc_setSeria"] = prot.asc_setSeria;
}, prot["asc_removeSeries"] = prot.asc_removeSeries;
getProperty: function(nType) { prot["asc_getChartEditorFlag"] = prot.asc_getChartEditorFlag;
switch (nType) { prot["asc_setChartEditorFlag"] = prot.asc_setChartEditorFlag;
case this.Properties.interval: return this.interval; break; //}
case this.Properties.rows: return this.rows; break;
case this.Properties.columns: return this.columns; break; //-----------------------------------------------------------------------------------
} // Chart range
}, //-----------------------------------------------------------------------------------
setProperty: function(nType, value) { function asc_CChartRange(object) {
switch (nType) {
case this.Properties.interval: this.interval = value; break; var bCopy = isObject(object);
case this.Properties.rows: this.rows = value; break;
case this.Properties.columns: this.columns = value; break; this.interval = bCopy ? object.interval : "";
} this.intervalObject = bCopy ? object.intervalObject : null;
} this.rows = bCopy ? object.rows : false;
} this.columns = bCopy ? object.columns : true;
this.Properties = {
interval: 0,
rows: 1,
columns: 2
};
}
window["Asc"].asc_CChartRange = asc_CChartRange; asc_CChartRange.prototype = {
window["Asc"]["asc_CChartRange"] = asc_CChartRange;
prot = asc_CChartRange.prototype;
prot["asc_getInterval"] = prot.asc_getInterval; asc_getInterval: function() { return this.interval; },
prot["asc_setInterval"] = prot.asc_setInterval; asc_setInterval: function(interval) { this.interval = interval; },
prot["asc_getRowsFlag"] = prot.asc_getRowsFlag;
prot["asc_setRowsFlag"] = prot.asc_setRowsFlag;
prot["asc_getColumnsFlag"] = prot.asc_getColumnsFlag; asc_getRowsFlag: function() { return this.rows; },
prot["asc_setColumnsFlag"] = prot.asc_setColumnsFlag; asc_setRowsFlag: function(value) {
this.rows = value;
this.columns = !value;
},
// Chart title asc_getColumnsFlag: function() { return this.columns; },
function asc_CChartHeader(object) { asc_setColumnsFlag: function(value) {
this.rows = !value;
this.columns = value;
},
var bCopy = isObject(object); // For collaborative editing
getType: function() {
this.title = bCopy ? object.title : ""; return UndoRedoDataTypes.ChartRange;
this.subTitle = bCopy ? object.subTitle : ""; },
this.bDefaultTitle = bCopy ? object.bDefaultTitle : false;
this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont();
this.Properties = {
title: 0,
subTitle: 1,
bDefaultTitle: 2,
font: 3
};
}
asc_CChartHeader.prototype = {
asc_getTitle: function() { return this.title; },
asc_setTitle: function(title) { this.title = title; },
asc_getSubTitle: function() { return this.subTitle; },
asc_setSubTitle: function(subTitle) { this.subTitle = subTitle; },
asc_getDefaultTitleFlag: function() { return this.bDefaultTitle; },
asc_setDefaultTitleFlag: function(defaultTitleFlag) { this.bDefaultTitle = defaultTitleFlag; },
// For collaborative editing
getType: function() {
return UndoRedoDataTypes.ChartHeader;
},
getProperties: function() { getProperties: function() {
return this.Properties; return this.Properties;
}, },
getProperty: function(nType) { getProperty: function(nType) {
switch (nType) { switch (nType) {
case this.Properties.title: return this.title; break; case this.Properties.interval: return this.interval; break;
case this.Properties.subTitle: return this.subTitle; break; case this.Properties.rows: return this.rows; break;
case this.Properties.bDefaultTitle: return this.bDefaultTitle; break; case this.Properties.columns: return this.columns; break;
case this.Properties.font: return this.font; break; }
} },
},
setProperty: function(nType, value) { setProperty: function(nType, value) {
switch (nType) { switch (nType) {
case this.Properties.title: this.title = value; break; case this.Properties.interval: this.interval = value; break;
case this.Properties.subTitle: this.subTitle = value; break; case this.Properties.rows: this.rows = value; break;
case this.Properties.bDefaultTitle: this.bDefaultTitle = value; break; case this.Properties.columns: this.columns = value; break;
case this.Properties.font: this.font = value; break;
}
} }
} }
}
window["Asc"].asc_CChartHeader = asc_CChartHeader;
window["Asc"]["asc_CChartHeader"] = asc_CChartHeader; //{ asc_CChartRange export
prot = asc_CChartHeader.prototype; window["Asc"].asc_CChartRange = asc_CChartRange;
window["Asc"]["asc_CChartRange"] = asc_CChartRange;
prot = asc_CChartRange.prototype;
prot["asc_getTitle"] = prot.asc_getTitle; prot["asc_getInterval"] = prot.asc_getInterval;
prot["asc_setTitle"] = prot.asc_setTitle; prot["asc_setInterval"] = prot.asc_setInterval;
prot["asc_getSubTitle"] = prot.asc_getSubTitle; prot["asc_getRowsFlag"] = prot.asc_getRowsFlag;
prot["asc_setSubTitle"] = prot.asc_setSubTitle; prot["asc_setRowsFlag"] = prot.asc_setRowsFlag;
prot["asc_getDefaultTitleFlag"] = prot.asc_getDefaultTitleFlag; prot["asc_getColumnsFlag"] = prot.asc_getColumnsFlag;
prot["asc_setDefaultTitleFlag"] = prot.asc_setDefaultTitleFlag; prot["asc_setColumnsFlag"] = prot.asc_setColumnsFlag;
//}
// Chart axis X
function asc_CChartAxisX(object) { //-----------------------------------------------------------------------------------
// Chart title
var bCopy = isObject(object); //-----------------------------------------------------------------------------------
this.title = bCopy ? object.title : "";
this.bDefaultTitle = bCopy ? object.bDefaultTitle : false;
this.bShow = bCopy ? object.bShow : true;
this.bGrid = bCopy ? object.bGrid : true;
this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont();
this.Properties = {
title: 0,
bDefaultTitle: 1,
bShow: 2,
bGrid: 3,
font: 4
};
}
asc_CChartAxisX.prototype = { function asc_CChartHeader(object) {
asc_getTitle: function() { return this.title; },
asc_setTitle: function(title) { this.title = title; },
asc_getDefaultTitleFlag: function() { return this.bDefaultTitle; }, var bCopy = isObject(object);
asc_setDefaultTitleFlag: function(defaultTitleFlag) { this.bDefaultTitle = defaultTitleFlag; },
this.title = bCopy ? object.title : "";
this.subTitle = bCopy ? object.subTitle : "";
this.bDefaultTitle = bCopy ? object.bDefaultTitle : false;
this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont();
this.Properties = {
title: 0,
subTitle: 1,
bDefaultTitle: 2,
font: 3
};
}
asc_getShowFlag: function() { return this.bShow; }, asc_CChartHeader.prototype = {
asc_setShowFlag: function(showFlag) { this.bShow = showFlag; }, asc_getTitle: function() { return this.title; },
asc_setTitle: function(title) { this.title = title; },
asc_getSubTitle: function() { return this.subTitle; },
asc_setSubTitle: function(subTitle) { this.subTitle = subTitle; },
asc_getGridFlag: function() { return this.bGrid; }, asc_getDefaultTitleFlag: function() { return this.bDefaultTitle; },
asc_setGridFlag: function(gridFlag) { this.bGrid = gridFlag; }, asc_setDefaultTitleFlag: function(defaultTitleFlag) { this.bDefaultTitle = defaultTitleFlag; },
// For collaborative editing // For collaborative editing
getType: function() { getType: function() {
return UndoRedoDataTypes.ChartAxisX; return UndoRedoDataTypes.ChartHeader;
}, },
getProperties: function() { getProperties: function() {
return this.Properties; return this.Properties;
}, },
getProperty: function(nType) { getProperty: function(nType) {
switch (nType) { switch (nType) {
case this.Properties.title: return this.title; break; case this.Properties.title: return this.title; break;
case this.Properties.bDefaultTitle: return this.bDefaultTitle; break; case this.Properties.subTitle: return this.subTitle; break;
case this.Properties.bShow: return this.bShow; break; case this.Properties.bDefaultTitle: return this.bDefaultTitle; break;
case this.Properties.bGrid: return this.bGrid; break; case this.Properties.font: return this.font; break;
case this.Properties.font: return this.font; break; }
} },
},
setProperty: function(nType, value) { setProperty: function(nType, value) {
switch (nType) { switch (nType) {
case this.Properties.title: this.title = value; break; case this.Properties.title: this.title = value; break;
case this.Properties.bDefaultTitle: this.bDefaultTitle = value; break; case this.Properties.subTitle: this.subTitle = value; break;
case this.Properties.bShow: this.bShow = value; break; case this.Properties.bDefaultTitle: this.bDefaultTitle = value; break;
case this.Properties.bGrid: this.bGrid = value; break; case this.Properties.font: this.font = value; break;
case this.Properties.font: this.font = value; break;
}
} }
} }
}
//{ asc_CChartHeader export
window["Asc"].asc_CChartHeader = asc_CChartHeader;
window["Asc"]["asc_CChartHeader"] = asc_CChartHeader;
prot = asc_CChartHeader.prototype;
window["Asc"].asc_CChartAxisX = asc_CChartAxisX; prot["asc_getTitle"] = prot.asc_getTitle;
window["Asc"]["asc_CChartAxisX"] = asc_CChartAxisX; prot["asc_setTitle"] = prot.asc_setTitle;
prot = asc_CChartAxisX.prototype;
prot["asc_getTitle"] = prot.asc_getTitle;
prot["asc_setTitle"] = prot.asc_setTitle;
prot["asc_getDefaultTitleFlag"] = prot.asc_getDefaultTitleFlag; prot["asc_getSubTitle"] = prot.asc_getSubTitle;
prot["asc_setDefaultTitleFlag"] = prot.asc_setDefaultTitleFlag; prot["asc_setSubTitle"] = prot.asc_setSubTitle;
prot["asc_getShowFlag"] = prot.asc_getShowFlag; prot["asc_getDefaultTitleFlag"] = prot.asc_getDefaultTitleFlag;
prot["asc_setShowFlag"] = prot.asc_setShowFlag; prot["asc_setDefaultTitleFlag"] = prot.asc_setDefaultTitleFlag;
//}
//-----------------------------------------------------------------------------------
// Chart axis X
//-----------------------------------------------------------------------------------
prot["asc_getGridFlag"] = prot.asc_getGridFlag; function asc_CChartAxisX(object) {
prot["asc_setGridFlag"] = prot.asc_setGridFlag;
var bCopy = isObject(object);
// Chart axis Y this.title = bCopy ? object.title : "";
function asc_CChartAxisY(object) { this.bDefaultTitle = bCopy ? object.bDefaultTitle : false;
this.bShow = bCopy ? object.bShow : true;
this.bGrid = bCopy ? object.bGrid : true;
this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont();
var bCopy = isObject(object); this.Properties = {
title: 0,
this.title = bCopy ? object.title : ""; bDefaultTitle: 1,
this.bDefaultTitle = bCopy ? object.bDefaultTitle : false; bShow: 2,
this.bShow = bCopy ? object.bShow : true; bGrid: 3,
this.bGrid = bCopy ? object.bGrid : true; font: 4
this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont(); };
}
this.Properties = {
title: 0,
bDefaultTitle: 1,
bShow: 2,
bGrid: 3,
font: 4
};
}
asc_CChartAxisY.prototype = { asc_CChartAxisX.prototype = {
asc_getTitle: function() { return this.title; }, asc_getTitle: function() { return this.title; },
asc_setTitle: function(title) { this.title = title; }, asc_setTitle: function(title) { this.title = title; },
asc_getDefaultTitleFlag: function() { return this.bDefaultTitle; }, asc_getDefaultTitleFlag: function() { return this.bDefaultTitle; },
asc_setDefaultTitleFlag: function(defaultTitleFlag) { this.bDefaultTitle = defaultTitleFlag; }, asc_setDefaultTitleFlag: function(defaultTitleFlag) { this.bDefaultTitle = defaultTitleFlag; },
asc_getShowFlag: function() { return this.bShow; }, asc_getShowFlag: function() { return this.bShow; },
asc_setShowFlag: function(showFlag) { this.bShow = showFlag; }, asc_setShowFlag: function(showFlag) { this.bShow = showFlag; },
asc_getGridFlag: function() { return this.bGrid; }, asc_getGridFlag: function() { return this.bGrid; },
asc_setGridFlag: function(gridFlag) { this.bGrid = gridFlag; }, asc_setGridFlag: function(gridFlag) { this.bGrid = gridFlag; },
// For collaborative editing // For collaborative editing
getType: function() { getType: function() {
return UndoRedoDataTypes.ChartAxisY; return UndoRedoDataTypes.ChartAxisX;
}, },
getProperties: function() { getProperties: function() {
return this.Properties; return this.Properties;
}, },
getProperty: function(nType) { getProperty: function(nType) {
switch (nType) { switch (nType) {
case this.Properties.title: return this.title; break; case this.Properties.title: return this.title; break;
case this.Properties.bDefaultTitle: return this.bDefaultTitle; break; case this.Properties.bDefaultTitle: return this.bDefaultTitle; break;
case this.Properties.bShow: return this.bShow; break; case this.Properties.bShow: return this.bShow; break;
case this.Properties.bGrid: return this.bGrid; break; case this.Properties.bGrid: return this.bGrid; break;
case this.Properties.font: return this.font; break; case this.Properties.font: return this.font; break;
} }
}, },
setProperty: function(nType, value) { setProperty: function(nType, value) {
switch (nType) { switch (nType) {
case this.Properties.title: this.title = value; break; case this.Properties.title: this.title = value; break;
case this.Properties.bDefaultTitle: this.bDefaultTitle = value; break; case this.Properties.bDefaultTitle: this.bDefaultTitle = value; break;
case this.Properties.bShow: this.bShow = value; break; case this.Properties.bShow: this.bShow = value; break;
case this.Properties.bGrid: this.bGrid = value; break; case this.Properties.bGrid: this.bGrid = value; break;
case this.Properties.font: this.font = value; break; case this.Properties.font: this.font = value; break;
}
} }
} }
}
//{ asc_CChartAxisX export
window["Asc"].asc_CChartAxisX = asc_CChartAxisX;
window["Asc"]["asc_CChartAxisX"] = asc_CChartAxisX;
prot = asc_CChartAxisX.prototype;
window["Asc"].asc_CChartAxisY = asc_CChartAxisY; prot["asc_getTitle"] = prot.asc_getTitle;
window["Asc"]["asc_CChartAxisY"] = asc_CChartAxisY; prot["asc_setTitle"] = prot.asc_setTitle;
prot = asc_CChartAxisY.prototype;
prot["asc_getTitle"] = prot.asc_getTitle; prot["asc_getDefaultTitleFlag"] = prot.asc_getDefaultTitleFlag;
prot["asc_setTitle"] = prot.asc_setTitle; prot["asc_setDefaultTitleFlag"] = prot.asc_setDefaultTitleFlag;
prot["asc_getDefaultTitleFlag"] = prot.asc_getDefaultTitleFlag; prot["asc_getShowFlag"] = prot.asc_getShowFlag;
prot["asc_setDefaultTitleFlag"] = prot.asc_setDefaultTitleFlag; prot["asc_setShowFlag"] = prot.asc_setShowFlag;
prot["asc_getShowFlag"] = prot.asc_getShowFlag; prot["asc_getGridFlag"] = prot.asc_getGridFlag;
prot["asc_setShowFlag"] = prot.asc_setShowFlag; prot["asc_setGridFlag"] = prot.asc_setGridFlag;
//}
//-----------------------------------------------------------------------------------
// Chart axis Y
//-----------------------------------------------------------------------------------
prot["asc_getGridFlag"] = prot.asc_getGridFlag; function asc_CChartAxisY(object) {
prot["asc_setGridFlag"] = prot.asc_setGridFlag;
// Chart legend var bCopy = isObject(object);
function asc_CChartLegend(object) {
this.title = bCopy ? object.title : "";
var bCopy = isObject(object); this.bDefaultTitle = bCopy ? object.bDefaultTitle : false;
this.bShow = bCopy ? object.bShow : true;
this.position = bCopy ? object.position : c_oAscChartLegend.right; this.bGrid = bCopy ? object.bGrid : true;
this.bShow = bCopy ? object.bShow : true; this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont();
this.bOverlay = bCopy ? object.bOverlay : false;
this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont(); this.Properties = {
title: 0,
this.Properties = { bDefaultTitle: 1,
position: 0, bShow: 2,
bShow: 1, bGrid: 3,
bOverlay: 2, font: 4
font: 3 };
}; }
}
asc_CChartLegend.prototype = { asc_CChartAxisY.prototype = {
asc_getPosition: function() { return this.position; }, asc_getTitle: function() { return this.title; },
asc_setPosition: function(pos) { this.position = pos; }, asc_setTitle: function(title) { this.title = title; },
asc_getShowFlag: function() { return this.bShow; }, asc_getDefaultTitleFlag: function() { return this.bDefaultTitle; },
asc_setShowFlag: function(showFlag) { this.bShow = showFlag; }, asc_setDefaultTitleFlag: function(defaultTitleFlag) { this.bDefaultTitle = defaultTitleFlag; },
asc_getOverlayFlag: function() { return this.bOverlay; }, asc_getShowFlag: function() { return this.bShow; },
asc_setOverlayFlag: function(overlayFlag) { this.bOverlay = overlayFlag; }, asc_setShowFlag: function(showFlag) { this.bShow = showFlag; },
// For collaborative editing
getType: function() {
return UndoRedoDataTypes.ChartLegend;
},
getProperties: function() { asc_getGridFlag: function() { return this.bGrid; },
return this.Properties; asc_setGridFlag: function(gridFlag) { this.bGrid = gridFlag; },
},
// For collaborative editing
getType: function() {
return UndoRedoDataTypes.ChartAxisY;
},
getProperty: function(nType) { getProperties: function() {
switch (nType) { return this.Properties;
case this.Properties.position: return this.position; break; },
case this.Properties.bShow: return this.bShow; break;
case this.Properties.bOverlay: return this.bOverlay; break;
case this.Properties.font: return this.font; break;
}
},
setProperty: function(nType, value) { getProperty: function(nType) {
switch (nType) { switch (nType) {
case this.Properties.position: this.position = value; break; case this.Properties.title: return this.title; break;
case this.Properties.bShow: this.bShow = value; break; case this.Properties.bDefaultTitle: return this.bDefaultTitle; break;
case this.Properties.bOverlay: this.bOverlay = value; break; case this.Properties.bShow: return this.bShow; break;
case this.Properties.font: this.font = value; break; case this.Properties.bGrid: return this.bGrid; break;
} case this.Properties.font: return this.font; break;
}
},
setProperty: function(nType, value) {
switch (nType) {
case this.Properties.title: this.title = value; break;
case this.Properties.bDefaultTitle: this.bDefaultTitle = value; break;
case this.Properties.bShow: this.bShow = value; break;
case this.Properties.bGrid: this.bGrid = value; break;
case this.Properties.font: this.font = value; break;
} }
} }
}
//{ asc_CChartAxisY export
window["Asc"].asc_CChartAxisY = asc_CChartAxisY;
window["Asc"]["asc_CChartAxisY"] = asc_CChartAxisY;
prot = asc_CChartAxisY.prototype;
prot["asc_getTitle"] = prot.asc_getTitle;
prot["asc_setTitle"] = prot.asc_setTitle;
window["Asc"].asc_CChartLegend = asc_CChartLegend; prot["asc_getDefaultTitleFlag"] = prot.asc_getDefaultTitleFlag;
window["Asc"]["asc_CChartLegend"] = asc_CChartLegend; prot["asc_setDefaultTitleFlag"] = prot.asc_setDefaultTitleFlag;
prot = asc_CChartLegend.prototype;
prot["asc_getPosition"] = prot.asc_getPosition; prot["asc_getShowFlag"] = prot.asc_getShowFlag;
prot["asc_setPosition"] = prot.asc_setPosition; prot["asc_setShowFlag"] = prot.asc_setShowFlag;
prot["asc_getShowFlag"] = prot.asc_getShowFlag; prot["asc_getGridFlag"] = prot.asc_getGridFlag;
prot["asc_setShowFlag"] = prot.asc_setShowFlag; prot["asc_setGridFlag"] = prot.asc_setGridFlag;
//}
//-----------------------------------------------------------------------------------
// Chart legend
//-----------------------------------------------------------------------------------
function asc_CChartLegend(object) {
var bCopy = isObject(object);
this.position = bCopy ? object.position : c_oAscChartLegend.right;
this.bShow = bCopy ? object.bShow : true;
this.bOverlay = bCopy ? object.bOverlay : false;
this.font = bCopy ? new asc_CChartFont(object.font) : new asc_CChartFont();
this.Properties = {
position: 0,
bShow: 1,
bOverlay: 2,
font: 3
};
}
prot["asc_getOverlayFlag"] = prot.asc_getOverlayFlag; asc_CChartLegend.prototype = {
prot["asc_setOverlayFlag"] = prot.asc_setOverlayFlag; asc_getPosition: function() { return this.position; },
asc_setPosition: function(pos) { this.position = pos; },
// Chart series asc_getShowFlag: function() { return this.bShow; },
function asc_CChartSeria() { asc_setShowFlag: function(showFlag) { this.bShow = showFlag; },
this.Val = { Formula: null, NumCache: [] };
this.xVal = { Formula: null, NumCache: [] };
this.Tx = null;
this.Marker = { Size: null, Symbol: null };
this.OutlineColor = null;
this.Properties = { asc_getOverlayFlag: function() { return this.bOverlay; },
ValFormula: 0, asc_setOverlayFlag: function(overlayFlag) { this.bOverlay = overlayFlag; },
ValNumCache: 1,
XValFormula: 2, // For collaborative editing
XValNumCache: 3, getType: function() {
Tx: 4, return UndoRedoDataTypes.ChartLegend;
MarkerSize: 5, },
MarkerSymbol: 6,
OutlineColor: 7 getProperties: function() {
}; return this.Properties;
},
getProperty: function(nType) {
switch (nType) {
case this.Properties.position: return this.position; break;
case this.Properties.bShow: return this.bShow; break;
case this.Properties.bOverlay: return this.bOverlay; break;
case this.Properties.font: return this.font; break;
}
},
setProperty: function(nType, value) {
switch (nType) {
case this.Properties.position: this.position = value; break;
case this.Properties.bShow: this.bShow = value; break;
case this.Properties.bOverlay: this.bOverlay = value; break;
case this.Properties.font: this.font = value; break;
}
} }
}
//{ asc_CChartLegend export
window["Asc"].asc_CChartLegend = asc_CChartLegend;
window["Asc"]["asc_CChartLegend"] = asc_CChartLegend;
prot = asc_CChartLegend.prototype;
prot["asc_getPosition"] = prot.asc_getPosition;
prot["asc_setPosition"] = prot.asc_setPosition;
prot["asc_getShowFlag"] = prot.asc_getShowFlag;
prot["asc_setShowFlag"] = prot.asc_setShowFlag;
prot["asc_getOverlayFlag"] = prot.asc_getOverlayFlag;
prot["asc_setOverlayFlag"] = prot.asc_setOverlayFlag;
//}
//-----------------------------------------------------------------------------------
// Chart series
//-----------------------------------------------------------------------------------
function asc_CChartSeria() {
this.Val = { Formula: null, NumCache: [] };
this.xVal = { Formula: null, NumCache: [] };
this.Tx = null;
this.Marker = { Size: null, Symbol: null };
this.OutlineColor = null;
this.Properties = {
ValFormula: 0,
ValNumCache: 1,
XValFormula: 2,
XValNumCache: 3,
Tx: 4,
MarkerSize: 5,
MarkerSymbol: 6,
OutlineColor: 7
};
}
asc_CChartSeria.prototype = { asc_CChartSeria.prototype = {
asc_getValFormula: function() { return this.Val.Formula; }, asc_getValFormula: function() { return this.Val.Formula; },
asc_setValFormula: function(formula) { this.Val.Formula = formula; }, asc_setValFormula: function(formula) { this.Val.Formula = formula; },
asc_getxValFormula: function() { return this.xVal.Formula; }, asc_getxValFormula: function() { return this.xVal.Formula; },
asc_setxValFormula: function(formula) { this.xVal.Formula = formula; }, asc_setxValFormula: function(formula) { this.xVal.Formula = formula; },
asc_getTitle: function() { return this.Tx; }, asc_getTitle: function() { return this.Tx; },
asc_setTitle: function(title) { this.Tx = title; }, asc_setTitle: function(title) { this.Tx = title; },
asc_getMarkerSize: function() { return this.Marker.Size; }, asc_getMarkerSize: function() { return this.Marker.Size; },
asc_setMarkerSize: function(size) { this.Marker.Size = size; }, asc_setMarkerSize: function(size) { this.Marker.Size = size; },
asc_getMarkerSymbol: function() { return this.Marker.Symbol; }, asc_getMarkerSymbol: function() { return this.Marker.Symbol; },
asc_setMarkerSymbol: function(symbol) { this.Marker.Symbol = symbol; }, asc_setMarkerSymbol: function(symbol) { this.Marker.Symbol = symbol; },
asc_getOutlineColor: function() { return this.OutlineColor; }, asc_getOutlineColor: function() { return this.OutlineColor; },
asc_setOutlineColor: function(color) { this.OutlineColor = color; }, asc_setOutlineColor: function(color) { this.OutlineColor = color; },
// For collaborative editing // For collaborative editing
getType: function() { getType: function() {
return UndoRedoDataTypes.ChartSeriesData; return UndoRedoDataTypes.ChartSeriesData;
}, },
getProperties: function() { getProperties: function() {
return this.Properties; return this.Properties;
}, },
getProperty: function(nType) { getProperty: function(nType) {
switch (nType) { switch (nType) {
case this.Properties.ValFormula: return this.Val.Formula; break; case this.Properties.ValFormula: return this.Val.Formula; break;
case this.Properties.ValNumCache: return this.Val.NumCache; break; case this.Properties.ValNumCache: return this.Val.NumCache; break;
case this.Properties.XValFormula: return this.xVal.Formula; break; case this.Properties.XValFormula: return this.xVal.Formula; break;
case this.Properties.XValNumCache: return this.xVal.NumCache; break; case this.Properties.XValNumCache: return this.xVal.NumCache; break;
case this.Properties.Tx: return this.Tx; break; case this.Properties.Tx: return this.Tx; break;
case this.Properties.MarkerSize: return this.Marker.Size; break; case this.Properties.MarkerSize: return this.Marker.Size; break;
case this.Properties.MarkerSymbol: return this.Marker.Symbol; break; case this.Properties.MarkerSymbol: return this.Marker.Symbol; break;
case this.Properties.OutlineColor: return this.OutlineColor; break; case this.Properties.OutlineColor: return this.OutlineColor; break;
} }
}, },
setProperty: function(nType, value) { setProperty: function(nType, value) {
switch (nType) { switch (nType) {
case this.Properties.ValFormula: this.Val.Formula = value; break; case this.Properties.ValFormula: this.Val.Formula = value; break;
case this.Properties.ValNumCache: this.Val.NumCache = value; break; case this.Properties.ValNumCache: this.Val.NumCache = value; break;
case this.Properties.XValFormula: this.xVal.Formula = value; break; case this.Properties.XValFormula: this.xVal.Formula = value; break;
case this.Properties.XValNumCache: this.xVal.NumCache = value; break; case this.Properties.XValNumCache: this.xVal.NumCache = value; break;
case this.Properties.Tx: this.Tx = value; break; case this.Properties.Tx: this.Tx = value; break;
case this.Properties.MarkerSize: this.Marker.Size = value; break; case this.Properties.MarkerSize: this.Marker.Size = value; break;
case this.Properties.MarkerSymbol: this.Marker.Symbol = value; break; case this.Properties.MarkerSymbol: this.Marker.Symbol = value; break;
case this.Properties.OutlineColor: this.OutlineColor = value; break; case this.Properties.OutlineColor: this.OutlineColor = value; break;
}
} }
} }
}
//{ asc_CChartSeria export
window["Asc"].asc_CChartSeria = asc_CChartSeria;
window["Asc"]["asc_CChartSeria"] = asc_CChartSeria;
prot = asc_CChartSeria.prototype;
prot["asc_getValFormula"] = prot.asc_getValFormula;
prot["asc_setValFormula"] = prot.asc_setValFormula;
window["Asc"].asc_CChartSeria = asc_CChartSeria; prot["asc_getxValFormula"] = prot.asc_getxValFormula;
window["Asc"]["asc_CChartSeria"] = asc_CChartSeria; prot["asc_setxValFormula"] = prot.asc_setxValFormula;
prot = asc_CChartSeria.prototype;
prot["asc_getValFormula"] = prot.asc_getValFormula; prot["asc_getTitle"] = prot.asc_getTitle;
prot["asc_setValFormula"] = prot.asc_setValFormula; prot["asc_setTitle"] = prot.asc_setTitle;
prot["asc_getxValFormula"] = prot.asc_getxValFormula; prot["asc_getMarkerSize"] = prot.asc_getMarkerSize;
prot["asc_setxValFormula"] = prot.asc_setxValFormula; prot["asc_setMarkerSize"] = prot.asc_setMarkerSize;
prot["asc_getTitle"] = prot.asc_getTitle; prot["asc_getMarkerSymbol"] = prot.asc_getMarkerSymbol;
prot["asc_setTitle"] = prot.asc_setTitle; prot["asc_setMarkerSymbol"] = prot.asc_setMarkerSymbol;
prot["asc_getMarkerSize"] = prot.asc_getMarkerSize; prot["asc_getOutlineColor"] = prot.asc_getOutlineColor;
prot["asc_setMarkerSize"] = prot.asc_setMarkerSize; prot["asc_setOutlineColor"] = prot.asc_setOutlineColor;
//}
//-----------------------------------------------------------------------------------
// Chart font
//-----------------------------------------------------------------------------------
prot["asc_getMarkerSymbol"] = prot.asc_getMarkerSymbol; function asc_CChartFont(object) {
prot["asc_setMarkerSymbol"] = prot.asc_setMarkerSymbol;
var bCopy = isObject(object);
prot["asc_getOutlineColor"] = prot.asc_getOutlineColor; this.name = bCopy ? object.name : "Arial";
prot["asc_setOutlineColor"] = prot.asc_setOutlineColor; this.size = bCopy ? object.size : 12;
this.color = bCopy ? object.color : "#000000";
// Chart font this.bold = bCopy ? object.bold : 0;
function asc_CChartFont(object) { this.italic = bCopy ? object.italic : 0;
this.underline = bCopy ? object.underline : 0;
var bCopy = isObject(object);
this.name = bCopy ? object.name : "Arial"; this.Properties = {
this.size = bCopy ? object.size : 12; name: 0,
this.color = bCopy ? object.color : "#000000"; size: 1,
color: 2,
this.bold = bCopy ? object.bold : 0; bold: 3,
this.italic = bCopy ? object.italic : 0; italic: 4,
this.underline = bCopy ? object.underline : 0; underline: 5
this.Properties = {
name: 0,
size: 1,
color: 2,
bold: 3,
italic: 4,
underline: 5
}
} }
}
asc_CChartFont.prototype = {
asc_getName: function() { return this.name; },
asc_setName: function(val) { this.name = val; },
asc_getSize: function() { return this.size; }, asc_CChartFont.prototype = {
asc_setSize: function(val) { this.size = val; }, asc_getName: function() { return this.name; },
asc_setName: function(val) { this.name = val; },
asc_getColor: function() { return this.color; }, asc_getSize: function() { return this.size; },
asc_setColor: function(val) { this.color = val; }, asc_setSize: function(val) { this.size = val; },
asc_getBold: function() { return this.bold; },
asc_setBold: function(val) { this.bold = val; },
asc_getItalic: function() { return this.italic; },
asc_setItalic: function(val) { this.italic = val; },
asc_getUnderline: function() { return this.underline; },
asc_setUnderline: function(val) { this.underline = val; },
// For collaborative editing
getType: function() {
return UndoRedoDataTypes.ChartFont;
},
getProperties: function() { asc_getColor: function() { return this.color; },
return this.Properties; asc_setColor: function(val) { this.color = val; },
},
asc_getBold: function() { return this.bold; },
asc_setBold: function(val) { this.bold = val; },
asc_getItalic: function() { return this.italic; },
asc_setItalic: function(val) { this.italic = val; },
asc_getUnderline: function() { return this.underline; },
asc_setUnderline: function(val) { this.underline = val; },
// For collaborative editing
getType: function() {
return UndoRedoDataTypes.ChartFont;
},
getProperty: function(nType) { getProperties: function() {
switch (nType) { return this.Properties;
case this.Properties.name: return this.name; break; },
case this.Properties.size: return this.size; break;
case this.Properties.color: return this.color; break;
case this.Properties.bold: return this.bold; break;
case this.Properties.italic: return this.italic; break;
case this.Properties.underline: return this.underline; break;
}
},
setProperty: function(nType, value) { getProperty: function(nType) {
switch (nType) { switch (nType) {
case this.Properties.name: this.name = value; break; case this.Properties.name: return this.name; break;
case this.Properties.size: this.size = value; break; case this.Properties.size: return this.size; break;
case this.Properties.color: this.color = value; break; case this.Properties.color: return this.color; break;
case this.Properties.bold: this.bold = value; break; case this.Properties.bold: return this.bold; break;
case this.Properties.italic: this.italic = value; break; case this.Properties.italic: return this.italic; break;
case this.Properties.underline: this.underline = value; break; case this.Properties.underline: return this.underline; break;
} }
},
setProperty: function(nType, value) {
switch (nType) {
case this.Properties.name: this.name = value; break;
case this.Properties.size: this.size = value; break;
case this.Properties.color: this.color = value; break;
case this.Properties.bold: this.bold = value; break;
case this.Properties.italic: this.italic = value; break;
case this.Properties.underline: this.underline = value; break;
} }
} }
}
//{ asc_CChartFont export
window["Asc"].asc_CChartFont = asc_CChartFont; window["Asc"].asc_CChartFont = asc_CChartFont;
window["Asc"]["asc_CChartFont"] = asc_CChartFont; window["Asc"]["asc_CChartFont"] = asc_CChartFont;
prot = asc_CChartFont.prototype; prot = asc_CChartFont.prototype;
...@@ -1282,9 +1331,13 @@ ...@@ -1282,9 +1331,13 @@
prot["asc_setItalic"] = prot.asc_setItalic; prot["asc_setItalic"] = prot.asc_setItalic;
prot["asc_getUnderline"] = prot.asc_getUnderline; prot["asc_getUnderline"] = prot.asc_getUnderline;
prot["asc_setUnderline"] = prot.asc_setUnderline; prot["asc_setUnderline"] = prot.asc_setUnderline;
//}
// Undo / Redo //-----------------------------------------------------------------------------------
// Undo/Redo
//-----------------------------------------------------------------------------------
DrawingObjects.prototype = { DrawingObjects.prototype = {
Undo: function(type, data) { Undo: function(type, data) {
...@@ -1315,7 +1368,7 @@ DrawingObjects.prototype = { ...@@ -1315,7 +1368,7 @@ DrawingObjects.prototype = {
aStorage.push(obj); aStorage.push(obj);
} }
this.changeObjectStorage(aStorage); this.changeObjectStorage(aStorage);
this.showDrawingObjects(true, null, false, false); this.showDrawingObjects(true, null, false);
} }
break; break;
} }
...@@ -1349,7 +1402,7 @@ DrawingObjects.prototype = { ...@@ -1349,7 +1402,7 @@ DrawingObjects.prototype = {
aStorage.push(obj); aStorage.push(obj);
} }
this.changeObjectStorage(aStorage); this.changeObjectStorage(aStorage);
this.showDrawingObjects(true, null, false, false); this.showDrawingObjects(true, null, false);
} }
break; break;
} }
...@@ -1378,7 +1431,10 @@ function DrawingObjects() { ...@@ -1378,7 +1431,10 @@ function DrawingObjects() {
var shiftKey = false; var shiftKey = false;
var userId = null; var userId = null;
var documentId = null; var documentId = null;
var lastObjectIndex = null; var lastObjectIndex = null;
// Все изменения, связанные с image.src прогоняем через этот класс
var imageLoader = new ImageLoader();
//----------------------------------------------------------------------------------- //-----------------------------------------------------------------------------------
// Public methods // Public methods
...@@ -1400,10 +1456,12 @@ function DrawingObjects() { ...@@ -1400,10 +1456,12 @@ function DrawingObjects() {
currentSheet.model.Drawings[i].worksheet = worksheet; currentSheet.model.Drawings[i].worksheet = worksheet;
aObjects[i] = _this.cloneDrawingObject(currentSheet.model.Drawings[i]); aObjects[i] = _this.cloneDrawingObject(currentSheet.model.Drawings[i]);
aObjects[i].flags.loaded = currentSheet.model.Drawings[i].flags.loaded;
if (aObjects[i].isChart())
if (aObjects[i].isChart()) _this.calcChartInterval(aObjects[i].chart);
_this.calcChartInterval(aObjects[i].chart);
if (aObjects[i].isImage())
imageLoader.addImage(aObjects[i].image.src);
} }
lastObjectIndex = aObjects.length; lastObjectIndex = aObjects.length;
...@@ -1526,7 +1584,7 @@ function DrawingObjects() { ...@@ -1526,7 +1584,7 @@ function DrawingObjects() {
_this.showOverlayDrawingObject = function(index) { _this.showOverlayDrawingObject = function(index) {
if (_this.checkDrawingObjectIndex(index)) { if (_this.checkDrawingObjectIndex(index)) {
var obj = aObjects[index]; var obj = aObjects[index];
if (!obj.flags.loaded || !obj.image.complete) // complete - дополнительная проверка в случае base64 if ( !obj.image.complete ) // complete - дополнительная проверка в случае base64
return; return;
if (obj.image.width && obj.image.height) { if (obj.image.width && obj.image.height) {
...@@ -1550,7 +1608,7 @@ function DrawingObjects() { ...@@ -1550,7 +1608,7 @@ function DrawingObjects() {
} }
} }
_this.showDrawingObjects = function(clearCanvas, printOptions, bMouseUp, bUpdateCharts) { _this.showDrawingObjects = function(clearCanvas, printOptions, bUpdateCharts) {
/*********** Print Options *************** /*********** Print Options ***************
printOptions : { printOptions : {
...@@ -1573,7 +1631,16 @@ function DrawingObjects() { ...@@ -1573,7 +1631,16 @@ function DrawingObjects() {
// всё чистим // всё чистим
if (clearCanvas) if (clearCanvas)
_this.clearDrawingObjects(); _this.clearDrawingObjects();
if ( !imageLoader.isReady() ) {
//console.log("imageLoader - False");
imageLoader.setReadyCallback(_this.showDrawingObjects);
}
else {
//console.log("imageLoader - Ok");
imageLoader.removeReadyCallback();
}
for (var i = 0; i < _this.countDrawingObjects(); i++) { for (var i = 0; i < _this.countDrawingObjects(); i++) {
...@@ -1585,7 +1652,8 @@ function DrawingObjects() { ...@@ -1585,7 +1652,8 @@ function DrawingObjects() {
if (!obj.flags.anchorUpdated) if (!obj.flags.anchorUpdated)
obj.updateAnchorPosition(); obj.updateAnchorPosition();
// History
if (obj.move.inAction && undoRedoObject && (undoRedoObject.id == obj.id)) { if (obj.move.inAction && undoRedoObject && (undoRedoObject.id == obj.id)) {
History.Create_NewPoint(); History.Create_NewPoint();
...@@ -1605,7 +1673,7 @@ function DrawingObjects() { ...@@ -1605,7 +1673,7 @@ function DrawingObjects() {
var srcForPrint; var srcForPrint;
// выход за границы // Выход за границы
while (worksheet.nColsCount < obj.to.col + 1) { while (worksheet.nColsCount < obj.to.col + 1) {
worksheet.expandColsOnScroll(true); worksheet.expandColsOnScroll(true);
} }
...@@ -1613,62 +1681,33 @@ function DrawingObjects() { ...@@ -1613,62 +1681,33 @@ function DrawingObjects() {
worksheet.expandRowsOnScroll(true); worksheet.expandRowsOnScroll(true);
} }
var bOnload = false;
if ( obj.isChart() && bUpdateCharts ) { if ( obj.isChart() && bUpdateCharts ) {
if ( !obj.chart.range.intervalObject ) if ( !obj.chart.range.intervalObject )
_this.intervalToIntervalObject(obj.chart); _this.intervalToIntervalObject(obj.chart);
var chartBase64 = chartRender.insertChart(obj.chart, null, obj.getWidthFromTo(), obj.getHeightFromTo()); var chartBase64 = chartRender.insertChart(obj.chart, null, obj.getWidthFromTo(), obj.getHeightFromTo());
if ( !chartBase64 ) if ( !chartBase64 )
continue; continue;
imageLoader.addImage(chartBase64);
imageLoader.setReadyCallback(_this.showDrawingObjects);
obj.image.onload = function() { obj.image.onload = function() {
obj.flags.loaded = true; obj.flags.currentCursor = null;
obj.flags.currentCursor = null;
_this.showDrawingObjects(true, printOptions, true, false);
} }
obj.image.src = chartBase64; obj.image.src = chartBase64;
obj.flags.loaded = false; continue;
bOnload = true;
} }
if ( !obj.canDraw() ) if ( !obj.canDraw() )
continue; continue;
if ( !bOnload ) {
obj.image.onload = function() {
// Пересчёт нужен при смене src(ресайз диаграммы)
var sWidth = obj.image.width - obj.getInnerOffsetLeft();
var sHeight = obj.image.height - obj.getInnerOffsetTop();
// Проверка для IE
var dWidth = obj.getVisibleWidth();
var dHeight = obj.getVisibleHeight();
if ((dWidth <= 0) || (dHeight <= 0))
return;
drawingCtx.drawImage(obj.image,
// обрезаем
pxToPt(obj.getInnerOffsetLeft()), pxToPt(obj.getInnerOffsetTop()),
pxToPt(sWidth), pxToPt(sHeight),
// вставляем
pxToPt(obj.getVisibleLeftOffset(true)), pxToPt(obj.getVisibleTopOffset(true)),
pxToPt(dWidth), pxToPt(dHeight));
if (obj.flags.selected && !printOptions)
_this.selectDrawingObject(index);
obj.flags.loaded = true;
}
}
var sWidth = obj.image.width - obj.getInnerOffsetLeft(); var sWidth = obj.image.width - obj.getInnerOffsetLeft();
var sHeight = obj.image.height - obj.getInnerOffsetTop(); var sHeight = obj.image.height - obj.getInnerOffsetTop();
if (printOptions) { if ( printOptions ) {
if (obj.isChart()) { if ( obj.isChart() ) {
srcForPrint = obj.image.src; // base64 srcForPrint = obj.image.src; // base64
} }
else { else {
...@@ -1689,31 +1728,27 @@ function DrawingObjects() { ...@@ -1689,31 +1728,27 @@ function DrawingObjects() {
pxToPt(obj.image.width), pxToPt(obj.image.height)); pxToPt(obj.image.width), pxToPt(obj.image.height));
} }
else { else {
if (!obj.image.width || !obj.image.height) if ( !obj.image.width || !obj.image.height )
//return;
continue; continue;
if (!obj.move.inAction || bMouseUp) { // Проверка для IE
var dWidth = obj.getVisibleWidth();
// Проверка для IE var dHeight = obj.getVisibleHeight();
var dWidth = obj.getVisibleWidth(); if ( (dWidth <= 0) || (dHeight <= 0) )
var dHeight = obj.getVisibleHeight(); continue;
if ( (dWidth <= 0) || (dHeight <= 0) )
continue; drawingCtx.drawImage(obj.image,
// обрезаем
drawingCtx.drawImage(obj.image, pxToPt(obj.getInnerOffsetLeft()), pxToPt(obj.getInnerOffsetTop()),
// обрезаем pxToPt(sWidth), pxToPt(sHeight),
pxToPt(obj.getInnerOffsetLeft()), pxToPt(obj.getInnerOffsetTop()), // вставляем
pxToPt(sWidth), pxToPt(sHeight), pxToPt(obj.getVisibleLeftOffset(true)), pxToPt(obj.getVisibleTopOffset(true)),
// вставляем pxToPt(dWidth), pxToPt(dHeight));
pxToPt(obj.getVisibleLeftOffset(true)), pxToPt(obj.getVisibleTopOffset(true)),
pxToPt(dWidth), pxToPt(dHeight));
}
} }
if (obj.flags.selected && !printOptions) if ( obj.flags.selected && !printOptions )
_this.selectDrawingObject(index); _this.selectDrawingObject(index);
if (obj.flags.lockState != c_oAscObjectLockState.No) if ( obj.flags.lockState != c_oAscObjectLockState.No )
_this.selectLockedDrawingObject(obj.id, obj.flags.lockState); _this.selectLockedDrawingObject(obj.id, obj.flags.lockState);
obj.move.inAction = false; obj.move.inAction = false;
...@@ -1849,7 +1884,6 @@ function DrawingObjects() { ...@@ -1849,7 +1884,6 @@ function DrawingObjects() {
_t.chart = new asc_CChart(); _t.chart = new asc_CChart();
_t.flags = { _t.flags = {
loaded: false,
selected: false, selected: false,
anchorUpdated: false, anchorUpdated: false,
lockState: c_oAscObjectLockState.No, lockState: c_oAscObjectLockState.No,
...@@ -2323,7 +2357,9 @@ function DrawingObjects() { ...@@ -2323,7 +2357,9 @@ function DrawingObjects() {
_this.addImageDrawingObject = function(imageUrl, bPackage, options) { _this.addImageDrawingObject = function(imageUrl, bPackage, options) {
if (imageUrl && !isViewerMode()) { if (imageUrl && !isViewerMode()) {
imageLoader.addImage(imageUrl);
var obj = _this.createDrawingObject(); var obj = _this.createDrawingObject();
obj.id = generateId(); obj.id = generateId();
...@@ -2407,8 +2443,7 @@ function DrawingObjects() { ...@@ -2407,8 +2443,7 @@ function DrawingObjects() {
else { else {
// Теперь знаем реальную высоту и ширину // Теперь знаем реальную высоту и ширину
obj.image.onload = function() { obj.image.onload = function() {
obj.flags.loaded = true;
calculateObjectMetrics(obj, obj.image.width, obj.image.height); calculateObjectMetrics(obj, obj.image.width, obj.image.height);
aObjects.push(obj); aObjects.push(obj);
...@@ -2536,7 +2571,9 @@ function DrawingObjects() { ...@@ -2536,7 +2571,9 @@ function DrawingObjects() {
chart.worksheet = worksheet; // Для формул серий chart.worksheet = worksheet; // Для формул серий
var chartBase64 = chartRender.insertChart(chart, null, bWordChart ? wordChart.width : c_oAscChartDefines.defaultChartWidth, bWordChart ? wordChart.height : c_oAscChartDefines.defaultChartHeight, isNewChart); var chartBase64 = chartRender.insertChart(chart, null, bWordChart ? wordChart.width : c_oAscChartDefines.defaultChartWidth, bWordChart ? wordChart.height : c_oAscChartDefines.defaultChartHeight, isNewChart);
if ( !chartBase64 ) if ( !chartBase64 )
return false; return false;
imageLoader.addImage(chartBase64);
// draw // draw
var obj = _this.createDrawingObject(); var obj = _this.createDrawingObject();
...@@ -2554,8 +2591,6 @@ function DrawingObjects() { ...@@ -2554,8 +2591,6 @@ function DrawingObjects() {
var realLeftOffset = obj.getRealLeftOffset(); var realLeftOffset = obj.getRealLeftOffset();
obj.image.onload = function() { obj.image.onload = function() {
obj.flags.loaded = true;
var objWidth = options && options.width ? options.width : obj.image.width; var objWidth = options && options.width ? options.width : obj.image.width;
var objHeight = options && options.height ? options.height : obj.image.height; var objHeight = options && options.height ? options.height : obj.image.height;
...@@ -2590,7 +2625,7 @@ function DrawingObjects() { ...@@ -2590,7 +2625,7 @@ function DrawingObjects() {
} }
if(options) if(options)
_this.showDrawingObjects(true, null/*printOptions*/, false/*bMouseUp*/, true/*bUpdateCharts*/); _this.showDrawingObjects(true, null/*printOptions*/, true/*bUpdateCharts*/);
else else
_this.showDrawingObjects(true); _this.showDrawingObjects(true);
...@@ -2662,7 +2697,7 @@ function DrawingObjects() { ...@@ -2662,7 +2697,7 @@ function DrawingObjects() {
_this.selectDrawingObject(index); _this.selectDrawingObject(index);
_this.selectDrawingObjectRange(index); _this.selectDrawingObjectRange(index);
_this.showDrawingObjects(false, null/*printOptions*/, false/*bMouseUp*/, true/*bUpdateCharts*/); _this.showDrawingObjects(false, null/*printOptions*/, true/*bUpdateCharts*/);
} }
} }
...@@ -2672,14 +2707,6 @@ function DrawingObjects() { ...@@ -2672,14 +2707,6 @@ function DrawingObjects() {
} }
} }
_this.reloadChartDrawingObjects = function(chart) {
for (var i = 0; i < _this.countDrawingObjects(); i++) {
var obj = aObjects[i];
if (obj.isChart())
obj.flags.loaded = false;
}
}
_this.deleteSelectedDrawingObject = function() { _this.deleteSelectedDrawingObject = function() {
var bResult = false; var bResult = false;
...@@ -4108,12 +4135,12 @@ function DrawingObjects() { ...@@ -4108,12 +4135,12 @@ function DrawingObjects() {
} }
// выход за границу слева // выход за границу слева
if (realLeftOffset <= worksheet.getCellLeft(0, 0)) if ( realLeftOffset <= worksheet.getCellLeft(0, 0) )
realLeftOffset = worksheet.getCellLeft(0, 0); realLeftOffset = worksheet.getCellLeft(0, 0);
// выход за границу справа // выход за границу справа
var foundCol = worksheet._findColUnderCursor(pxToPt(realLeftOffset + widthFromTo), true); var foundCol = worksheet._findColUnderCursor(pxToPt(realLeftOffset + widthFromTo), true);
while (foundCol == null) { while ( foundCol == null ) {
worksheet.expandColsOnScroll(true); worksheet.expandColsOnScroll(true);
worksheet._trigger("reinitializeScrollX"); worksheet._trigger("reinitializeScrollX");
foundCol = worksheet._findColUnderCursor(pxToPt(realLeftOffset + widthFromTo), true); foundCol = worksheet._findColUnderCursor(pxToPt(realLeftOffset + widthFromTo), true);
...@@ -4129,7 +4156,7 @@ function DrawingObjects() { ...@@ -4129,7 +4156,7 @@ function DrawingObjects() {
if ( heightFromTo < 0 ) if ( heightFromTo < 0 )
heightFromTo = 0; heightFromTo = 0;
var foundRow = worksheet._findRowUnderCursor(pxToPt(realTopOffset + heightFromTo), true); var foundRow = worksheet._findRowUnderCursor(pxToPt(realTopOffset + heightFromTo), true);
while (foundRow == null) { while ( foundRow == null ) {
worksheet.expandRowsOnScroll(true); worksheet.expandRowsOnScroll(true);
worksheet._trigger("reinitializeScrollY"); worksheet._trigger("reinitializeScrollY");
foundRow = worksheet._findRowUnderCursor(pxToPt(realTopOffset + heightFromTo), true); foundRow = worksheet._findRowUnderCursor(pxToPt(realTopOffset + heightFromTo), true);
...@@ -4243,4 +4270,53 @@ function DrawingObjects() { ...@@ -4243,4 +4270,53 @@ function DrawingObjects() {
var tmp = val * ascCvtRatio(0, 3); var tmp = val * ascCvtRatio(0, 3);
return tmp; return tmp;
} }
}
//-----------------------------------------------------------------------------------
// Image loader
//-----------------------------------------------------------------------------------
function ImageLoader() {
var _this = this;
var readyCallback = null;
var ImageObject = function() {
var _t = this;
_t.bReady = false;
_t.image = new Image();
_t.image.onload = function() {
_t.bReady = true;
if ( _this.isReady() && readyCallback )
readyCallback(false, null, false);
}
};
var container = []; // array of ImageObject
_this.isReady = function() {
for (var i = 0; i < container.length; i++) {
if ( !container[i].bReady )
return false;
}
container = []; // remove cache
return true;
}
_this.addImage = function(imageSrc) {
if ( imageSrc ) {
var imageObject = new ImageObject();
imageObject.image.src = imageSrc;
container.push(imageObject);
}
}
_this.setReadyCallback = function(callback) {
if ( callback && (typeof(callback) == "function") )
readyCallback = callback;
}
_this.removeReadyCallback = function(callback) {
readyCallback = null;
}
} }
\ No newline at end of file
...@@ -1382,7 +1382,7 @@ var ASC_DOCS_API_USE_EMBEDDED_FONTS = "@@ASC_DOCS_API_USE_EMBEDDED_FONTS"; ...@@ -1382,7 +1382,7 @@ var ASC_DOCS_API_USE_EMBEDDED_FONTS = "@@ASC_DOCS_API_USE_EMBEDDED_FONTS";
_onShowDrawingObjects: function () { _onShowDrawingObjects: function () {
if (this.wb) { if (this.wb) {
this.wb.getWorksheet().objectRender.showDrawingObjects(true, /*printOptions*/null, /*bMouseUp*/false, /*bUpdateCharts*/false); this.wb.getWorksheet().objectRender.showDrawingObjects(true, /*printOptions*/null, /*bUpdateCharts*/false);
} }
}, },
......
...@@ -1866,7 +1866,7 @@ ...@@ -1866,7 +1866,7 @@
bottom: printPagesData.bottomFieldInPt bottom: printPagesData.bottomFieldInPt
} }
}; };
this.objectRender.showDrawingObjects(false, drawingPrintOptions, false, true); this.objectRender.showDrawingObjects(false, drawingPrintOptions, false);
this.visibleRange = tmpVisibleRange.clone(true); this.visibleRange = tmpVisibleRange.clone(true);
if (isAppBridge) {window['appBridge']['dummyCommandUpdate'] ();} if (isAppBridge) {window['appBridge']['dummyCommandUpdate'] ();}
...@@ -1894,7 +1894,7 @@ ...@@ -1894,7 +1894,7 @@
} }
//draw auto filters //draw auto filters
this.autoFilters.drawAutoF(this); this.autoFilters.drawAutoF(this);
this.objectRender.showDrawingObjects(true, null/*printOptions*/, false/*bMouseUp*/, true/*bUpdateCharts*/); this.objectRender.showDrawingObjects(true, null/*printOptions*/, true/*bUpdateCharts*/);
this.cellCommentator.drawCommentCells(false); this.cellCommentator.drawCommentCells(false);
return this; return this;
...@@ -3456,7 +3456,7 @@ ...@@ -3456,7 +3456,7 @@
t.overlayCtx.ctx.globalAlpha = 1; t.overlayCtx.ctx.globalAlpha = 1;
if (res) { if (res) {
// Все хорошо, мы залочили, теперь применяем // Все хорошо, мы залочили, теперь применяем
t.objectRender.showDrawingObjects(true, null, true, true); t.objectRender.showDrawingObjects(true, null, true);
} }
else { else {
// Не удалось, восстанавливаем состояние // Не удалось, восстанавливаем состояние
...@@ -8017,7 +8017,7 @@ ...@@ -8017,7 +8017,7 @@
if (isUpdateCols) { t._updateVisibleColsCount(); } if (isUpdateCols) { t._updateVisibleColsCount(); }
if (isUpdateRows) { t._updateVisibleRowsCount(); } if (isUpdateRows) { t._updateVisibleRowsCount(); }
t.objectRender.showDrawingObjects(true, null, false, true); t.objectRender.showDrawingObjects(true, null, true);
}; };
switch (prop) { switch (prop) {
...@@ -8304,7 +8304,7 @@ ...@@ -8304,7 +8304,7 @@
if (isUpdateRows) { t._updateVisibleRowsCount(); } if (isUpdateRows) { t._updateVisibleRowsCount(); }
if (false === lockDraw) { if (false === lockDraw) {
t.objectRender.showDrawingObjects(true, null, false, true); t.objectRender.showDrawingObjects(true, null, true);
t.autoFilters.drawAutoF(t); t.autoFilters.drawAutoF(t);
} }
}, },
...@@ -9034,7 +9034,6 @@ ...@@ -9034,7 +9034,6 @@
t._trigger("selectionChanged", t.getSelectionInfo()); t._trigger("selectionChanged", t.getSelectionInfo());
} }
t.objectRender.reloadChartDrawingObjects();
t.cellCommentator.updateCommentPosition(); t.cellCommentator.updateCommentPosition();
t.draw(lockDraw); t.draw(lockDraw);
}, },
......
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