Commit 5e0b122b authored by Igor.Zotov's avatar Igor.Zotov Committed by Alexander.Trofimov

изменения в округлении чисел высших порядков

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@49532 954022d7-b5bf-4e40-9824-e11837661b57
parent 3945d8ea
...@@ -439,7 +439,12 @@ ...@@ -439,7 +439,12 @@
//приводим к первому порядку для дальнейших вычислений //приводим к первому порядку для дальнейших вычислений
var secPart = max.toString().split('.'); var secPart = max.toString().split('.');
var numPow = 1; var numPow = 1;
if(0 != secPart[0]) if(secPart[1] && secPart[1].toString().search('e+') != -1 && secPart[0] && secPart[0].toString().length == 1)
{
var expNum = secPart[1].toString().split('e+');
numPow = Math.pow(10, expNum[1]);
}
else if(0 != secPart[0])
numPow = Math.pow(10, secPart[0].toString().length - 1) numPow = Math.pow(10, secPart[0].toString().length - 1)
max = max/numPow; max = max/numPow;
if(0 == max.toString().split('.')[0]) if(0 == max.toString().split('.')[0])
...@@ -497,6 +502,12 @@ ...@@ -497,6 +502,12 @@
num--; num--;
} }
} }
else if(greaterNull.toString().indexOf("e+") > -1)
{
var splitString = greaterNull.toString().split("e+");
if(splitString[1])
greaterNullNum = Math.pow(10, parseFloat(splitString[1]));
}
greaterNull = greaterNull/greaterNullNum; greaterNull = greaterNull/greaterNullNum;
//if(axisXMin == 0) //if(axisXMin == 0)
...@@ -1042,6 +1053,7 @@ ...@@ -1042,6 +1053,7 @@
} }
stepOY = OfficeExcel.num_round(stepOY);
...@@ -1307,6 +1319,7 @@ ...@@ -1307,6 +1319,7 @@
{ {
var maxDig = 1000000000; var maxDig = 1000000000;
var minDig = 0.000000001; var minDig = 0.000000001;
var floatKoff = 100000000000;
if(typeof(arr) == 'number') if(typeof(arr) == 'number')
{ {
...@@ -1351,6 +1364,7 @@ ...@@ -1351,6 +1364,7 @@
exp += 1; exp += 1;
tmp /= 10; tmp /= 10;
} }
tmp = Math.round(tmp*floatKoff)/floatKoff
if(arr[i] < 0) if(arr[i] < 0)
tmp *= -1; tmp *= -1;
arr[i] = tmp + "E+" + exp; arr[i] = tmp + "E+" + exp;
...@@ -1374,28 +1388,14 @@ ...@@ -1374,28 +1388,14 @@
OfficeExcel.num_round = function (num) OfficeExcel.num_round = function (num)
{ {
/*var partNum = num.toString().split('.'); var floatKoff = 100000000000;
var len; if(num.toString() && num.toString().indexOf('e+') > -1)
if(partNum == undefined || num.toString().split('e-')[1] != undefined)
{
partNum = num.toString().split('e-');
len = partNum[1] + 1;
}
if(partNum[1] != undefined && partNum[1])
{
if(!len)
len = partNum[1].length;
if(len)
{ {
var floatKoff = Math.pow(10, (len - 1)) var parseVal = num.toString().split("e+");
if(floatKoff > 1) var roundVal = Math.round(parseFloat(parseVal[0])*floatKoff)/floatKoff;
num = Math.round(num*floatKoff)/floatKoff ; var changeSymbol = roundVal.toString() + "e+" + parseVal[1];
num = parseFloat(changeSymbol);
} }
}*/
var floatKoff = 100000000000;
num = Math.round(num*floatKoff)/floatKoff ; num = Math.round(num*floatKoff)/floatKoff ;
return num; return num;
} }
......
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