home *** CD-ROM | disk | FTP | other *** search
/ The World of Computer Software / World_Of_Computer_Software-02-385-Vol-1of3.iso / i / iv26_w_3.zip / EXAMPLES / DCLOCK / DIGIT.C < prev    next >
C/C++ Source or Header  |  1980-01-05  |  2KB  |  73 lines

  1. /*
  2.  * Copyright (c) 1987, 1988, 1989 Stanford University
  3.  *
  4.  * Permission to use, copy, modify, distribute, and sell this software and its
  5.  * documentation for any purpose is hereby granted without fee, provided
  6.  * that the above copyright notice appear in all copies and that both that
  7.  * copyright notice and this permission notice appear in supporting
  8.  * documentation, and that the name of Stanford not be used in advertising or
  9.  * publicity pertaining to distribution of the software without specific,
  10.  * written prior permission.  Stanford makes no representations about
  11.  * the suitability of this software for any purpose.  It is provided "as is"
  12.  * without express or implied warranty.
  13.  *
  14.  * STANFORD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  15.  * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
  16.  * IN NO EVENT SHALL STANFORD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  17.  * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  18.  * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
  19.  * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
  20.  * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  21.  */
  22.  
  23. /*
  24.  * Digit class for digital clock
  25.  */
  26.  
  27. #include "dclock.h"
  28. #include "digit.h"
  29. #include "segment.h"
  30.  
  31. Digit::Digit (float Xoff, float Yoff) {
  32.     Xorg = Xoff;
  33.     Yorg = Yoff;
  34.     for (Seg s = SegA; s <= SegG; s++) {
  35.     Segs[s] = new Segment(s, Xoff, Yoff);
  36.     }
  37. }
  38.  
  39. Digit::~Digit () {
  40.     for (Seg s = SegA; s <= SegG; s++) {
  41.     delete Segs[s];
  42.     }
  43. }
  44.  
  45. boolean Digit::Set (int value) {
  46.     if (value > 9 || value < 0) {
  47.     // out of range, use blank
  48.     value = 10;
  49.     }
  50.     boolean done = true;
  51.     for (Seg s = SegA; s <= SegG; s++) {
  52.     done &= SegCode[value][s] ? Segs[s]->On() : Segs[s]->Off();
  53.     };
  54.     return done;
  55. }
  56.  
  57. void Digit::Reconfig (Painter* output) {
  58.     // configure any segment to initialize all segment patterns
  59.     Segs[SegA]->Reconfig(output);
  60. }
  61.  
  62. void Digit::Resize (Canvas* canvas, int height) {
  63.     for (Seg s = SegA; s <= SegG; s++) {
  64.     Segs[s]->Resize(canvas, height);
  65.     }
  66. }
  67.  
  68. void Digit::Redraw () {
  69.     for (Seg s = SegA; s <= SegG; s++) {
  70.     Segs[s]->Redraw();
  71.     }
  72. }
  73.