rainmeter-studio/Library/MeterBitmap.h

62 lines
1.8 KiB
C
Raw Normal View History

2009-02-10 18:37:48 +00:00
/*
Copyright (C) 2001 Kimmo Pekkola
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
2009-02-10 18:37:48 +00:00
*/
#ifndef __METERBITMAP_H__
#define __METERBITMAP_H__
#include "Meter.h"
#include "TintedImage.h"
2009-02-10 18:37:48 +00:00
class CMeterBitmap : public CMeter
{
public:
2011-02-15 16:26:54 +00:00
CMeterBitmap(CMeterWindow* meterWindow, const WCHAR* name);
2009-02-10 18:37:48 +00:00
virtual ~CMeterBitmap();
2012-04-09 19:45:54 +03:00
virtual UINT GetTypeID() { return TypeID<CMeterBitmap>(); }
2009-02-10 18:37:48 +00:00
virtual bool HitTest(int x, int y);
virtual void Initialize();
virtual bool Update();
virtual bool Draw(Gdiplus::Graphics& graphics);
virtual bool HasActiveTransition();
2009-02-10 18:37:48 +00:00
protected:
virtual void ReadConfig(CConfigParser& parser, const WCHAR* section);
2009-02-10 18:37:48 +00:00
private:
CTintedImage m_Image;
2012-05-20 20:57:12 +03:00
std::wstring m_ImageName;
bool m_NeedsReload;
2009-02-10 18:37:48 +00:00
bool m_ZeroFrame; // If true, the first frame is only shown when the measured value is zero
2012-05-20 20:57:12 +03:00
int m_FrameCount;
int m_TransitionFrameCount; // Number of transition frames (per one frame) in the bitmap
2012-05-20 20:57:12 +03:00
METER_ALIGNMENT m_Align;
2009-02-10 18:37:48 +00:00
bool m_Extend; // If true, bitmaps extend horizontally and are used like numbers
int m_Separation;
int m_Digits;
double m_Value;
ULONGLONG m_TransitionStartTicks;
double m_TransitionStartValue;
2009-02-10 18:37:48 +00:00
};
#endif