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 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
/*
* XEvil(TM) Copyright (C) 1994,2000 Steve Hardt and Michael Judge
* http://www.xevil.com
* satan@xevil.com
*
* 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, the file "gpl.txt"; if not, write to the Free
* Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
* 02111-1307, USA, or visit http://www.gnu.org.
*/
#include "stdafx.h"
#include "fogpal.h"
FogPalette::FogPalette(ColorPalette &p_palette)
:PaletteModifier(p_palette)
{
int t_int=0;
m_amount=0;
m_dir=-1*FOG_AMOUNT;
for (int i=0;i<PALENTRIES;i++)//first 10 and last 10 are reserved
{
t_int=p_palette.palentries[i].peRed*p_palette.palentries[i].peRed;
t_int+=p_palette.palentries[i].peGreen*p_palette.palentries[i].peGreen;
t_int+=p_palette.palentries[i].peBlue*p_palette.palentries[i].peBlue;
t_int= t_int/3;
t_int= (int)sqrt((float)t_int);
m_palette.palentries[i].peRed=t_int;
m_palette.palentries[i].peGreen=t_int;
m_palette.palentries[i].peBlue=t_int;
}
m_palette.palversion=0x300; //default of windows
m_palette.numentries=PALENTRIES;//256
m_fogholdingpalette=m_palette;
m_hpal= ::CreatePalette((LOGPALETTE *)&m_palette);//create a global palette
}
void FogPalette::clock()
{
m_palette= m_fogholdingpalette;
m_amount+=m_dir;
if (m_amount>FOG_UPPERLIMIT)
{
m_amount=FOG_UPPERLIMIT;
m_dir=-1*FOG_AMOUNT;
}
if (m_amount<FOG_LOWERLIMIT)
{
m_amount=FOG_LOWERLIMIT;
m_dir=FOG_AMOUNT;
}
for (int i=0;i<PALENTRIES;i++)
{
if (((int)m_palette.palentries[i].peRed+m_amount)>255)
m_palette.palentries[i].peRed=255;
else
if (((int)m_palette.palentries[i].peRed+m_amount)<0)
m_palette.palentries[i].peRed=0;
else
m_palette.palentries[i].peRed+=m_amount;
if (((int)m_palette.palentries[i].peGreen+m_amount)>255)
m_palette.palentries[i].peGreen=255;
else
if (((int)m_palette.palentries[i].peGreen+m_amount)<0)
m_palette.palentries[i].peGreen=0;
else
m_palette.palentries[i].peGreen+=m_amount;
if (((int)m_palette.palentries[i].peBlue+m_amount)>255)
m_palette.palentries[i].peBlue=255;
else
if (((int)m_palette.palentries[i].peBlue+m_amount)<0)
m_palette.palentries[i].peBlue=0;
else
m_palette.palentries[i].peBlue+=m_amount;
}
m_ddpalette->SetEntries(0,0,255,m_palette.palentries);
}
|