Breadboard for "Shift Register - Common Anode Seven segments, Chained"


Fritzing diagram: shift-register-daisy-chain-anode.fzz


Run this example from the command line with:

node eg/shift-register-daisy-chain-anode.js
var five = require("johnny-five");
var async = require("async");
var _ = require("lodash");
var board = new five.Board();

board.on("ready", function() {

   * While we may have multiple ShiftRegisters,
   * we only need one to control them both.
  var register = new five.ShiftRegister({
    isAnode: true,
    size: 2,
    pins: {
      data: 2,
      clock: 3,
      latch: 4,
      reset: 9,

   * Pressing this button will trigger the die roll.
  var button = new five.Button(8);

   * Sends a random number to the shift register.
  function randomNumber() {
    return register.display(Math.round(Math.random() * 20));

   * This is an array of delays in ms.  When a button is pressed,
   * we'll iterate over this array and display a random number after the
   * delay.  This simulates a die bouncing on a table.
  var delays = new Array(10).fill(16)
    .concat(new Array(8).fill(32))
    .concat(new Array(6).fill(64))
    .concat(new Array(4).fill(128))
    .concat(new Array(2).fill(256))


  button.on("press", function() {
    async.eachSeries(delays, function(delay, done) {
      setTimeout(function() {
      }, delay);
    }, randomNumber);


Component Classes in this example:

Hi! The Johnny-Five community is building new projects every day. We made this newsletter to tell you about what's new, what's good, and what's next for Open Source robotics. Join us in exploring what we can make together.

Fork me on GitHub