546N/A/*
546N/A * Copyright (c) 1988-91 by Patrick J. Naughton.
546N/A *
546N/A * Permission to use, copy, modify, and distribute this software and its
546N/A * documentation for any purpose and without fee is hereby granted,
546N/A * provided that the above copyright notice appear in all copies and that
546N/A * both that copyright notice and this permission notice appear in
546N/A * supporting documentation.
546N/A *
546N/A * This file is provided AS IS with no warranties of any kind. The author
546N/A * shall have no liability with respect to the infringement of copyrights,
546N/A * trade secrets or any patents by this file or any part thereof. In no
546N/A * event will the author be liable for any lost revenue or profits or
546N/A * other special, indirect and consequential damages.
546N/A */
546N/A
546N/A/*
943N/A * Copyright (c) 1989, 1994, Oracle and/or its affiliates. All rights reserved.
546N/A *
546N/A * Permission is hereby granted, free of charge, to any person obtaining a
919N/A * copy of this software and associated documentation files (the "Software"),
919N/A * to deal in the Software without restriction, including without limitation
919N/A * the rights to use, copy, modify, merge, publish, distribute, sublicense,
919N/A * and/or sell copies of the Software, and to permit persons to whom the
919N/A * Software is furnished to do so, subject to the following conditions:
546N/A *
919N/A * The above copyright notice and this permission notice (including the next
919N/A * paragraph) shall be included in all copies or substantial portions of the
919N/A * Software.
546N/A *
919N/A * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
919N/A * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
919N/A * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
919N/A * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
919N/A * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
919N/A * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
919N/A * DEALINGS IN THE SOFTWARE.
546N/A */
546N/A/*-
546N/A * qix.c - Vector swirl for xlock, the X Window System lockscreen.
546N/A *
546N/A * Copyright (c) 1991 by Patrick J. Naughton.
546N/A *
546N/A * See xlock.c for copying information.
546N/A *
546N/A * Revision History:
546N/A * 29-Jul-90: support for multiple screens.
546N/A * made check_bounds_?() a macro.
546N/A * fixed initial parameter setup.
546N/A * 15-Dec-89: Fix for proper skipping of {White,Black}Pixel() in colors.
546N/A * 08-Oct-89: Fixed bug in memory allocation in initqix().
546N/A * Moved seconds() to an extern.
546N/A * 23-Sep-89: Switch to random() and fixed bug w/ less than 4 lines.
546N/A * 20-Sep-89: Lint.
546N/A * 24-Mar-89: Written.
546N/A */
546N/A
546N/A#include "xlock.h"
546N/A
546N/Atypedef struct {
546N/A int x;
546N/A int y;
546N/A} point;
546N/A
546N/Atypedef struct {
546N/A int pix;
546N/A long startTime;
546N/A int first;
546N/A int last;
546N/A int dx1;
546N/A int dy1;
546N/A int dx2;
546N/A int dy2;
546N/A int x1;
546N/A int y1;
546N/A int x2;
546N/A int y2;
546N/A int offset;
546N/A int delta;
546N/A int width;
546N/A int height;
546N/A int nlines;
546N/A point *lineq;
546N/A} qixstruct;
546N/A
546N/Aextern XColor ssblack[];
546N/Aextern XColor sswhite[];
546N/A
546N/Astatic qixstruct qixs[MAXSCREENS];
546N/A
546N/Avoid
546N/Ainitqix(win)
546N/A Window win;
546N/A{
546N/A XWindowAttributes xgwa;
546N/A qixstruct *qp = &qixs[screen];
546N/A
546N/A qp->startTime = seconds();
546N/A qp->nlines = (batchcount + 1) * 2;
546N/A if (!qp->lineq) {
546N/A qp->lineq = (point *) malloc(qp->nlines * sizeof(point));
546N/A memset(qp->lineq, '\0', qp->nlines * sizeof(point));
546N/A }
546N/A
546N/A XGetWindowAttributes(dsp, win, &xgwa);
546N/A qp->width = xgwa.width;
546N/A qp->height = xgwa.height;
546N/A qp->delta = 16;
546N/A
546N/A if (qp->width < 100) { /* icon window */
546N/A qp->nlines /= 4;
546N/A qp->delta /= 4;
546N/A }
546N/A qp->offset = qp->delta / 3;
546N/A qp->last = 0;
546N/A qp->pix = 0;
546N/A qp->dx1 = random() % qp->delta + qp->offset;
546N/A qp->dy1 = random() % qp->delta + qp->offset;
546N/A qp->dx2 = random() % qp->delta + qp->offset;
546N/A qp->dy2 = random() % qp->delta + qp->offset;
546N/A qp->x1 = random() % qp->width;
546N/A qp->y1 = random() % qp->height;
546N/A qp->x2 = random() % qp->width;
546N/A qp->y2 = random() % qp->height;
546N/A XSetForeground(dsp, Scr[screen].gc, ssblack[screen].pixel);
546N/A XFillRectangle(dsp, win, Scr[screen].gc, 0, 0, qp->width, qp->height);
546N/A}
546N/A
546N/A#define check_bounds(qp, val, del, max) \
546N/A{ \
546N/A if ((val) < 0) { \
546N/A *(del) = (random() % (qp)->delta) + (qp)->offset; \
546N/A } else if ((val) > (max)) { \
546N/A *(del) = -(random() % (qp)->delta) - (qp)->offset; \
546N/A } \
546N/A}
546N/A
546N/Avoid
546N/Adrawqix(win)
546N/A Window win;
546N/A{
546N/A qixstruct *qp = &qixs[screen];
546N/A
546N/A qp->first = (qp->last + 2) % qp->nlines;
546N/A
546N/A qp->x1 += qp->dx1;
546N/A qp->y1 += qp->dy1;
546N/A qp->x2 += qp->dx2;
546N/A qp->y2 += qp->dy2;
546N/A check_bounds(qp, qp->x1, &qp->dx1, qp->width);
546N/A check_bounds(qp, qp->y1, &qp->dy1, qp->height);
546N/A check_bounds(qp, qp->x2, &qp->dx2, qp->width);
546N/A check_bounds(qp, qp->y2, &qp->dy2, qp->height);
546N/A XSetForeground(dsp, Scr[screen].gc, ssblack[screen].pixel);
546N/A XDrawLine(dsp, win, Scr[screen].gc,
546N/A qp->lineq[qp->first].x, qp->lineq[qp->first].y,
546N/A qp->lineq[qp->first + 1].x, qp->lineq[qp->first + 1].y);
546N/A if (!mono && Scr[screen].npixels > 2) {
546N/A XSetForeground(dsp, Scr[screen].gc, Scr[screen].pixels[qp->pix]);
546N/A if (++qp->pix >= Scr[screen].npixels)
546N/A qp->pix = 0;
546N/A } else
546N/A XSetForeground(dsp, Scr[screen].gc, sswhite[screen].pixel);
546N/A
546N/A XDrawLine(dsp, win, Scr[screen].gc, qp->x1, qp->y1, qp->x2, qp->y2);
546N/A
546N/A qp->lineq[qp->last].x = qp->x1;
546N/A qp->lineq[qp->last].y = qp->y1;
546N/A qp->last++;
546N/A if (qp->last >= qp->nlines)
546N/A qp->last = 0;
546N/A
546N/A qp->lineq[qp->last].x = qp->x2;
546N/A qp->lineq[qp->last].y = qp->y2;
546N/A qp->last++;
546N/A if (qp->last >= qp->nlines)
546N/A qp->last = 0;
546N/A}