File: Spectrum.cpp

package info (click to toggle)
hamfax 0.5.1-1
  • links: PTS
  • area: main
  • in suites: woody
  • size: 416 kB
  • ctags: 441
  • sloc: cpp: 3,188; sh: 197; makefile: 124
file content (73 lines) | stat: -rw-r--r-- 2,010 bytes parent folder | download
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
// HamFax -- an application for sending and receiving amateur radio facsimiles
// Copyright (C) 2001 Christof Schmitt, DH1CS <cschmitt@users.sourceforge.net>
//  
// 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.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//  
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

#include "Spectrum.hpp"
#include <qpainter.h>
#include <qpixmap.h>
#include <math.h>

Spectrum::Spectrum(QWidget* parent)
	: QFrame(parent)
{
	setFrameStyle(QFrame::Panel|QFrame::Sunken);
	setMargin(2);
	setFixedSize(128+2*margin(),64+2*margin());
	pixmap=new QPixmap(width()-2*margin(),height()-2*margin());
	QPainter paint(pixmap,this);
	paint.eraseRect(0,0,width(),height());
	paint.flush();
}

void Spectrum::init(void)
{
	for(int i=0; i<64; i++) {
		data[i]=0;
	}
}

void Spectrum::paintEvent(QPaintEvent* e)
{
	QFrame::paintEvent(e);
	bitBlt(this,margin(),margin(),pixmap,0,0,
	       width()-2*margin(),height()-2*margin());
}

void Spectrum::samples(int* buffer, int n)
{
	for(int i=0; i<64; i++) {
		data[i]=0;
	}
	for(int i=0; i<n; i++) {
		data[buffer[i]/4]++;
	}
	for(int i=0; i<64; i++) {
		data[i]=data[i]*128.0/n+1;
		data[i]=log(data[i])*32.0;
		if(data[i]>127) {
			data[i]=127;
		}
	}
	QPainter paint(pixmap,this);
	paint.eraseRect(0,0,width(),height());
	paint.setPen(Qt::blue);
	paint.setBrush(Qt::blue);
	for(int i=0; i<64; i++) {
		paint.drawRect(i*2,128-data[i],2,data[i]);
	}
	paint.flush();
	update();
}