Сообщение создано: 31. 08. 2020 [16:09]
|
IgorIVS
Игорь Шерстобитов
Создатель темы
Зарегистрирован(а) с: 12.03.2020
Сообщения: 15
|
Так как в разделе "Отслеживание ошибок", согласно правил ошибки в библиотеках не соответствуют правилам, то пишу сюда.
OpenSCADA v1+r2703
Виджет "Корневая страница (СО)" /wlb_Main/wdg_RootPgSo
При большом количестве вложенных страниц, кнопки выбора не переходяят на 2 строку (все кнопки в одну строку, с выходом за границы кадра).
Ошибка в процедуре обработки в части //Processing SO and views
Патч (мои правки выделены комментариями "by IVS":
1 фрагмент
for(var iSO in soLstS) {
if(!(curSO=iSO.toInt())) continue;
soNmSz = soLstS[iSO].nmSz*soSymbSz + soInterSpecX;
if((row1w+soNmSz) < soWdth) row1w += soNmSz, row1++;
// else if((row2w+soNmSz) < soWdth) row2w += soNmSz, row1++; //Original
else if((row2w+soNmSz) < soWdth) row2w += soNmSz, row2++; // 1 modify by IVS
else continue; //Too more and long SO
if(curSO != 1) this.wdgAdd("so"+curSO, soLstS[iSO].nm, this.attr("parent")+"/wdg_so1");
2 фрагмент
soWdthAdd = (soWdth-row1w)/row1;
soOff = soX, i = 0;
for(var iSO in soLstS) {
if(!(curSO=iSO.toInt())) continue;
if(i > (row1+row2)) break;
soW = this["so"+curSO];
soNm = soW.attr("name");
soNmSz = soLstS[iSO].nmSz*soSymbSz + soInterSpecX;
soOffY = soY2;
if(i < row1) soNmSz += soWdthAdd, soOffY = soY;
if(i == row1) soOff = soX; // 2 Add by IVS
soW.attrSet("geomX",soOff)..attrSet("geomY",soOffY).attrSet("geomW",soNmSz-soInterSpecX);
soOff += soNmSz;
i++;
}
|
Сообщение создано: 31. 08. 2020 [21:39]
|
roman
Roman Savochenko
Moderator Contributor Developer
Зарегистрирован(а) с: 12.12.2007
Сообщения: 3750
|
"IgorIVS" wrote:
Так как в разделе "Отслеживание ошибок", согласно правил ошибки в библиотеках не соответствуют правилам, то пишу сюда.
Где про это? Внутренние библиотеки OpenSCADA это часть проекта!
"IgorIVS" wrote:
Виджет "Корневая страница (СО)" /wlb_Main/wdg_RootPgSo
При большом количестве вложенных страниц, кнопки выбора не переходяят на 2 строку (все кнопки в одну строку, с выходом за границы кадра).
Не завершено ибо не нужно было.
"IgorIVS" wrote:
Ошибка в процедуре обработки в части //Processing SO and views
Патч (мои правки выделены комментариями "by IVS":
Не совсем, правильно так:
--- vcaBase.sql (revision 2694)
+++ vcaBase.sql (working copy)
@@ -20073,7 +20073,7 @@
soInterSpecX = logoR ? this.so1.attr("geomX") : (this.logo.attr("en")?this.so1.attr("geomX")-this.logo.attr("geomX")-this.logo.attr("geomW"):2);
soX = logoR ? soInterSpecX : this.so1.attr("geomX");
soWdth = logoR ? ((this.logo.attr("en")?this.logo.attr("geomX"):this.attr("geomW"))-soX) : (this.attr("geomW") - soX);
- soSymbSz = this.so1.attr("font").parse(1," ").toReal()*0.8;
+ soSymbSz = this.so1.attr("font").parse(1," ").toReal()*0.75;
soInterSpecY = this.so1.attr("geomY");
soY = this.so1.attr("geomY");
@@ -20083,8 +20083,8 @@
for(var iSO in soLstS) {
if(!(curSO=iSO.toInt())) continue;
soNmSz = soLstS[iSO].nmSz*soSymbSz + soInterSpecX;
- if((row1w+soNmSz) < soWdth) row1w += soNmSz, row1++;
- else if((row2w+soNmSz) < soWdth) row2w += soNmSz, row1++;
+ if(!row2 && (row1w+soNmSz) < soWdth) row1w += soNmSz, row1++;
+ else if((row2w+soNmSz) < soWdth) row2w += soNmSz, row2++;
else continue; //Too more and long SO
if(curSO != 1) this.wdgAdd("so"+curSO, soLstS[iSO].nm, this.attr("parent")+"/wdg_so1");
@@ -20135,7 +20135,8 @@
soNmSz = soLstS[iSO].nmSz*soSymbSz + soInterSpecX;
soOffY = soY2;
if(i < row1) soNmSz += soWdthAdd, soOffY = soY;
- soW.attrSet("geomX",soOff)..attrSet("geomY",soOffY).attrSet("geomW",soNmSz-soInterSpecX);
+ else if(i == row1) soOff = soX;
+ soW.attrSet("geomX",soOff).attrSet("geomY",soOffY).attrSet("geomW",soNmSz-soInterSpecX);
soOff += soNmSz;
i++;
}
Learn, learn and learn better than work, work and work.
|
Сообщение создано: 01. 09. 2020 [09:26]
|
IgorIVS
Игорь Шерстобитов
Создатель темы
Зарегистрирован(а) с: 12.03.2020
Сообщения: 15
|
Спасибо, учту на будущее, не понял фразу про библиотеки.
|