/*
 * Copyright (c) 1991-1994 Regents of the University of California.
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. All advertising materials mentioning features or use of this software
 *    must display the following acknowledgement:
 *	This product includes software developed by the Computer Systems
 *	Engineering Group at Lawrence Berkeley Laboratory.
 * 4. Neither the name of the University nor of the Laboratory may be used
 *    to endorse or promote products derived from this software without
 *    specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 *
 * @(#) $Header: /work/projects/tove/cvs/src/testing/vat/vu.h,v 1.1 1997/12/08 17:22:55 parnanen Exp $ (LBL)
 */

#ifndef vat_vu_h
#define vat_vu_h

#include "tkwidget.h"

class VUMeter : public TkWidget {
    public:
	VUMeter(const char* path,
		double scale, double lpfgain = .75, int width = 10);
	void set(double);
	virtual int command(int argc, const char*const* argv);
    protected:
	virtual void draw();
	virtual void update();
	virtual void resize();
	virtual double warp(double value) const = 0;

	double value_;		/* current (mean) level */
	double alpha_;		/* low-pass filter time constant */
    private:
	inline void rect(Display* dpy, Drawable win, GC gc,
			 int x0, int y0, int w, int h) const;

	double scale_;

	int barht_;
	int gap_;

	int nlevel_;		/* number of discrete levels (i.e., blocks) */
	int hot_level_;		/* blk number we display in VatVU.hot color */
	int topblk_;		/* index of topmost block displayed */
	int ntop_;
	int peak_;		/* top block for peak indicator */
	int peakcnt_;		/* hysteresis for peak indicator */
	int setpeak_;

	static GC bg_;
	static GC fg_;
	static GC gray_;
	static GC hot_;
};

class DBMeter : public VUMeter {
    public:
	DBMeter(const char* path,
		double scale, double lpfgain = .75, int width = 10);
    protected:
	virtual double warp(double value) const;
};

class LinearMeter : public VUMeter {
    public:
	LinearMeter(const char* path,
		    double scale, double lpfgain = .75, int width = 10);
    protected:
	virtual double warp(double value) const;
};

#endif
