| 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
96
97
98
99
 | .. highlight:: cpp
.. _lang-shiftout:
shiftOut()
==========
Shift out a byte of data, one bit at a time.
.. contents:: Contents
   :local:
Library Documentation
---------------------
.. doxygenfunction:: shiftOut
Discussion
----------
This is a software implementation.  There is also a hardware :ref:`SPI
<spi>` library available which will be faster and consume less CPU
cycles than this function.
Note that the ``dataPin`` and ``clockPin`` must already be configured
to :ref:`OUTPUT <lang-constants-output>` mode by a call to
:ref:`pinMode() <lang-pinmode>`.
Also note that since shiftOut() outputs 1 byte (8 bits) at a time, it
requires multiple steps to output values larger than 255.
Examples
--------
To use these examples, replace ``dataPin`` and ``clockPin`` with the
numbers of the pins you want to use::
    /* MSBFIRST example */
    uint16 data = 500;
    // shift out high byte
    shiftOut(dataPin, clockPin, MSBFIRST, (data >> 8));
    // shift out low byte
    shiftOut(dataPin, clockPin, MSBFIRST, data);
    /* LSBFIRST serial */
    data = 500;
    // shift out low byte
    shiftOut(dataPin, clockPin, LSBFIRST, data);
    // shift out high byte
    shiftOut(dataPin, clockPin, LSBFIRST, (data >> 8));
Arduino Tutorial Example
------------------------
This Arduino example runs unmodified on the Maple.  For accompanying
circuit, see the `tutorial on controlling a 74HC595 shift register
<http://arduino.cc/en/Tutorial/ShiftOut>`_.
::
    //**************************************************************//
    //  Name    : shiftOutCode, Hello World                         //
    //  Author  : Carlyn Maw, Tom Igoe                              //
    //  Date    : 25 Oct, 2006                                      //
    //  Version : 1.0                                               //
    //  Notes   : Code for using a 74HC595 Shift Register           //
    //          : to count from 0 to 255                            //
    //**************************************************************//
    // Pin connected to ST_CP of 74HC595
    int latchPin = 8;
    // Pin connected to SH_CP of 74HC595
    int clockPin = 12;
    // Pin connected to DS of 74HC595
    int dataPin = 11;
    void setup() {
      // Set pins to output because they are addressed in the main loop
      pinMode(latchPin, OUTPUT);
      pinMode(clockPin, OUTPUT);
      pinMode(dataPin, OUTPUT);
    }
    void loop() {
      // Count up routine
      for (int j = 0; j < 256; j++) {
        // Ground latchPin and hold low for as long as you are transmitting
        digitalWrite(latchPin, LOW);
        shiftOut(dataPin, clockPin, LSBFIRST, j);
        // Return the latch pin high to signal chip that it
        // no longer needs to listen for information
        digitalWrite(latchPin, HIGH);
        delay(1000);
      }
    }
.. include:: /lang/cc-attribution.txt
 |