Logo ROOT   6.16/01
Reference Guide
RPadDisplayItem.hxx
Go to the documentation of this file.
1/// \file ROOT/RPadDisplayItem.hxx
2/// \ingroup Base ROOT7
3/// \author Sergey Linev
4/// \date 2017-05-31
5/// \warning This is part of the ROOT 7 prototype! It will change without notice. It might trigger earthquakes. Feedback
6/// is welcome!
7
8/*************************************************************************
9 * Copyright (C) 1995-2017, Rene Brun and Fons Rademakers. *
10 * All rights reserved. *
11 * *
12 * For the licensing terms see $ROOTSYS/LICENSE. *
13 * For the list of contributors see $ROOTSYS/README/CREDITS. *
14 *************************************************************************/
15
16#ifndef ROOT7_RPadDisplayItem
17#define ROOT7_RPadDisplayItem
18
19#include <ROOT/RDisplayItem.hxx>
20#include <ROOT/RFrame.hxx>
21#include <ROOT/RPad.hxx>
22
23namespace ROOT {
24namespace Experimental {
25
26/// Display item for the pad
27/// Includes different graphical properties of the pad itself plus
28/// list of created items for all primitives
29
30class RPadDisplayItem : public RDisplayItem {
31public:
32 // list of snapshot for primitives in pad
33 using PadPrimitives_t = std::vector<std::unique_ptr<RDisplayItem>>;
34
35
36protected:
37 const RFrame *fFrame{nullptr}; ///< temporary pointer on frame object
38 const RPadDrawingOpts *fDrawOpts{nullptr}; ///< temporary pointer on pad drawing options
39 const RPadExtent *fSize{nullptr}; ///< temporary pointer on pad size attributes
40 std::string fTitle; ///< title of the pad (used for canvas)
41 std::array<RPadLength::Pixel, 2> fWinSize; ///< window size (used for canvas)
42 PadPrimitives_t fPrimitives; ///< display items for all primitives in the pad
43public:
44 RPadDisplayItem() = default;
45 virtual ~RPadDisplayItem() {}
46 void SetFrame(const RFrame *f) { fFrame = f; }
47 void SetDrawOpts(const RPadDrawingOpts *opts) { fDrawOpts = opts; }
48 void SetSize(const RPadExtent *sz) { fSize = sz; }
49 void SetTitle(const std::string &title) { fTitle = title; }
50 void SetWindowSize(const std::array<RPadLength::Pixel, 2> &win) { fWinSize = win; }
52 void Add(std::unique_ptr<RDisplayItem> &&item) { fPrimitives.push_back(std::move(item)); }
53 void Clear()
54 {
55 fPrimitives.clear();
56 fFrame = nullptr;
57 fDrawOpts = nullptr;
58 fSize = nullptr;
59 fWinSize[0] = fWinSize[1] = 0;
60 fTitle.clear();
61 }
62};
63
64} // Experimental
65} // ROOT
66
67#endif
#define f(i)
Definition: RSha256.hxx:104
Holds a user coordinate system with a palette.
Definition: RFrame.hxx:35
Display item for the pad Includes different graphical properties of the pad itself plus list of creat...
const RPadExtent * fSize
temporary pointer on pad size attributes
void SetTitle(const std::string &title)
std::array< RPadLength::Pixel, 2 > fWinSize
window size (used for canvas)
void SetWindowSize(const std::array< RPadLength::Pixel, 2 > &win)
void SetSize(const RPadExtent *sz)
const RPadDrawingOpts * fDrawOpts
temporary pointer on pad drawing options
void Add(std::unique_ptr< RDisplayItem > &&item)
PadPrimitives_t fPrimitives
display items for all primitives in the pad
void SetDrawOpts(const RPadDrawingOpts *opts)
std::vector< std::unique_ptr< RDisplayItem > > PadPrimitives_t
const RFrame * fFrame
temporary pointer on frame object
std::string fTitle
title of the pad (used for canvas)
Drawing options for a RPad.
Definition: RPad.hxx:245
Namespace for new ROOT classes and functions.
Definition: StringConv.hxx:21
An extent / size (horizontal and vertical) in a RPad.
Definition: RPadExtent.hxx:47