Project

General

Profile

Statistics
| Revision:

root / branches / autonomous_recharging / code / projects / libbayboard / orb.c @ 669

History | View | Annotate | Download (3.45 KB)

1 641 emullini
/**
2
 * Copyright (c) 2008 Colony Project
3
 *
4
 * Permission is hereby granted, free of charge, to any person
5
 * obtaining a copy of this software and associated documentation
6
 * files (the "Software"), to deal in the Software without
7
 * restriction, including without limitation the rights to use,
8
 * copy, modify, merge, publish, distribute, sublicense, and/or sell
9
 * copies of the Software, and to permit persons to whom the
10
 * Software is furnished to do so, subject to the following
11
 * conditions:
12
 *
13
 * The above copyright notice and this permission notice shall be
14
 * included in all copies or substantial portions of the Software.
15
 *
16
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
18
 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
20
 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
21
 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
22
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
23
 * OTHER DEALINGS IN THE SOFTWARE.
24
 **/
25
26
/**
27
 * @file orb.c
28
 * @brief Orbs
29
 *
30
 * Implemenation for the orbs (tri-colored LEDs)
31
 *
32
 * @author Colony Project, CMU Robotics Club
33
 **/
34
35
#include <avr/io.h>
36
#include "orb.h"
37
38
/**
39
 * @defgroup orbs Orbs
40
 * @brief Functions for controlling the color of the orbs.
41
 *
42
 * Functions for controlling the color and lighting of the orbs.
43
 *
44
 * @{
45
 **/
46
47
/**
48
 * Initializes the PWM for Orb control. This must be called before
49
 * the orbs are used for them to function.
50
 **/
51
int orb_init (void)
52
{
53
        /*data direction registers, blue, green (bit 6) and red (bit 4)*/
54 669 emullini
        DDRB |= _BV(DDB4);
55 641 emullini
56 669 emullini
        DDRD |= _BV(DDD4)|_BV(DDD6);
57 641 emullini
58
59
        /*blue is here. it goes on timer 0*/
60
        /*timer counter control registers for timer 0*/
61 669 emullini
        TCCR0A = _BV(COM0B1)|_BV(COM0B0)|_BV(WGM01)|_BV(WGM00);
62 641 emullini
63 669 emullini
        TCCR0B = _BV(CS00);
64 641 emullini
        OCR0B = 0;
65
66
        /*green is here. it goes on timer 2*/
67 669 emullini
        TCCR2A = _BV(COM2B1)|_BV(COM2B0)|_BV(WGM21)|_BV(WGM20);
68
        TCCR2B = _BV(CS20);
69 641 emullini
        OCR2B = 0;
70
71
72 669 emullini
        /*red is here. it goes on timer 1 which counts to the value in ICR1 instead of 8 bits*/
73
        TCCR1A = _BV(COM1B1)|_BV(COM1B0)|_BV(WGM11);
74
        TCCR1B = _BV(WGM13)|_BV(WGM12)|_BV(CS10);
75 641 emullini
        ICR1 = 0x9C40;
76
        OCR1B = 0;
77 658 emullini
78 641 emullini
        return 0;
79
}
80
81
/**
82
 * Set both orbs to the color specified. orb_init must
83
 * be called before this function may be used.
84
 *
85
 * @param red the red component of the color
86
 * @param green the green component of the color
87
 * @param blue the blue component of the color
88
 *
89
 * @see orb_init
90
 **/
91
92
int set_orb(int red, int green, int blue){
93
        /*blue is here. it goes on timer 0*/
94 669 emullini
        if(blue==0){
95
                DDRB &= ~(_BV(DDB4));
96
        }
97
        else{
98
                DDRB |= _BV(DDB4);
99
                blue = blue%256;
100
                OCR0B = blue;
101
        }
102
103 641 emullini
        /*green is here. it goes on timer 2*/
104 669 emullini
        if(green==0){
105
                DDRD &= ~(_BV(DDD6));
106
        }
107
        else{
108
                DDRD |= _BV(DDD6);
109
                green = green%256;
110
                OCR2B = green;
111
        }
112 641 emullini
113 657 emullini
        /*red is here. it goes on timer 1*/
114 641 emullini
        red = red%256;
115
        red *= 0x9C40;
116
        red = (int)(red/256);
117 669 emullini
        OCR1B = red;
118 657 emullini
119 641 emullini
        return 0;
120
}
121
122 653 emullini
/**
123
 * Set both orbs to the color specified. orb_init must
124
 * be called before this function may be used.
125
 *
126 669 emullini
 * @param color use a pound-defined color
127 653 emullini
 *
128
 * @see orb_init
129
 **/
130
131 669 emullini
 int set_color(long color){
132 656 emullini
        int red = (color>>16)&BYTEMASK;
133 669 emullini
        int green = (color>>8)&BYTEMASK;
134
        int blue = color&BYTEMASK;
135 656 emullini
        return set_orb(red, green, blue);
136 653 emullini
 }
137
138 641 emullini
/** @} **/ //end group