118using namespace std::string_literals;
177 static const struct {
178 const char *
name{
nullptr};
179 bool with_derived{
false};
180 bool reduse_by_many{
false};
181 } supported_classes[] = {{
"TH1",
true},
188 {
"TGraphPolargram",
true},
193 {
"TBox",
false,
true},
195 {
"TLine",
false,
true},
196 {
"TEllipse",
true,
true},
203 {
"TPolyLine",
true,
true},
220 for (
int i = 0; supported_classes[i].name !=
nullptr; ++i)
221 if ((!many_primitives || !supported_classes[i].reduse_by_many) && (strcmp(supported_classes[i].
name, obj->
ClassName()) == 0))
225 for (
int i = 0; supported_classes[i].name !=
nullptr; ++i)
226 if (supported_classes[i].with_derived && (!many_primitives || !supported_classes[i].reduse_by_many))
261 if (
name[0] ==
'+') {
284 TView *view =
nullptr;
317 painter->SetPainting(
nullptr);
376 auto *tgt = listofcols->Reserve(pal.
GetSize());
379 listofcols->FixSize();
395 bool process_primitives = (version == 0) || (pad_status.fVersion > version);
427 TIter iter(primitives);
431 bool need_frame =
false, has_histo =
false, need_palette =
false;
432 std::string need_title;
434 while (process_primitives && ((obj = iter()) !=
nullptr)) {
440 auto hs =
static_cast<THStack *
>(obj);
456 frame =
static_cast<TFrame *
>(obj);
467 if (!has_histo && (strlen(obj->
GetTitle()) > 0))
471 if (!has_histo && (strlen(obj->
GetTitle()) > 0))
474 need_frame = need_palette =
true;
479 if (!has_histo && (strlen(obj->
GetTitle()) > 0))
482 if (strcmp(obj->
GetName(),
"title") == 0)
498 auto line0 = title->
GetLine(0);
501 title =
new TPaveText(0, 0, 0, 0,
"blNDC");
510 title->
AddText(need_title.c_str());
512 primitives->
Add(title);
516 auto flush_master = [&]() {
523 auto check_save_tf1 = [&](
TObject *fobj,
bool ignore_nodraw =
false) {
529 auto f1 =
static_cast<TF1 *
>(fobj);
537 bool first_obj =
true;
539 if (process_primitives)
540 pad_status._has_specials =
false;
542 while ((obj = iter()) !=
nullptr) {
546 }
else if (!process_primitives) {
557 hist->TAttLine::Copy(*
h1);
558 hist->TAttFill::Copy(*
h1);
559 hist->TAttMarker::Copy(*
h1);
564 while (
auto fobj = fiter())
568 if (title && first_obj) hopt.
Append(
";;use_pad_title");
575 TH1 *hist =
static_cast<TH1 *
>(obj);
583 while ((fobj = fiter()) !=
nullptr) {
589 check_save_tf1(fobj);
628 std::stringstream exec;
629 exec <<
"new TPaletteAxis(0,0,0,0, (TH1*)" << std::hex << std::showbase << (size_t)hist <<
");";
630 palette = (
TObject *)
gROOT->ProcessLine(exec.str().c_str());
635 if (title && first_obj) hopt.
Append(
";;use_pad_title");
639 if (palette) hopt.
Append(
";;use_pad_palette");
645 auto p1 = opt.
Index(
"["), p2 = opt.
Index(
"]");
646 if ((p1 !=
kNPOS) && (p2 !=
kNPOS) && p2 > p1 + 1) {
647 TString cutname = opt(p1 + 1, p2 - p1 - 1);
675 while (
auto fobj = fiter()) {
679 check_save_tf1(fobj);
689 if (title && first_obj) gropt.
Append(
";;use_pad_title");
690 if (stats) gropt.
Append(
";;use_pad_stats");
695 while (
auto fobj = fiter())
713 TString hopt = !real_draw ? iter.
GetOption() : (zscale ?
"lego2z" :
"lego2");
714 if (title) hopt.
Append(
";;use_pad_title");
717 auto hist = gr2d->
GetHistogram(real_draw ?
"empty" :
"");
731 while (
auto fobj = fiter()) {
733 check_save_tf1(fobj);
739 while (
auto fobj = fiter())
753 TObject *fobj =
nullptr, *palette =
nullptr;
755 while ((fobj = fiter()) !=
nullptr) {
765 std::stringstream exec;
766 exec <<
"new TPaletteAxis(0,0,0,0,0,0);";
767 palette = (
TObject *)
gROOT->ProcessLine(exec.str().c_str());
769 funcs->AddFirst(palette);
773 if (title && first_obj) scopt.
Append(
";;use_pad_title");
774 if (palette) scopt.
Append(
";;use_pad_palette");
779 while ((fobj = fiter()) !=
nullptr)
788 auto f1 =
static_cast<TF1 *
> (obj);
792 check_save_tf1(obj,
true);
799 f1opt.
Append(
";webcanv_hist");
808 auto gaxis =
static_cast<TGaxis *
> (obj);
816 if (frame && (obj == frame)) {
830 bool provide_colors =
false;
834 provide_colors = process_primitives;
860 TList *dlst =
nullptr;
861 while ((dlst = (
TList *)diter()) !=
nullptr) {
863 while ((obj = fiter()) !=
nullptr)
866 dlst->
Clear(
"nodelete");
876 TIter siter(&save_lst);
878 while ((dlst = (
TList *)diter()) !=
nullptr) {
879 while ((obj = siter()) !=
nullptr) {
886 save_lst.
Clear(
"nodelete");
902 if (conn.match(connid)) {
903 conn.fCtrl[key] =
value;
920 if (conn.match(connid))
921 conn.fSend.emplace(msg);
935 bool isMoreData =
false, isAnySend =
false;
939 bool isConnData = !conn.fCtrl.empty() || !conn.fSend.empty() ||
940 ((conn.fCheckedVersion <
fCanvVersion) && (conn.fSendVersion == conn.fDrawVersion));
942 while ((conn.is_batch() && !connid) || (conn.match(connid) &&
fWindow &&
fWindow->CanSend(conn.fConnId,
true))) {
947 if (!conn.fCtrl.empty()) {
950 }
else if (!conn.fSend.empty()) {
951 std::swap(buf, conn.fSend.front());
953 }
else if ((conn.fCheckedVersion <
fCanvVersion) && (conn.fSendVersion == conn.fDrawVersion)) {
962 if (!conn.fSendVersion)
968 if (conn.is_batch()) {
975 auto hash =
json.Hash();
976 if (conn.fLastSendHash && (conn.fLastSendHash == hash) && conn.fSendVersion) {
980 buf.append(
json.Data());
981 conn.fLastSendHash = hash;
996 if (!buf.empty() && !conn.is_batch()) {
997 fWindow->Send(conn.fConnId, buf);
1006 if (fTimer->IsSlow() && isMoreData)
1030 fWindow->SetDefaultPage(
"file:rootui5sys/canv/canvas6.html");
1034 [
this](
unsigned connid) {
1039 [
this](
unsigned connid,
const std::string &arg) {
1044 [
this](
unsigned connid) {
1047 if (
c.fConnId == connid) {
1057 if ((
w > 0) && (
w < 50000) && (
h > 0) && (
h < 30000))
1073 if (
gROOT->IsWebDisplayBatch())
1097 if (!pad || !obj)
return;
1101 AddCtrlMsg(0,
"edit"s, std::to_string(hash));
1170 if ((cw > 0) && (ch > 0)) {
1216 auto arr = TBufferJSON::FromJSON<std::vector<TWebPadOptions>>(msg);
1223 TPad *pad_with_execs =
nullptr;
1224 TExec *hist_exec =
nullptr;
1226 for (
unsigned n = 0;
n < arr->size(); ++
n) {
1227 auto &
r = arr->at(
n);
1237 if (
r.w.size() == 4) {
1246 if (
r.active && (pad !=
gPad))
gPad = pad;
1293 if (mother->GetAbsWNDC() > 0. && mother->GetAbsHNDC() > 0.) {
1294 pad->
fXlowNDC = (
r.xlow - mother->GetAbsXlowNDC()) / mother->GetAbsWNDC();
1295 pad->
fYlowNDC = (
r.ylow - mother->GetAbsYlowNDC()) / mother->GetAbsHNDC();
1296 pad->
fXUpNDC = (
r.xup - mother->GetAbsXlowNDC()) / mother->GetAbsWNDC();
1297 pad->
fYUpNDC = (
r.yup - mother->GetAbsYlowNDC()) / mother->GetAbsHNDC();
1298 pad->
fWNDC = (
r.xup -
r.xlow) / mother->GetAbsWNDC();
1299 pad->
fHNDC = (
r.yup -
r.ylow) / mother->GetAbsHNDC();
1314 if ((xrange != 0.) && (pxrange != 0)) {
1317 pad->
fXtoPixelk = rounding + -pxrange*
r.px1/xrange;
1324 if ((yrange != 0.) && (pyrange != 0.)) {
1327 pad->
fYtoPixelk = rounding + -pyrange - pyrange*
r.py1/yrange;
1343 if (hist_holder == hist)
1344 hist_holder =
nullptr;
1358 if ((
hmin ==
hmax) && !no_entries) {
1363 }
else if (
r.zy1 ==
r.zy2) {
1372 if ((
hmin ==
hmax) && !no_entries) {
1378 if (
r.zz1 ==
r.zz2) {
1397 ::Error(
"SetMember",
"Cannot find %s data member in %s",
name, hist_holder->
ClassName());
1401 SetMember(
"fMinimum",
hmin);
1402 SetMember(
"fMaximum",
hmax);
1406 while (
auto fobj = next())
1408 hist_exec = (
TExec *) fobj;
1409 need_update =
kTRUE;
1413 std::map<std::string, int> idmap;
1415 for (
auto &item :
r.primitives) {
1416 auto iter = idmap.find(item.snapid);
1418 if (iter == idmap.end())
1419 idmap[item.snapid] = 1;
1421 idcnt = ++iter->second;
1429 need_update =
kTRUE;
1432 if (process_execs && (
gPad == pad))
1433 pad_with_execs = pad;
1450 if ((!execs || !execs->GetSize()) && !extra)
1462 while (
auto obj = next()) {
1463 auto exec =
dynamic_cast<TExec *
>(obj);
1480 std::string buf = lines;
1484 while (obj && !buf.empty()) {
1485 std::string sub = buf;
1486 auto pos = buf.find(
";;");
1487 if (pos == std::string::npos) {
1491 sub = buf.substr(0,pos);
1492 buf = buf.substr(pos+2);
1494 if (sub.empty())
continue;
1496 std::stringstream exec;
1497 exec <<
"((" << obj->
ClassName() <<
" *) " << std::hex << std::showbase << (size_t)obj <<
")->" << sub <<
";";
1498 if (indx < 3 || gDebug > 0)
1499 Info(
"ProcessLinesForObject",
"Obj %s Execute %s", obj->
GetName(), exec.str().c_str());
1500 gROOT->ProcessLine(exec.str().c_str());
1517 if (
fWebConn[indx].fConnId == connid)
1523 Bool_t is_main_connection = indx == 1;
1527 FlagGuard(
Bool_t &_flag) : flag(_flag) { flag =
true; }
1528 ~FlagGuard() { flag =
false; }
1533 const char *cdata = arg.c_str();
1535 if (arg ==
"KEEPALIVE") {
1538 }
else if (arg ==
"QUIT") {
1543 }
else if (arg.compare(0, 7,
"READY6:") == 0) {
1550 const char *separ = strchr(cdata,
':');
1552 fWebConn[indx].fDrawVersion = std::stoll(cdata);
1554 fWebConn[indx].fDrawVersion = std::stoll(std::string(cdata, separ - cdata));
1560 }
else if (arg ==
"RELOAD") {
1565 }
else if (arg.compare(0, 5,
"SAVE:") == 0) {
1568 const char *img = cdata + 5;
1570 const char *separ = strchr(img,
':');
1575 std::ofstream ofs(
filename.Data());
1586 Info(
"ProcessData",
"File %s has been created",
filename.Data());
1589 }
else if (arg.compare(0, 8,
"PRODUCE:") == 0) {
1594 }
else if (arg.compare(0, 9,
"OPTIONS6:") == 0) {
1600 }
else if (arg.compare(0, 11,
"STATUSBITS:") == 0) {
1602 if (is_main_connection) {
1606 }
else if (arg.compare(0, 10,
"HIGHLIGHT:") == 0) {
1607 if (is_main_connection) {
1608 auto arr = TBufferJSON::FromJSON<std::vector<std::string>>(arg.substr(10));
1609 if (!arr || (arr->size() != 4)) {
1610 Error(
"ProcessData",
"Wrong arguments count %d in highlight message", (
int)(arr ? arr->size() : -1));
1614 int argx = std::stoi(arr->at(2));
1615 int argy = std::stoi(arr->at(3));
1626 }
else if (arg ==
"FITPANEL"s) {
1628 TH1 *hist =
nullptr;
1630 while (
auto obj = iter()) {
1631 hist =
dynamic_cast<TH1 *
>(obj);
1635 TString cmd =
TString::Format(
"auto panel = std::make_shared<ROOT::Experimental::RFitPanel>(\"FitPanel\");"
1636 "panel->AssignCanvas(\"%s\");"
1637 "panel->AssignHistogram((TH1 *)0x%zx);"
1639 "panel->ClearOnClose(panel);",
Canvas()->GetName(), (
size_t) hist);
1643 }
else if (arg ==
"START_BROWSER"s) {
1645 gROOT->ProcessLine(
"new TBrowser;");
1652 }
else if (arg.compare(0, 6,
"EVENT:") == 0) {
1653 auto arr = TBufferJSON::FromJSON<std::vector<std::string>>(arg.substr(6));
1654 if (!arr || (arr->size() != 5)) {
1655 Error(
"ProcessData",
"Wrong arguments count %d in event message", (
int)(arr ? arr->size() : -1));
1658 std::string kind = arr->at(1);
1661 int argx = std::stoi(arr->at(2));
1662 int argy = std::stoi(arr->at(3));
1665 if ((
event >= 0) && pad && (pad ==
gPad)) {
1676 }
else if (arg.compare(0, 8,
"GETMENU:") == 0) {
1684 std::string buf =
"MENU:";
1689 }
else if (arg.compare(0, 8,
"PRIMIT6:") == 0) {
1693 auto opt = TBufferJSON::FromJSON<TWebObjectOptions>(arg.c_str() + 8);
1704 }
else if (arg.compare(0, 11,
"PADCLICKED:") == 0) {
1706 auto click = TBufferJSON::FromJSON<TWebPadClick>(arg.c_str() + 11);
1714 const char *mthd = btn->GetMethod();
1715 if (mthd && *mthd) {
1717 gROOT->ProcessLine(mthd);
1722 if (pad && (pad !=
gPad)) {
1729 if (!click->objid.empty()) {
1737 if ((click->x >= 0) && (click->y >= 0)) {
1750 }
else if (arg.compare(0, 8,
"OBJEXEC:") == 0) {
1752 auto buf = arg.substr(8);
1753 auto pos = buf.find(
":");
1756 auto sid = buf.substr(0, pos);
1757 buf.erase(0, pos + 1);
1760 TPad *objpad =
nullptr;
1764 if (obj && !buf.empty()) {
1777 }
else if (arg.compare(0, 12,
"EXECANDSEND:") == 0) {
1781 std::string buf = arg.substr(12);
1785 auto pos = buf.find(
":");
1789 reply = buf.substr(0, pos);
1790 buf.erase(0, pos + 1);
1791 pos = buf.find(
":");
1793 auto sid = buf.substr(0, pos);
1794 buf.erase(0, pos + 1);
1799 if (obj && !buf.empty() && !reply.empty()) {
1800 std::stringstream exec;
1801 exec <<
"((" << obj->
ClassName() <<
" *) " << std::hex << std::showbase << (size_t)obj
1802 <<
")->" << buf <<
";";
1804 Info(
"ProcessData",
"Obj %s Exec %s", obj->
GetName(), exec.str().c_str());
1806 auto res =
gROOT->ProcessLine(exec.str().c_str());
1809 std::string send = reply;
1813 if (reply[0] ==
'D')
1818 }
else if (arg.compare(0, 6,
"CLEAR:") == 0) {
1819 std::string snapid = arg.substr(6);
1828 Error(
"ProcessData",
"Not found pad with id %s to clear\n", snapid.c_str());
1830 }
else if (arg.compare(0, 7,
"DIVIDE:") == 0) {
1831 auto arr = TBufferJSON::FromJSON<std::vector<std::string>>(arg.substr(7));
1832 if (arr && arr->size() == 2) {
1834 int nn = 0, n1 = 0, n2 = 0;
1836 std::string divide = arr->at(1);
1837 auto p = divide.find(
'x');
1838 if (
p == std::string::npos)
1839 p = divide.find(
'X');
1841 if (
p != std::string::npos) {
1842 n1 = std::stoi(divide.substr(0,
p));
1843 n2 = std::stoi(divide.substr(
p+1));
1845 nn = std::stoi(divide);
1848 if (pad && ((nn > 1) || (n1*n2 > 1))) {
1860 }
else if (arg.compare(0, 8,
"DRAWOPT:") == 0) {
1861 auto arr = TBufferJSON::FromJSON<std::vector<std::string>>(arg.substr(8));
1862 if (arr && arr->size() == 2) {
1868 }
else if (arg.compare(0, 8,
"RESIZED:") == 0) {
1869 auto arr = TBufferJSON::FromJSON<std::vector<int>>(arg.substr(8));
1870 if (arr && arr->size() == 7) {
1882 }
else if (arg.compare(0, 7,
"POPOBJ:") == 0) {
1883 auto arr = TBufferJSON::FromJSON<std::vector<std::string>>(arg.substr(7));
1884 if (arr && arr->size() == 2) {
1889 while (
auto o = next())
1899 }
else if (arg ==
"INTERRUPT"s) {
1900 gROOT->SetInterrupt();
1922 entry._modified =
true;
1926 while (
auto obj = iter()) {
1941 entry.second._detected =
false;
1942 entry.second._modified = force_modified;
1949 bool is_any_modified =
false;
1951 if (iter->second._modified)
1952 is_any_modified =
true;
1953 if (!iter->second._detected)
1960 if (is_any_modified) {
1963 if (entry.second._modified)
1967 return is_any_modified;
2042 Info(
"WaitWhenCanvasPainted",
"version %ld", (
long)ver);
2044 while (cnt++ < cnt_limit) {
2046 if (!
fWindow->HasConnection(0,
false)) {
2048 Info(
"WaitWhenCanvasPainted",
"no connections - abort");
2054 Info(
"WaitWhenCanvasPainted",
"ver %ld got painted", (
long)ver);
2064 Info(
"WaitWhenCanvasPainted",
"timeout");
2087 imp->CreatePadSnapshot(holder, pad, 0, [&res, json_compression](
TPadWebSnapshot *snap) {
2107 auto imp = std::make_unique<TWebCanvas>(
c,
c->GetName(), 0, 0,
c->GetWw(),
c->GetWh(),
kTRUE);
2111 imp->CreatePadSnapshot(holder,
c, 0, [&res, json_compression](
TPadWebSnapshot *snap) {
2137 auto imp = std::make_unique<TWebCanvas>(
c,
c->GetName(), 0, 0,
c->GetWw(),
c->GetWh(),
kTRUE);
2187 std::vector<std::string> jsons;
2188 std::vector<Int_t> widths, heights;
2191 bool is_multipdf_ok =
true;
2193 for (
unsigned n = 0;
n < pads.size(); ++
n) {
2203 if ((pad->GetCanvas() == pad) || (pad->IsA() ==
TCanvas::Class())) {
2207 w = (
Int_t) (pad->GetAbsWNDC() * pad->GetCanvas()->GetWw());
2208 h = (
Int_t) (pad->GetAbsHNDC() * pad->GetCanvas()->GetWh());
2215 is_multipdf_ok =
false;
2217 jsons.emplace_back(
json.Data());
2218 widths.emplace_back(
w);
2219 heights.emplace_back(
h);
2224 return is_multipdf_ok;
2237 TPad *objpad =
nullptr;
2240 if (item.
fcust.compare(
"exec") == 0) {
2241 auto pos = item.
opt.find(
"(");
2242 if (obj && (pos != std::string::npos) && obj->
IsA()->
GetMethodAllAny(item.
opt.substr(0,pos).c_str())) {
2243 std::stringstream exec;
2244 exec <<
"((" << obj->
ClassName() <<
" *) " << std::hex << std::showbase
2245 << (size_t)obj <<
")->" << item.
opt <<
";";
2246 Info(
"ProcessObjectOptions",
"Obj %s Execute %s", obj->
GetName(), exec.str().c_str());
2247 gROOT->ProcessLine(exec.str().c_str());
2249 Error(
"ProcessObjectOptions",
"Fail to execute %s for object %p %s", item.
opt.c_str(), obj, obj ? obj->
ClassName() :
"---");
2255 bool modified =
false;
2258 auto pos = item.
opt.find(
";;use_");
2259 if (pos != std::string::npos) item.
opt.resize(pos);
2262 Info(
"ProcessObjectOptions",
"Set draw option %s for object %s %s", item.
opt.c_str(),
2270 if (item.
fcust.compare(0,10,
"auto_exec:") == 0) {
2272 }
else if (item.
fcust.compare(
"frame") == 0) {
2275 if (item.
fopt.size() >= 4) {
2283 }
else if (item.
fcust.compare(0,4,
"pave") == 0) {
2286 if ((item.
fopt.size() >= 4) && objpad) {
2302 auto stats =
static_cast<TPaveStats *
>(pave);
2304 size_t pos_start = 6, pos_end;
2305 while ((pos_end = item.
fcust.find(
";;", pos_start)) != std::string::npos) {
2306 stats->AddText(item.
fcust.substr(pos_start, pos_end - pos_start).c_str());
2307 pos_start = pos_end + 2;
2309 stats->AddText(item.
fcust.substr(pos_start).c_str());
2312 }
else if (item.
fcust.compare(0,9,
"func_fail") == 0) {
2317 Error(
"ProcessObjectOptions",
"Client fails to calculate function %s cl %s but it should not try!", obj ? obj->
GetName() :
"---", obj ? obj->
ClassName() :
"---");
2321 return modified ? objpad :
nullptr;
2332 if (sid.empty() || (sid ==
"0"s))
2339 auto separ = sid.find(
"#");
2340 long unsigned id = 0;
2341 bool search_hist =
false;
2343 if (sid ==
"histogram") {
2345 }
else if (separ == std::string::npos) {
2346 id = std::stoul(sid);
2348 kind = sid.substr(separ + 1);
2349 id = std::stoul(sid.substr(0, separ));
2355 auto getHistogram = [](
TObject *obj) ->
TH1* {
2356 auto offset = obj->IsA()->GetDataMemberOffset(
"fHistogram");
2358 return *((
TH1 **)((
char*) obj +
offset));
2359 ::Error(
"getHistogram",
"Cannot access fHistogram data member in %s", obj->ClassName());
2364 TObject *obj = lnk->GetObject();
2367 TString opt = lnk->GetOption();
2385 return getHistogram(
gr);
2387 return getHistogram(gr2d);
2389 return getHistogram(scatter);
2391 return getHistogram(mg);
2393 return getHistogram(hs);
2395 return getHistogram(
f1);
2403 if ((
TString::Hash(&obj,
sizeof(obj)) ==
id) && (--idcnt <= 0)) {
2407 if (kind.compare(0, 4,
"hist") == 0) {
2409 obj =
h1 = getHistogram(
gr);
2411 obj =
h1 = getHistogram(mg);
2413 obj =
h1 = getHistogram(hs);
2415 obj =
h1 = getHistogram(scatter);
2417 obj =
h1 = getHistogram(
f1);
2419 obj =
h1 = getHistogram(gr2d);
2422 if (!kind.empty() && (kind[0]==
'#')) kind.erase(0,1);
2426 if (
h1 && (kind ==
"x"))
2428 if (
h1 && (kind ==
"y"))
2430 if (
h1 && (kind ==
"z"))
2433 if ((
h1 ||
gr || scatter) && !kind.empty() && (kind.compare(0,5,
"func_") == 0)) {
2434 auto funcname = kind.substr(5);
2436 return col ? col->
FindObject(funcname.c_str()) :
nullptr;
2439 if ((
h1 ||
gr) && !kind.empty() && (kind.compare(0,5,
"indx_") == 0)) {
2441 return col ? col->
At(std::stoi(kind.substr(5))) :
nullptr;
2444 if (!kind.empty() && (kind.compare(0,7,
"member_") == 0)) {
2445 auto member = kind.substr(7);
2459 if (
h1 ||
gr || mg || scatter) {
2467 else if (scatter && scatter->
GetGraph())
2470 while (
auto fobj = fiter())
2478 if (objpad && !*objpad)
void Info(const char *location, const char *msgfmt,...)
Use this function for informational messages.
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t hmin
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char filename
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t hmax
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h offset
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void funcs
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t src
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t height
R__EXTERN TStyle * gStyle
R__EXTERN TSystem * gSystem
R__EXTERN TVirtualPS * gVirtualPS
Holds different arguments for starting browser with RWebDisplayHandle::Display() method.
EBrowserKind GetBrowserKind() const
returns configured browser kind, see EBrowserKind for supported values
RWebDisplayArgs & SetWidgetKind(const std::string &kind)
set widget kind
RWebDisplayArgs & SetSize(int w, int h)
set preferable web window width and height
RWebDisplayArgs & SetPos(int x=-1, int y=-1)
set preferable web window x and y position, negative is default
@ kCEF
Chromium Embedded Framework - local display with CEF libs.
@ kQt5
Qt5 QWebEngine libraries - Chromium code packed in qt5.
@ kQt6
Qt6 QWebEngine libraries - Chromium code packed in qt6.
static bool ProduceImages(const std::string &fname, const std::vector< std::string > &jsons, const std::vector< int > &widths, const std::vector< int > &heights, const char *batch_file=nullptr)
Produce image file(s) using JSON data as source Invokes JSROOT drawing functionality in headless brow...
static bool ProduceImage(const std::string &fname, const std::string &json, int width=800, int height=600, const char *batch_file=nullptr)
Produce image file using JSON data as source Invokes JSROOT drawing functionality in headless browser...
static std::shared_ptr< RWebWindow > Create()
Create new RWebWindow Using default RWebWindowsManager.
static bool EmbedFileDialog(const std::shared_ptr< RWebWindow > &window, unsigned connid, const std::string &args)
Create dialog instance to use as embedded dialog inside provided widget Loads libROOTBrowserv7 and tr...
static bool IsFileDialogMessage(const std::string &msg)
Check if this could be the message send by client to start new file dialog If returns true,...
Array of integers (32 bits per element).
const Int_t * GetArray() const
virtual void SetFillColor(Color_t fcolor)
Set the fill area color.
virtual void SetFillStyle(Style_t fstyle)
Set the fill area style.
virtual void SetBottomMargin(Float_t bottommargin)
Set Pad bottom margin in fraction of the pad height.
virtual void SetLeftMargin(Float_t leftmargin)
Set Pad left margin in fraction of the pad width.
virtual void SetRightMargin(Float_t rightmargin)
Set Pad right margin in fraction of the pad width.
Float_t GetRightMargin() const
virtual void SetTopMargin(Float_t topmargin)
Set Pad top margin in fraction of the pad height.
virtual void SetTextAlign(Short_t align=11)
Set the text alignment.
virtual void SetTextColor(Color_t tcolor=1)
Set the text color.
virtual void SetTextFont(Font_t tfont=62)
Set the text font.
virtual void SetTextSize(Float_t tsize=1)
Set the text size.
virtual void SetRangeUser(Double_t ufirst, Double_t ulast)
Set the viewing range for the axis from ufirst to ulast (in user coordinates, that is,...
virtual void SetRange(Int_t first=0, Int_t last=0)
Set the viewing range for the axis using bin numbers.
static TString Decode(const char *data)
Decode a base64 string date into a generic TString.
virtual void SetY2(Double_t y2)
virtual void SetX1(Double_t x1)
virtual void SetX2(Double_t x2)
virtual void SetY1(Double_t y1)
static Int_t ExportToFile(const char *filename, const TObject *obj, const char *option=nullptr)
Convert object into JSON and store in text file Returns size of the produce file Used in TObject::Sav...
static TString ToJSON(const T *obj, Int_t compact=0, const char *member_name=nullptr)
@ kNoSpaces
no new lines plus remove all spaces around "," and ":" symbols
@ kMapAsObject
store std::map, std::unordered_map as JSON object
@ kSameSuppression
zero suppression plus compress many similar values together
ABC describing GUI independent main window (with menubar, scrollbars and a drawing area).
void SetScripts(const std::string &src)
void SetFixedSize(bool on=true)
void SetHighlightConnect(bool on=true)
UInt_t fCw
Width of the canvas along X (pixels)
UInt_t GetWindowHeight() const
void SetClickSelectedPad(TPad *pad)
Int_t fWindowTopX
Top X position of window (in pixels)
Int_t fEventX
! Last X mouse position in canvas
TVirtualPadPainter * GetCanvasPainter()
Access and (probably) creation of pad painter.
UInt_t fWindowWidth
Width of window (including borders, etc.)
Int_t fEventY
! Last Y mouse position in canvas
UInt_t fWindowHeight
Height of window (including menubar, borders, etc.)
TObject * fSelected
! Currently selected object
UInt_t fCh
Height of the canvas along Y (pixels)
UInt_t GetWindowWidth() const
Int_t fWindowTopY
Top Y position of window (in pixels)
void SetClickSelected(TObject *obj)
UInt_t GetWw() const override
UInt_t GetWh() const override
virtual void Highlighted(TVirtualPad *pad, TObject *obj, Int_t x, Int_t y)
Emit Highlighted() signal.
Int_t fEvent
! Type of current or last handled event
TClass instances represent classes, structs and namespaces in the ROOT type system.
Longptr_t GetDataMemberOffset(const char *membername) const
return offset for member name.
Int_t Size() const
Return size of object of this class.
Bool_t InheritsFrom(const char *cl) const override
Return kTRUE if this class inherits from a class with name "classname".
TMethod * GetMethodAllAny(const char *method)
Return pointer to method without looking at parameters.
Collection abstract base class.
TObject * FindObject(const char *name) const override
Find an object in this collection using its name.
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
The color creation and management class.
static const TArrayI & GetPalette()
Static function returning the current active palette.
static Bool_t DefinedColors()
Static function returning kTRUE if some new colors have been defined after initialisation or since th...
virtual Int_t GetValue(const char *name, Int_t dflt) const
Returns the integer value for a resource.
TExec is a utility class that can be used to execute a C++ command when some event happens in a pad.
virtual void Exec(const char *command="")
Execute the command referenced by this object.
virtual TH1 * GetHistogram() const
Return a pointer to the histogram used to visualise the function Note that this histogram is managed ...
virtual void GetRange(Double_t *xmin, Double_t *xmax) const
Return range of a generic N-D function.
virtual void Save(Double_t xmin, Double_t xmax, Double_t ymin, Double_t ymax, Double_t zmin, Double_t zmax)
Save values of function in array fSave.
TF1 * GetFunction() const
Graphics object made of three arrays X, Y and Z with the same number of points each.
TH2D * GetHistogram(Option_t *option="")
By default returns a pointer to the Delaunay histogram.
A TGraph is an object made of two arrays X and Y with npoints each.
TList * GetListOfFunctions() const
virtual TH1F * GetHistogram() const
Returns a pointer to the histogram used to draw the axis Takes into account the two following cases.
1-D histogram with a double per channel (see TH1 documentation)}
TH1K class supports the nearest K Neighbours method, widely used in cluster analysis.
Double_t GetBinContent(Int_t bin) const override
Return content of global bin number bin.
TH1 is the base class of all histogram classes in ROOT.
virtual void SetDirectory(TDirectory *dir)
By default, when a histogram is created, it is added to the list of histogram objects in the current ...
virtual Int_t GetDimension() const
@ kNoTitle
Don't draw the histogram title.
virtual void SetMaximum(Double_t maximum=-1111)
virtual void SetMinimum(Double_t minimum=-1111)
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
virtual Double_t GetEntries() const
Return the current number of entries.
TList * GetListOfFunctions() const
void SetName(const char *name) override
Change the name of this histogram.
virtual Int_t BufferEmpty(Int_t action=0)
Fill histogram with all entries in the buffer.
The Histogram stack class.
Option_t * GetOption() const
void Clear(Option_t *option="") override
Remove all objects from the list.
TObject * FindObject(const char *name) const override
Find an object in this list using its name.
void Add(TObject *obj) override
TObject * Remove(TObject *obj) override
Remove object from the list.
void AddLast(TObject *obj) override
Add object at the end of the list.
TObject * Last() const override
Return the last object in the list. Returns 0 when list is empty.
virtual TObjLink * FirstLink() const
TObject * At(Int_t idx) const override
Returns the object at position idx. Returns 0 if idx is out of range.
void AddFirst(TObject *obj) override
Add object at the beginning of the list.
A TMultiGraph is a collection of TGraph (or derived) objects.
TList * GetListOfFunctions()
Return pointer to list of functions.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
const char * GetName() const override
Returns name of object.
const char * GetTitle() const override
Returns title of object.
Wrapper around a TObject so it can be stored in a TList.
virtual void SetOption(Option_t *)
TObject * GetObject() const
Mother of all ROOT objects.
virtual const char * GetName() const
Returns name of object.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual TObject * Clone(const char *newname="") const
Make a clone of an object using the Streamer facility.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
virtual TObject * FindObject(const char *name) const
Must be redefined in derived classes.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual const char * GetTitle() const
Returns title of object.
virtual TClass * IsA() const
virtual void Paint(Option_t *option="")
This method must be overridden if a class wants to paint itself.
TPadWebSnapshot & NewSubPad()
Create new entry for subpad.
TWebSnapshot & NewPrimitive(TObject *obj=nullptr, const std::string &opt="", const std::string &suffix="")
Create new entry in list of primitives.
TWebSnapshot & NewSpecials()
Create new entry in list of primitives in the front.
void SetHasExecs(bool on=true)
void SetWithoutPrimitives(bool on=true)
void SetActive(bool on=true)
bool IsSetObjectIds() const
The most important graphics class in the ROOT system.
Int_t GetTicky() const override
Double_t fAbsYlowNDC
Absolute Y top left corner of pad in NDC [0,1].
Double_t fXtoAbsPixelk
Conversion coefficient for X World to absolute pixel.
virtual void DivideSquare(Int_t n, Float_t xmargin=0.01, Float_t ymargin=0.01, Int_t color=0)
"n" is the total number of sub-pads.
Double_t fWNDC
Width of pad along X in Normalized Coordinates (NDC)
void SetView(TView *view=nullptr) override
Set the current TView. Delete previous view if view=0.
TVirtualViewer3D * GetViewer3D(Option_t *type="") override
Create/obtain handle to 3D viewer.
Double_t fPixeltoYk
Conversion coefficient for pixel to Y World.
void SetGrid(Int_t valuex=1, Int_t valuey=1) override
Double_t fPixeltoY
yworld = fPixeltoYk + fPixeltoY*ypixel
Double_t fAbsXlowNDC
Absolute X top left corner of pad in NDC [0,1].
TList * GetListOfExecs() const override
void Divide(Int_t nx=1, Int_t ny=1, Float_t xmargin=0.01, Float_t ymargin=0.01, Int_t color=0) override
Automatic pad generation by division.
Double_t fXtoPixel
xpixel = fXtoPixelk + fXtoPixel*xworld
Bool_t GetGridx() const override
Double_t fX2
X of upper X coordinate.
Double_t fPixeltoX
xworld = fPixeltoXk + fPixeltoX*xpixel
Double_t fYtoPixel
ypixel = fYtoPixelk + fYtoPixel*yworld
Double_t fAbsWNDC
Absolute Width of pad along X in NDC.
UInt_t GetWw() const override
Get Ww.
Double_t fX1
X of lower X coordinate.
TList * GetListOfPrimitives() const override
Double_t fUymin
Minimum value on the Y axis.
Int_t fLogz
(=0 if Z linear scale, =1 if log scale)
Double_t fYtoPixelk
Conversion coefficient for Y World to pixel.
Double_t fPixeltoXk
Conversion coefficient for pixel to X World.
Bool_t IsModified() const override
Double_t fY1
Y of lower Y coordinate.
Double_t fYlowNDC
Y bottom left corner of pad in NDC [0,1].
Double_t fAbsPixeltoXk
Conversion coefficient for absolute pixel to X World.
void Clear(Option_t *option="") override
Delete all pad primitives.
Int_t GetTickx() const override
Double_t fUymax
Maximum value on the Y axis.
void Modified(Bool_t flag=1) override
TVirtualPad * GetMother() const override
TView * GetView() const override
TClass * IsA() const override
Bool_t GetGridy() const override
Double_t fAbsHNDC
Absolute Height of pad along Y in NDC.
void SetFixedAspectRatio(Bool_t fixed=kTRUE) override
Fix pad aspect ratio to current value if fixed is true.
Int_t fLogx
(=0 if X linear scale, =1 if log scale)
Double_t GetAbsWNDC() const override
UInt_t GetWh() const override
Get Wh.
TCanvas * GetCanvas() const override
TVirtualPad * cd(Int_t subpadnumber=0) override
Set Current pad.
void Print(const char *filename="") const override
This method is equivalent to SaveAs("filename"). See TPad::SaveAs for details.
TFrame * GetFrame() override
Get frame.
Double_t fYtoAbsPixelk
Conversion coefficient for Y World to absolute pixel.
Double_t fXtoPixelk
Conversion coefficient for X World to pixel.
Int_t fLogy
(=0 if Y linear scale, =1 if log scale)
Double_t fHNDC
Height of pad along Y in Normalized Coordinates (NDC)
Double_t fXlowNDC
X bottom left corner of pad in NDC [0,1].
Double_t fUxmin
Minimum value on the X axis.
Double_t GetAbsHNDC() const override
void SetTicks(Int_t valuex=1, Int_t valuey=1) override
Double_t fUxmax
Maximum value on the X axis.
Double_t fY2
Y of upper Y coordinate.
Double_t fAbsPixeltoYk
Conversion coefficient for absolute pixel to Y World.
const char * GetName() const override
Returns name of object.
The histogram statistics painter class.
virtual void SetStatFormat(const char *format="6.4g")
Change (i.e. set) the format for printing statistics.
virtual void SetFitFormat(const char *format="5.4g")
Change (i.e. set) the format for printing fit parameters in statistics box.
void SetParent(TObject *obj) override
A Pave (see TPave) with text, lines or/and boxes inside.
virtual TText * AddText(Double_t x1, Double_t y1, const char *label)
Add a new Text line to this pavetext at given coordinates.
void Clear(Option_t *option="") override
Clear all lines in this pavetext.
virtual TText * GetLine(Int_t number) const
Get Pointer to line number in this pavetext.
A TBox with a bordersize and a shadow option.
virtual void SetY1NDC(Double_t y1)
virtual void ConvertNDCtoPad()
Convert pave coordinates from NDC to Pad coordinates.
virtual void SetName(const char *name="")
virtual void SetBorderSize(Int_t bordersize=4)
virtual void SetY2NDC(Double_t y2)
virtual void SetX1NDC(Double_t x1)
virtual void SetX2NDC(Double_t x2)
A TScatter is able to draw four variables scatter plot on a single plot.
TGraph * GetGraph() const
Get the graph holding X and Y positions.
TH2F * GetHistogram() const
Get the graph histogram used for drawing axis.
const char * Data() const
void ToUpper()
Change string to upper case.
UInt_t Hash(ECaseCompare cmp=kExact) const
Return hash value.
TString & Append(const char *cs)
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
Color_t GetStatTextColor() const
Int_t GetOptTitle() const
Float_t GetStatFontSize() const
Float_t GetPadRightMargin() const
Style_t GetTitleFont(Option_t *axis="X") const
Return title font.
Color_t GetTitleFillColor() const
Style_t GetTitleStyle() const
Color_t GetStatColor() const
Width_t GetTitleBorderSize() const
Width_t GetStatBorderSize() const
Color_t GetTitleTextColor() const
Style_t GetStatStyle() const
const char * GetFitFormat() const
const char * GetStatFormat() const
Style_t GetStatFont() const
Float_t GetTitleFontSize() const
virtual void Sleep(UInt_t milliSec)
Sleep milliSec milli seconds.
virtual Bool_t ProcessEvents()
Process pending events (GUI, timers, sockets).
Handles synchronous and a-synchronous timer events.
virtual void TurnOn()
Add the timer to the system timer list.
void SetTime(Long_t milliSec)
static TView * CreateView(Int_t system=1, const Double_t *rmin=nullptr, const Double_t *rmax=nullptr)
Create a concrete default 3-d view via the plug-in manager.
virtual void SetAutoRange(Bool_t autorange=kTRUE)=0
TVirtualPS is an abstract interface to Postscript, PDF, SVG.
To make it possible to use GL for 2D graphic in a TPad/TCanvas.
small helper class to store/restore gPad context in TPad methods
TVirtualPad is an abstract base class for the Pad and Canvas classes.
Semi-Abstract base class defining a generic interface to the underlying, low level,...
void SetSlow(Bool_t slow=kTRUE)
TWebCanvasTimer(TWebCanvas &canv)
void Timeout() override
used to send control messages to clients
Basic TCanvasImp ABI implementation for Web-based Graphics Provides painting of main ROOT classes in ...
TVirtualPadPainter * CreatePadPainter() override
Creates web-based pad painter.
void ForceUpdate() override
Increment canvas version and force sending data to client - do not wait for reply.
void AddCustomClass(const std::string &clname, bool with_derived=false)
Assign custom class.
static TString CreatePadJSON(TPad *pad, Int_t json_compression=0, Bool_t batchmode=kFALSE)
Create JSON painting output for given pad Produce JSON can be used for offline drawing with JSROOT.
Bool_t fTF1UseSave
! use save buffer for TF1/TF2, need when evaluation failed on client side
void SetCanvasSize(UInt_t w, UInt_t h) override
Set canvas size of web canvas.
UInt_t fColorsHash
! last hash of colors/palette
void ShowCmd(const std::string &arg, Bool_t show)
Function used to send command to browser to toggle menu, toolbar, editors, ...
Long64_t fColorsVersion
! current colors/palette version, checked every time when new snapshot created
std::string fCustomScripts
! custom JavaScript code or URL on JavaScript files to load before start drawing
virtual Bool_t IsReadOnly() const
std::shared_ptr< ROOT::RWebWindow > fWindow
virtual Bool_t IsJSSupportedClass(TObject *obj, Bool_t many_primitives=kFALSE)
Returns kTRUE when object is fully supported on JSROOT side In ROOT7 Paint function will just return ...
void AddCtrlMsg(unsigned connid, const std::string &key, const std::string &value)
Add control message for specified connection Same control message can be overwritten many time before...
void SetCustomScripts(const std::string &src)
Configures custom script for canvas.
ObjectSelectSignal_t fObjSelectSignal
! signal emitted when new object selected in the pad
PadClickedSignal_t fPadClickedSignal
! signal emitted when simple mouse click performed on the pad
void SetLongerPolling(Bool_t on)
UInt_t fStyleHash
! last hash of gStyle
virtual Bool_t CanCreateObject(const std::string &)
void ShowWebWindow(const ROOT::RWebDisplayArgs &user_args="")
Show canvas in specified place.
Int_t fPrimitivesMerge
! number of PS primitives, which will be merged together
void Show() override
Show canvas in browser window.
Bool_t WaitWhenCanvasPainted(Long64_t ver)
Wait when specified version of canvas was painted and confirmed by browser.
std::vector< std::string > fCustomClasses
! list of custom classes, which can be delivered as is to client
Bool_t IsAsyncMode() const
UInt_t CalculateColorsHash()
Calculate hash function for all colors and palette.
Bool_t HasStatusBar() const override
Returns kTRUE if web canvas has status bar.
void Close() override
Close web canvas - not implemented.
static bool ProduceImages(std::vector< TPad * > pads, const char *filename, Int_t width=0, Int_t height=0)
Create images for several pads using batch (headless) capability of Chrome or Firefox browsers Suppor...
Bool_t HasMenuBar() const override
Returns kTRUE if web canvas has menu bar.
Int_t InitWindow() override
Initialize window for the web canvas At this place canvas is not yet register to the list of canvases...
void CheckPadModified(TPad *pad)
Returns true if any pad in the canvas were modified Reset modified flags, increment canvas version (i...
void RaiseWindow() override
Raise browser window.
static bool ProduceImage(TPad *pad, const char *filename, Int_t width=0, Int_t height=0)
Create image using batch (headless) capability of Chrome or Firefox browsers Supported png,...
void ActivateInEditor(TPad *pad, TObject *obj)
Activate object in editor in web browser.
std::vector< WebConn > fWebConn
! connections
PadSignal_t fActivePadChangedSignal
! signal emitted when active pad changed in the canvas
Bool_t GetLongerPolling() const
UInt_t fClientBits
! latest status bits from client like editor visible or not
std::function< void(TPadWebSnapshot *)> PadPaintingReady_t
Function called when pad painting produced.
Int_t fPaletteDelivery
! colors palette delivery 0:never, 1:once, 2:always, 3:per subpad
Bool_t fProcessingData
! flag used to prevent blocking methods when process data is invoked
Bool_t HasToolTips() const override
Returns kTRUE if tooltips are activated in web canvas.
friend class TWebCanvasTimer
TWebCanvasTimer * fTimer
! timer to submit control messages
Long64_t fCanvVersion
! actual canvas version, changed with every new Modified() call
bool IsCustomClass(const TClass *cl) const
Checks if class belongs to custom.
std::vector< int > fWindowGeometry
! last received window geometry
TPad * ProcessObjectOptions(TWebObjectOptions &item, TPad *pad, int idcnt=1)
Process data for single primitive Returns object pad if object was modified.
void CreateObjectSnapshot(TPadWebSnapshot &master, TPad *pad, TObject *obj, const char *opt, TWebPS *masterps=nullptr)
Creates representation of the object for painting in web browser.
void AddColorsPalette(TPadWebSnapshot &master)
Add special canvas objects like colors list at selected palette.
Long64_t fStyleVersion
! current gStyle object version, checked every time when new snapshot created
void AddSendQueue(unsigned connid, const std::string &msg)
Add message to send queue for specified connection If connid == 0, message will be add to all connect...
void SetWindowPosition(Int_t x, Int_t y) override
Set window position of web canvas.
UpdatedSignal_t fUpdatedSignal
! signal emitted when canvas updated or state is changed
Int_t fJsonComp
! compression factor for messages send to the client
Bool_t IsFirstConn(unsigned connid) const
~TWebCanvas() override
Destructor.
Bool_t fReadOnly
!< configured display
std::map< TPad *, PadStatus > fPadsStatus
! map of pads in canvas and their status flags
Bool_t CheckDataToSend(unsigned connid=0)
Check if any data should be send to client If connid != 0, only selected connection will be checked.
Bool_t PerformUpdate(Bool_t async) override
if canvas or any subpad was modified, scan all primitives in the TCanvas and subpads and convert them...
void AssignStatusBits(UInt_t bits)
Assign clients bits.
virtual Bool_t ProcessData(unsigned connid, const std::string &arg)
Handle data from web browser Returns kFALSE if message was not processed.
void ProcessLinesForObject(TObject *obj, const std::string &lines)
Execute one or several methods for selected object String can be separated by ";;" to let execute sev...
TWebCanvas(TCanvas *c, const char *name, Int_t x, Int_t y, UInt_t width, UInt_t height, Bool_t readonly=kTRUE)
Constructor.
static Int_t StoreCanvasJSON(TCanvas *c, const char *filename, const char *option="")
Create JSON painting output for given canvas and store into the file See TBufferJSON::ExportToFile() ...
void Iconify() override
Iconify browser window.
void SetWindowTitle(const char *newTitle) override
Set window title of web canvas.
UInt_t GetWindowGeometry(Int_t &x, Int_t &y, UInt_t &w, UInt_t &h) override
Returns window geometry including borders and menus.
static TCanvasImp * NewCanvas(TCanvas *c, const char *name, Int_t x, Int_t y, UInt_t width, UInt_t height)
Static method to create TWebCanvas instance Used by plugin manager.
static TString CreateCanvasJSON(TCanvas *c, Int_t json_compression=0, Bool_t batchmode=kFALSE)
Create JSON painting output for given canvas Produce JSON can be used for offline drawing with JSROOT...
Bool_t HasEditor() const override
Returns kTRUE if web canvas has graphical editor.
Int_t fStyleDelivery
! gStyle delivery to clients: 0:never, 1:once, 2:always
PadClickedSignal_t fPadDblClickedSignal
! signal emitted when simple mouse click performed on the pad
void ProcessExecs(TPad *pad, TExec *extra=nullptr)
Process TExec objects in the pad.
TList fPrimitivesLists
! list of lists of primitives, temporary collected during painting
void CreatePadSnapshot(TPadWebSnapshot &paddata, TPad *pad, Long64_t version, PadPaintingReady_t func)
Create snapshot for pad and all primitives Callback function is used to create JSON in the middle of ...
Bool_t CheckCanvasModified(bool force_modified=false)
Check if any pad on the canvas was modified If yes, increment version of correspondent pad Returns tr...
virtual Bool_t DecodePadOptions(const std::string &, bool process_execs=false)
Decode all pad options, which includes ranges plus objects options.
Int_t GetPaletteDelivery() const
void SetWindowSize(UInt_t w, UInt_t h) override
Set window size of web canvas.
TObject * FindPrimitive(const std::string &id, int idcnt=1, TPad *pad=nullptr, TObjLink **objlnk=nullptr, TPad **objpad=nullptr)
Search of object with given id in list of primitives One could specify pad where search could be star...
Bool_t fFixedSize
! is canvas size fixed
Int_t GetStyleDelivery() const
Class used to transport drawing options from the client.
std::vector< double > fopt
custom float array
std::string fcust
custom string
std::string snapid
id of the object
std::string opt
drawing options
Bool_t IsEmptyPainting() const
TWebPainting * TakePainting()
TWebPainting * GetPainting()
Implement TVirtualPadPainter which abstracts painting operations.
Object used to store paint operations and deliver them to JSROOT.
void AddColor(Int_t indx, TColor *col)
Add custom color to operations.
@ kSVG
list of SVG primitives
@ kColors
list of ROOT colors + palette
void SetSnapshot(Int_t kind, TObject *snapshot, Bool_t owner=kFALSE)
SetUse pointer to assign object id - TString::Hash.
void SetObjectIDAsPtr(void *ptr, const std::string &suffix="")
Use pointer to assign object id - TString::Hash.
LongDouble_t Power(LongDouble_t x, LongDouble_t y)
Returns x raised to the power y.
bool _detected
! if pad was detected during last scan