225 lines
6.3 KiB
C
225 lines
6.3 KiB
C
/*
|
|
* Copyright (c) 2002-2004, Adam Dunkels.
|
|
* 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. The name of the author may not be used to endorse or promote
|
|
* products derived from this software without specific prior
|
|
* written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
|
|
*
|
|
* This file is part of the Contiki desktop environment
|
|
*
|
|
* $Id: plasma.c,v 1.1 2007/05/23 23:11:24 oliverschmidt Exp $
|
|
*
|
|
*/
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include "ctk/ctk.h"
|
|
#include "ctk/ctk-draw.h"
|
|
#include "ctk/ctk-mouse.h"
|
|
#include "contiki.h"
|
|
|
|
static unsigned char sinetab1[256] = {
|
|
128, 131, 134, 137, 140, 143, 146, 149,
|
|
152, 156, 159, 162, 165, 168, 171, 174,
|
|
176, 179, 182, 185, 188, 191, 193, 196,
|
|
199, 201, 204, 206, 209, 211, 213, 216,
|
|
218, 220, 222, 224, 226, 228, 230, 232,
|
|
234, 236, 237, 239, 240, 242, 243, 245,
|
|
246, 247, 248, 249, 250, 251, 252, 252,
|
|
253, 254, 254, 255, 255, 255, 255, 255,
|
|
255, 255, 255, 255, 255, 255, 254, 254,
|
|
253, 252, 252, 251, 250, 249, 248, 247,
|
|
246, 245, 243, 242, 240, 239, 237, 236,
|
|
234, 232, 230, 228, 226, 224, 222, 220,
|
|
218, 216, 213, 211, 209, 206, 204, 201,
|
|
199, 196, 193, 191, 188, 185, 182, 179,
|
|
176, 174, 171, 168, 165, 162, 159, 156,
|
|
152, 149, 146, 143, 140, 137, 134, 131,
|
|
128, 124, 121, 118, 115, 112, 109, 106,
|
|
103, 99, 96, 93, 90, 87, 84, 81,
|
|
79, 76, 73, 70, 67, 64, 62, 59,
|
|
56, 54, 51, 49, 46, 44, 42, 39,
|
|
37, 35, 33, 31, 29, 27, 25, 23,
|
|
21, 19, 18, 16, 15, 13, 12, 10,
|
|
9, 8, 7, 6, 5, 4, 3, 3,
|
|
2, 1, 1, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 1, 1,
|
|
2, 3, 3, 4, 5, 6, 7, 8,
|
|
9, 10, 12, 13, 15, 16, 18, 19,
|
|
21, 23, 25, 27, 29, 31, 33, 35,
|
|
37, 39, 42, 44, 46, 49, 51, 54,
|
|
56, 59, 62, 64, 67, 70, 73, 76,
|
|
78, 81, 84, 87, 90, 93, 96, 99,
|
|
103, 106, 109, 112, 115, 118, 121, 124,
|
|
};
|
|
|
|
static unsigned char sinetab2[256];
|
|
static unsigned char sinetab3[256];
|
|
|
|
static unsigned char colortab[256];
|
|
|
|
static unsigned char colors[16] =
|
|
{
|
|
0x00, 0x06, 0x0b, 0x04,
|
|
0x0a, 0x0f, 0x07, 0x01,
|
|
0x07, 0x0f, 0x0a, 0x08,
|
|
0x02, 0x09, 0x00, 0x00,
|
|
};
|
|
|
|
#define XSIZE 25
|
|
#define YSIZE 25
|
|
|
|
#define XADD01 0xfe
|
|
#define YADD01 0x05
|
|
|
|
#define XADD1 0x04
|
|
#define YADD1 0x02
|
|
#define XADD2 0xfc
|
|
#define YADD2 0xf9
|
|
|
|
#define XADD 0x03
|
|
#define YADD 0xfe
|
|
|
|
#define MOVADD 0xfb
|
|
|
|
static unsigned char xplasma[XSIZE], yplasma[YSIZE];
|
|
static unsigned char xcnt, ycnt;
|
|
static unsigned char xcnt01, xcnt02, xcnt1, xcnt2;
|
|
static unsigned char ycnt01, ycnt02, ycnt1, ycnt2;
|
|
|
|
static unsigned char xadd02 = 0x01;
|
|
static unsigned char yadd02 = 0xfb;
|
|
|
|
static unsigned char movcnt;
|
|
|
|
PROCESS(plasma_process, "Plasma screensaver");
|
|
/*---------------------------------------------------------------------------*/
|
|
static void
|
|
scrninit(void)
|
|
{
|
|
unsigned char *ptr, *cptr;
|
|
static int i;
|
|
|
|
/* Make sine tables */
|
|
for(i = 0; i < 256; ++i) {
|
|
sinetab2[(unsigned char)i] = sinetab1[(unsigned char)i] / 2;
|
|
sinetab3[(unsigned char)i] = sinetab1[(unsigned char)i] / 4;
|
|
}
|
|
|
|
/* Make color table */
|
|
for(i = 0; i < 256; ++i) {
|
|
colortab[(unsigned char)i] = colors[(unsigned char)i / 16];
|
|
}
|
|
|
|
|
|
/* Fill screen with inverted spaces. */
|
|
cptr = COLOR_RAM;
|
|
for(ptr = (unsigned char *)0x0400;
|
|
ptr != (unsigned char *)0x07e8;
|
|
++ptr) {
|
|
*ptr = 0xa0;
|
|
*cptr++ = 0x00;
|
|
}
|
|
|
|
VIC.ctrl1 = 0x1b; /* $D011 */
|
|
VIC.addr = 0x17; /* $D018 */
|
|
VIC.ctrl2 = 0xc8; /* $D016 */
|
|
VIC.bordercolor = 0x00; /* $D020 */
|
|
VIC.bgcolor0 = 0x00; /* $D021 */
|
|
CIA2.pra = 0x03; /* $DD00 */
|
|
|
|
}
|
|
/*---------------------------------------------------------------------------*/
|
|
static void
|
|
pollhandler(void)
|
|
{
|
|
static unsigned char i, x, y;
|
|
register unsigned char *cptr;
|
|
|
|
if(ctk_mode_get() == CTK_MODE_SCREENSAVER) {
|
|
|
|
|
|
xcnt1 = xcnt01;
|
|
xcnt2 = xcnt02;
|
|
|
|
for(i = 0; i < XSIZE; ++i) {
|
|
xplasma[i] = sinetab1[xcnt1] + sinetab2[xcnt2];
|
|
xcnt1 += XADD1;
|
|
xcnt2 += XADD2;
|
|
}
|
|
|
|
ycnt1 = ycnt01;
|
|
ycnt2 = ycnt02;
|
|
|
|
for(i = 0; i < YSIZE; ++i) {
|
|
yplasma[i] = sinetab1[ycnt1] + sinetab3[ycnt2];
|
|
ycnt1 += YADD1;
|
|
ycnt2 += YADD2;
|
|
}
|
|
|
|
xcnt01 += XADD01;
|
|
xcnt02 += xadd02;
|
|
ycnt01 += YADD01;
|
|
ycnt02 += yadd02;
|
|
|
|
|
|
yadd02 = sinetab3[ycnt] / 4;
|
|
xadd02 = sinetab3[xcnt] / 4;
|
|
|
|
ycnt += YADD;
|
|
xcnt += XADD;
|
|
|
|
movcnt += MOVADD;
|
|
cptr = (unsigned char *)(COLOR_RAM + sinetab1[movcnt]/16);
|
|
for(y = 0; y < YSIZE; ++y) {
|
|
for(x = 0; x < XSIZE; ++x) {
|
|
*cptr = colortab[(xplasma[x] + yplasma[y]) & 0xff];
|
|
++cptr;
|
|
}
|
|
cptr += 40 - XSIZE;
|
|
}
|
|
}
|
|
}
|
|
/*---------------------------------------------------------------------------*/
|
|
PROCESS_THREAD(plasma_process, ev, data)
|
|
{
|
|
PROCESS_POLLHANDLER(pollhandler());
|
|
|
|
PROCESS_BEGIN();
|
|
|
|
ctk_mode_set(CTK_MODE_SCREENSAVER);
|
|
ctk_mouse_hide();
|
|
|
|
scrninit();
|
|
|
|
PROCESS_WAIT_EVENT_UNTIL(ev == ctk_signal_screensaver_stop ||
|
|
ev == PROCESS_EVENT_EXIT);
|
|
ctk_draw_init();
|
|
ctk_desktop_redraw(NULL);
|
|
|
|
PROCESS_END();
|
|
}
|
|
/*---------------------------------------------------------------------------*/
|