RobotPictureBrowser
Want to use your own images? This is how.
Picture Browser
You can make your own gallery/picture show with help of the Robot. Put some pictures in the SD card, start the sketch, and you can see them showing up on the LCD. Use left and right button on the D-pad to go the previous or next image. Press up or down to enter the "tilt navigation" mode.
Hardware Required
- Arduino Robot 
- Some pictures on the SD card 
Instruction
- Upload the example. You can keep the USB plugged in for power. 
- After the starting screen, you will see some instructions about the sketch. 
- A picture from the gallery will show up on the screen. 
- Press left/right/middle to navigate through the pictures 
- Press up/down to change the mode, you'll see the current mode showing up on top of the screen. 
- In tilt control mode, rotate your robot to navigate the gallery. 
- If you want to add your own pictures, make them 128*160, 24-bit bmp. Name them as "PicN.bmp" (where N is a number 1-9) and copy them onto the sd card. 
- The program only supports 10 pictures, Pic0.bmp to Pic9.bmp. Want to add more? Improve the program yourself! 
Try it out
 
  
    
    
You can change the picture navigation mode by pressing the down button and tilt the robot to check the next picture.
 
  
    
    
Code
1/* Picture Browser2
3 You can make your own gallery/picture show with the4
5 Robot. Put some pictures on the SD card, start the6
7 sketch, they will display on the screen.8
9 Use the left/right buttons to navigate through the10
11 previous and next images.12
13 Press up or down to enter a mode where you change14
15 the pictures by rotating the robot.16
17 You can add your own pictures onto the SD card, and18
19 view them in the Robot's gallery!20
21 Pictures must be uncompressed BMP, 24-bit color depth,22
23 160 pixels wide, and 128 pixels tall.24
25 They should be named as "picN.bmp". Replace 'N' with a26
27 number between 0 and 9.28
29 The current code only supports 10 pictures. How would you30
31 improve it to handle more?32
33 Circuit:34
35 * Arduino Robot36
37 created 1 May 201338
39 by X. Yang40
41 modified 12 May 201342
43 by D. Cuartielles44
45 This example is in the public domain46
47 */48
49#include <ArduinoRobot.h> // include the robot library50#include <Wire.h>51
52const int NUM_PICS = 4;  //Total number of pictures in Gallery53
54// name the modes55
56const int CONTROL_MODE_KEY = 0;57
58const int CONTROL_MODE_COMPASS = 1;59
60char buffer[] = "pic1.bmp";  // current file name61int i = 1;  // Current gallery sequence counter62int mode = 0;  // Current mode63
64// text to display on screen65char modeNames[][9] = { "keyboard", "tilt    " };66
67void setup() {68
69  // initialize the Robot, SD card, display, and speaker70
71  Robot.beginSD();72
73  Robot.beginTFT();74
75  Robot.begin();76
77  // draw "lg0.bmp" and "lg1.bmp" on the screen78
79  Robot.displayLogos();80
81  // draw init3.bmp from the SD card on the screen82
83  Robot.drawBMP("init3.bmp", 0, 0);84
85  // display instructions86
87  Robot.stroke(0, 0, 0);88
89  Robot.text("The gallery\n\n has 2 modes, in\n keyboard mode, L/R\n key for switching\n pictures, U/D key\n for changing modes", 5, 5);90
91  delay(6000);92
93  Robot.clearScreen();94
95  Robot.drawBMP("pb.bmp", 0, 0);96
97  Robot.text("In tilt mode,\n quickly tilt the\n robot to switch\n pictures", 5, 5);98
99  delay(4000);100}101
102void loop() {103
104  buffer[3] = '0' + i; // change filename of the img to be displayed105
106  Robot.drawBMP(buffer, 0, 0); // draw the file on the screen107
108  // change control modes109
110  switch (mode) {111
112    case CONTROL_MODE_COMPASS:113
114      compassControl(3);115
116      break;117
118    case CONTROL_MODE_KEY:119
120      keyboardControl();121
122      break;123
124  }125
126  delay(200);127}128
129void keyboardControl() {130
131  //Use buttons to control the gallery132
133  while (true) {134
135    int keyPressed = Robot.keyboardRead(); // read the button values136
137    switch (keyPressed) {138
139      case BUTTON_LEFT:  // display previous picture140
141        if (--i < 1) {142
143          i = NUM_PICS;144
145        }146
147        return;148
149      case BUTTON_MIDDLE:  // do nothing150
151      case BUTTON_RIGHT:  // display next picture152
153        if (++i > NUM_PICS) {154
155          i = 1;156
157        }158
159        return;160
161      case BUTTON_UP:  // change mode162
163        changeMode(-1);164
165        return;166
167      case BUTTON_DOWN:  // change mode168
169        changeMode(1);170
171        return;172
173    }174
175  }176}177
178// if controlling by the compass179void compassControl(int change) {180
181  // Rotate the robot to change the pictures182
183  while (true) {184
185    // read the value of the compass186
187    int oldV = Robot.compassRead();188
189    //get the change of angle190
191    int diff = Robot.compassRead() - oldV;192
193    if (diff > 180) {194
195      diff -= 360;196
197    } else if (diff < -180) {198
199      diff += 360;200
201    }202
203    if (abs(diff) > change) {204
205      if (++i > NUM_PICS) {206
207        i = 1;208
209      }210
211      return;212
213    }214
215    // change modes, if buttons are pressed216
217    int keyPressed = Robot.keyboardRead();218
219    switch (keyPressed) {220
221      case BUTTON_UP:222
223        changeMode(-1);224
225        return;226
227      case BUTTON_DOWN:228
229        changeMode(1);230
231        return;232
233    }234
235    delay(10);236
237  }238}239
240// Change the control mode and display it on the LCD241void changeMode(int changeDir) {242
243  // alternate modes244
245  mode += changeDir;246
247  if (mode < 0) {248
249    mode = 1;250
251  } else if (mode > 1) {252
253    mode = 0;254
255  }256
257  // display  the mode on screen258
259  Robot.fill(255, 255, 255);260
261  Robot.stroke(255, 255, 255);262
263  Robot.rect(0, 0, 128, 12);264
265  Robot.stroke(0, 0, 0);266
267  Robot.text("Control:", 2, 2);268
269  Robot.text(modeNames[mode], 52, 2);270
271  delay(1000);272}Suggested changes
The content on docs.arduino.cc is facilitated through a public GitHub repository. You can read more on how to contribute in the contribution policy.
License
The Arduino documentation is licensed under the Creative Commons Attribution-Share Alike 4.0 license.