/*************************************************************************** graph.cpp ------------------- begin : Sat Sep 29 2001 copyright : (C) 2001 - 2003 by Roland Riegel email : feedback@roland-riegel.de ***************************************************************************/ /*************************************************************************** * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * ***************************************************************************/ #include "graph.h" #include "window.h" #include "options.h" Graph::Graph() { m_heightofbars = 0; m_trafficwithmaxdeflectionofbars = 0; } Graph::~Graph() { } //sets the number of the graph's vertical #-bars void Graph::setNumOfBars( int new_numofbars ) { //logically wrong: number of #-bars has always to be positive if( new_numofbars <= 0 ) return; //vertically resize the graph's value list m_values.resize( new_numofbars ); } //sets the height of the graph's vertical #-bars void Graph::setHeightOfBars( int new_heightofbars ) { m_heightofbars = new_heightofbars; } //set the traffic at which the graph shows 100% deflection void Graph::setTrafficWithMaxDeflectionOfBars( OptionLong* new_trafficwithmaxdeflectionofbars ) { //[new_trafficwithmaxdeflectionofbars] = kBit/s m_trafficwithmaxdeflectionofbars = new_trafficwithmaxdeflectionofbars; } //new traffic measurement has been made => update the graph's value list void Graph::update(int new_value) { //[new_value] = Bytes/s if( m_values.size() == 0 ) return; //put new value to the beginning of the list, it becomes the first #-bar m_values.push_front( new_value ); //delete the last #-bar of the list m_values.pop_back(); } //print the graph with the upper left corner at the coordinates (x, y) void Graph::print( Window& window, int x, int y ) { window.setXY( x, y ); //cycle through through the lines for( int l = 0; l < m_heightofbars; l++ ) { //for each line cycle through the rows for( list::reverse_iterator r = m_values.rbegin(); r != m_values.rend() ; r++ ) { int trafficperline = trafficWithMaxDeflectionOfBars() / m_heightofbars; int restoftraffic = ( (*r) - ( m_heightofbars - l - 1 ) * trafficperline ) % trafficperline; if( (float) (*r) / trafficWithMaxDeflectionOfBars() >= (float) ( m_heightofbars - l ) / m_heightofbars ) window.print( '#' ); else if( restoftraffic >= 0.7 * trafficperline ) window.print( '|' ); else if( restoftraffic >= 0.3 * trafficperline ) window.print( '.' ); else window.print( ' ' ); } window.print( '\n' ); window.setX( x ); } } //reset all traffic values in the graph to zero void Graph::resetTrafficData() { int size = m_values.size(); m_values.clear(); m_values.resize( size ); } long Graph::trafficWithMaxDeflectionOfBars() { int tr = m_trafficwithmaxdeflectionofbars ? (long) *m_trafficwithmaxdeflectionofbars : STANDARD_MAX_DEFLECTION; return tr * 1024 / 8; //recalculate from kBit/s to Bytes/s }