-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmainpage.dox
106 lines (87 loc) · 3.82 KB
/
mainpage.dox
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*! \mainpage My Personal Index Page
*
* \section intro_sec Introduction
*
* This is a small library I wrote in order to create some "performance" widgets.
* What I mean by that is a series of widgets that can show computer performance, like ram usage , CPU usage etc.
* I tried to build the library in a way which is a bit flexible and modular and adapt to different type of data.
* Beware though this is not a library for data plotting, there are a lot of professional libraries out there to do that.
*
* \section install_sec Compiling
* This library doesn't have any external dependency and is self contained.
* At this point it only work on Linux since it relies on a /proc/stat file and other Linux specific query.
* There will be need to modify the classes to work differently on a OSX or Windows environment.
*
* Here my .pro file if can be useful
*\code
*#-------------------------------------------------
#
# Project created by QtCreator 2014-06-19T10:25:43
#
#-------------------------------------------------
QT += core gui
greaterThan(QT_MAJOR_VERSION,5)
{
QT += widgets
}
TARGET = osWidget
TEMPLATE = app
SOURCES += main.cpp\
mainwindow.cpp \
painters/performancepainter.cpp \
painters/graphpainter.cpp \
painters/painterutils.cpp \
dataQuery/dataquery.cpp \
dataQuery/cpudataquery.cpp \
painters/barspainter.cpp \
painters/graphmulticolorpainter.cpp \
widgets/cpuwidget.cpp \
widgets/performancewidget.cpp \
dataQuery/queryresource.cpp \
widgets/ramwidget.cpp \
dataQuery/ramdataquery.cpp
HEADERS += mainwindow.h \
painterutils.h \
performancewidget.h \
painters/performancepainter.h \
painters/graphpainter.h \
painters/painterutils.h \
dataQuery/dataquery.h \
dataQuery/cpudataquery.h \
painters/barspainter.h \
painters/graphmulticolorpainter.h \
widgets/cpuwidget.h \
widgets/performancewidget.h \
dataQuery/queryresource.h \
widgets/ramwidget.h \
dataQuery/ramdataquery.h
FORMS += mainwindow.ui
OTHER_FILES += \
mainpage.dox
*\endcode
*
* \subsection usage_sec Usage
* As mentioned before in order to give a bit of flexibility to this library a specific coding pattern has been adopted.
A new widgets need to inherit PerformanceWidget class which implements the basic functionality for the widgets like :
\li automatic fetch of the data over time
\li automatic call of paint functions
In order to work the widgets needs two extra components that have to been provided by the user.
The first is the dataFetcher which inherit from the abstract class DataQuery.
The only goal of this class is to query the data and give it back in a format the widgets is able to use.
For example you might want to inherit from this class to create a GpuQuery class.
The next step is to provide a painter class which only goal is to paint the data it s given to it.
You need to inherit from the abstract class PerformancePainter.
This means is possible to swap on the fly different type of painters to draw the data in a different way.
Different painters have been implemented already like the BarsPainter and the GraphPainter.
The result of this process are the two sub-classed CpuWidget and RamWidget.
Included a demo application (main.cpp etc) which looks like this :
@image html demoWidget.png "Demo Widget"
Showing CPU widget at the top and gpu widget at the bottom.
\subsection contacts_sec Contacts.
For any question feel free to write on my github repo :
Or contact me at :
marco(DOT)giordano(DOT)work(AT)gmail(DOT)com
*
* Special thanks to my mentor Francesco Giordana for all the help in developing this tool and
Bryan Cairns (VoidRealms on youtube) for his crazy cool series of tutorial in C++ about Qt.
*/