-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathmeter.h
63 lines (52 loc) · 1.82 KB
/
meter.h
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
//
// Copyright (c) 1994, 1995, 2006 by Mike Romberg ( [email protected] )
//
// This file may be distributed under terms of the GPL
//
#ifndef _METER_H_
#define _METER_H_
#include "xosview.h"
#include <iostream>
class Meter {
public:
Meter( XOSView *parent, const char *title = "", const char *legend ="",
int docaptions = 0, int dolegends = 0, int dousedlegends = 0 );
virtual ~Meter( void );
virtual const char *name( void ) const { return "Meter"; }
void resize( int x, int y, int width, int height );
virtual void checkevent( void ) = 0;
virtual void draw( void ) = 0;
void title( const char *title );
const char *title( void ) { return title_; }
void legend( const char *legend );
const char *legend( void ) { return legend_; }
void docaptions( int val ) { docaptions_ = val; }
void dolegends( int val ) { dolegends_ = val; }
void dousedlegends( int val ) { dousedlegends_ = val; }
int requestevent( void ){
if (priority_ == 0) {
std::cerr << "Warning: meter " << name() << " had an invalid priority "
<< "of 0. Resetting to 1..." << std::endl;
priority_ = 1;
}
int rval = counter_ % priority_;
counter_ = (counter_ + 1) % priority_;
return !rval;
}
int getX() const { return x_; }
int getY() const { return y_; }
int getWidth() const { return width_; }
int getHeight() const { return height_; }
virtual void checkResources( void );
static double scaleValue( double value, char *scale, bool metric );
protected:
XOSView *parent_;
int x_, y_, width_, height_, docaptions_, dolegends_, dousedlegends_;
int priority_, counter_;
char *title_, *legend_;
unsigned long textcolor_;
double samplesPerSecond() { return 1.0*MAX_SAMPLES_PER_SECOND/priority_; }
double secondsPerSample() { return 1.0/samplesPerSecond(); }
private:
};
#endif