#1 Re: Програмування Arduino » Конфликт экрана n5110 и SD карты » 2016-03-31 02:56:12

Pin

Из-за таймера в коде работы с картой памяти (в ардуино иде), нельзя подключить больше устройства на аппаратный spi.

#2 Програмування Arduino » Конфликт экрана n5110 и SD карты » 2016-03-30 19:20:03

Pin
відповідей: 2

Подключил экран и карту памяти на SPI.
Экран работает, карта определяется.
Но если попробовать что-то вывести на экран после работы с картой, то ничего не будет, экран даже не очистится.
В чем проблема?
ATmega328
Вот скетч:

/*
  SD card test
 
 This example shows how use the utility libraries on which the'
 SD library is based in order to get info about your SD card.
 Very useful for testing a card when you're not sure whether its working or not.
 
 The circuit: 
  * SD card attached to SPI bus as follows:
 ** MOSI - pin 11 on Arduino Uno/Duemilanove/Diecimila
 ** MISO - pin 12 on Arduino Uno/Duemilanove/Diecimila
 ** CLK - pin 13 on Arduino Uno/Duemilanove/Diecimila
 ** CS - depends on your SD card shield or module.
        Pin 4 used here for consistency with other Arduino examples
 
 
 created  28 Mar 2011
 by Limor Fried
 modified 9 Apr 2012
 by Tom Igoe
 */
// include the SD library:
#include <SPI.h>
#include <SD.h>
 
// set up variables using the SD utility library functions:
Sd2Card card;
SdVolume volume;
SdFile root;
 
#define PIN_RESET_ 9
#define PIN_SCE_   10
#define PIN_DC_    12
#define PIN_SDIN_  11
#define PIN_SCLK_  13
 
#define LCD_C_     LOW
#define LCD_D_     HIGH
 
#define LCD_X_     84
#define LCD_Y_     48
 
static const byte ASCII[][5] =
{
 {0x00, 0x00, 0x00, 0x00, 0x00} // 20  
,{0x00, 0x00, 0x5f, 0x00, 0x00} // 21 !
,{0x00, 0x07, 0x00, 0x07, 0x00} // 22 "
,{0x14, 0x7f, 0x14, 0x7f, 0x14} // 23 #
,{0x24, 0x2a, 0x7f, 0x2a, 0x12} // 24 $
,{0x23, 0x13, 0x08, 0x64, 0x62} // 25 %
,{0x36, 0x49, 0x55, 0x22, 0x50} // 26 &
,{0x00, 0x05, 0x03, 0x00, 0x00} // 27 '
,{0x00, 0x1c, 0x22, 0x41, 0x00} // 28 (
,{0x00, 0x41, 0x22, 0x1c, 0x00} // 29 )
,{0x14, 0x08, 0x3e, 0x08, 0x14} // 2a *
,{0x08, 0x08, 0x3e, 0x08, 0x08} // 2b +
,{0x00, 0x50, 0x30, 0x00, 0x00} // 2c ,
,{0x08, 0x08, 0x08, 0x08, 0x08} // 2d -
,{0x00, 0x60, 0x60, 0x00, 0x00} // 2e .
,{0x20, 0x10, 0x08, 0x04, 0x02} // 2f /
,{0x3e, 0x51, 0x49, 0x45, 0x3e} // 30 0
,{0x00, 0x42, 0x7f, 0x40, 0x00} // 31 1
,{0x42, 0x61, 0x51, 0x49, 0x46} // 32 2
,{0x21, 0x41, 0x45, 0x4b, 0x31} // 33 3
,{0x18, 0x14, 0x12, 0x7f, 0x10} // 34 4
,{0x27, 0x45, 0x45, 0x45, 0x39} // 35 5
,{0x3c, 0x4a, 0x49, 0x49, 0x30} // 36 6
,{0x01, 0x71, 0x09, 0x05, 0x03} // 37 7
,{0x36, 0x49, 0x49, 0x49, 0x36} // 38 8
,{0x06, 0x49, 0x49, 0x29, 0x1e} // 39 9
,{0x00, 0x36, 0x36, 0x00, 0x00} // 3a :
,{0x00, 0x56, 0x36, 0x00, 0x00} // 3b ;
,{0x08, 0x14, 0x22, 0x41, 0x00} // 3c <
,{0x14, 0x14, 0x14, 0x14, 0x14} // 3d =
,{0x00, 0x41, 0x22, 0x14, 0x08} // 3e >
,{0x02, 0x01, 0x51, 0x09, 0x06} // 3f ?
,{0x32, 0x49, 0x79, 0x41, 0x3e} // 40 @
,{0x7e, 0x11, 0x11, 0x11, 0x7e} // 41 A
,{0x7f, 0x49, 0x49, 0x49, 0x36} // 42 B
,{0x3e, 0x41, 0x41, 0x41, 0x22} // 43 C
,{0x7f, 0x41, 0x41, 0x22, 0x1c} // 44 D
,{0x7f, 0x49, 0x49, 0x49, 0x41} // 45 E
,{0x7f, 0x09, 0x09, 0x09, 0x01} // 46 F
,{0x3e, 0x41, 0x49, 0x49, 0x7a} // 47 G
,{0x7f, 0x08, 0x08, 0x08, 0x7f} // 48 H
,{0x00, 0x41, 0x7f, 0x41, 0x00} // 49 I
,{0x20, 0x40, 0x41, 0x3f, 0x01} // 4a J
,{0x7f, 0x08, 0x14, 0x22, 0x41} // 4b K
,{0x7f, 0x40, 0x40, 0x40, 0x40} // 4c L
,{0x7f, 0x02, 0x0c, 0x02, 0x7f} // 4d M
,{0x7f, 0x04, 0x08, 0x10, 0x7f} // 4e N
,{0x3e, 0x41, 0x41, 0x41, 0x3e} // 4f O
,{0x7f, 0x09, 0x09, 0x09, 0x06} // 50 P
,{0x3e, 0x41, 0x51, 0x21, 0x5e} // 51 Q
,{0x7f, 0x09, 0x19, 0x29, 0x46} // 52 R
,{0x46, 0x49, 0x49, 0x49, 0x31} // 53 S
,{0x01, 0x01, 0x7f, 0x01, 0x01} // 54 T
,{0x3f, 0x40, 0x40, 0x40, 0x3f} // 55 U
,{0x1f, 0x20, 0x40, 0x20, 0x1f} // 56 V
,{0x3f, 0x40, 0x38, 0x40, 0x3f} // 57 W
,{0x63, 0x14, 0x08, 0x14, 0x63} // 58 X
,{0x07, 0x08, 0x70, 0x08, 0x07} // 59 Y
,{0x61, 0x51, 0x49, 0x45, 0x43} // 5a Z
,{0x00, 0x7f, 0x41, 0x41, 0x00} // 5b [
,{0x02, 0x04, 0x08, 0x10, 0x20} // 5c ВҐ
,{0x00, 0x41, 0x41, 0x7f, 0x00} // 5d ]
,{0x04, 0x02, 0x01, 0x02, 0x04} // 5e ^
,{0x40, 0x40, 0x40, 0x40, 0x40} // 5f _
,{0x00, 0x01, 0x02, 0x04, 0x00} // 60 `
,{0x20, 0x54, 0x54, 0x54, 0x78} // 61 a
,{0x7f, 0x48, 0x44, 0x44, 0x38} // 62 b
,{0x38, 0x44, 0x44, 0x44, 0x20} // 63 c
,{0x38, 0x44, 0x44, 0x48, 0x7f} // 64 d
,{0x38, 0x54, 0x54, 0x54, 0x18} // 65 e
,{0x08, 0x7e, 0x09, 0x01, 0x02} // 66 f
,{0x0c, 0x52, 0x52, 0x52, 0x3e} // 67 g
,{0x7f, 0x08, 0x04, 0x04, 0x78} // 68 h
,{0x00, 0x44, 0x7d, 0x40, 0x00} // 69 i
,{0x20, 0x40, 0x44, 0x3d, 0x00} // 6a j 
,{0x7f, 0x10, 0x28, 0x44, 0x00} // 6b k
,{0x00, 0x41, 0x7f, 0x40, 0x00} // 6c l
,{0x7c, 0x04, 0x18, 0x04, 0x78} // 6d m
,{0x7c, 0x08, 0x04, 0x04, 0x78} // 6e n
,{0x38, 0x44, 0x44, 0x44, 0x38} // 6f o
,{0x7c, 0x14, 0x14, 0x14, 0x08} // 70 p
,{0x08, 0x14, 0x14, 0x18, 0x7c} // 71 q
,{0x7c, 0x08, 0x04, 0x04, 0x08} // 72 r
,{0x48, 0x54, 0x54, 0x54, 0x20} // 73 s
,{0x04, 0x3f, 0x44, 0x40, 0x20} // 74 t
,{0x3c, 0x40, 0x40, 0x20, 0x7c} // 75 u
,{0x1c, 0x20, 0x40, 0x20, 0x1c} // 76 v
,{0x3c, 0x40, 0x30, 0x40, 0x3c} // 77 w
,{0x44, 0x28, 0x10, 0x28, 0x44} // 78 x
,{0x0c, 0x50, 0x50, 0x50, 0x3c} // 79 y
,{0x44, 0x64, 0x54, 0x4c, 0x44} // 7a z
,{0x00, 0x08, 0x36, 0x41, 0x00} // 7b {
,{0x00, 0x00, 0x7f, 0x00, 0x00} // 7c |
,{0x00, 0x41, 0x36, 0x08, 0x00} // 7d }
,{0x10, 0x08, 0x08, 0x10, 0x08} // 7e в†ђ
,{0x78, 0x46, 0x41, 0x46, 0x78} // 7f в†’
};
 
void LcdCharacter(char character)
{
  LcdWrite(LCD_D_, 0x00);
  for (int index = 0; index < 5; index++)
  {
    LcdWrite(LCD_D_, ASCII[character - 0x20][index]);
  }
  LcdWrite(LCD_D_, 0x00);
}
 
void LcdClear(void)
{
  for (int index = 0; index < LCD_X_ * LCD_Y_ / 8; index++)
  {
    LcdWrite(LCD_D_, 0x00);
  }
}
 
void LcdInitialise(void)
{
  pinMode(PIN_SCE_, OUTPUT);
  pinMode(PIN_RESET_, OUTPUT);
  pinMode(PIN_DC_, OUTPUT);
  pinMode(PIN_SDIN_, OUTPUT);
  pinMode(PIN_SCLK_, OUTPUT);
  digitalWrite(PIN_RESET_, LOW);
  digitalWrite(PIN_RESET_, HIGH);
  LcdWrite(LCD_C_, 0x21 );  // LCD Extended Commands.
  LcdWrite(LCD_C_, 0xB1 );  // Set LCD Vop (Contrast). 
  LcdWrite(LCD_C_, 0x04 );  // Set Temp coefficent. //0x04
  LcdWrite(LCD_C_, 0x14 );  // LCD bias mode 1:48. //0x13
  LcdWrite(LCD_C_, 0x20 );  // LCD Basic Commands
  LcdWrite(LCD_C_, 0x0C );  // LCD in normal mode.
}
 
void LcdString(char *characters)
{
  while (*characters)
  {
    LcdCharacter(*characters++);
  }
}
 
void LcdWrite(byte dc, byte data)
{
  digitalWrite(PIN_DC_, dc);
  digitalWrite(PIN_SCE_, LOW);
  shiftOut(PIN_SDIN_, PIN_SCLK_, MSBFIRST, data);
  digitalWrite(PIN_SCE_, HIGH);
}
 
void gotoXY(int x, int y)
{
  LcdWrite(0, 0x80 | x);  // Column.
  LcdWrite(0, 0x40 | y);  // Row.  
}
 
// change this to match your SD shield or module;
// Arduino Ethernet shield: pin 4
// Adafruit SD shields and modules: pin 10
// Sparkfun SD shield: pin 8
const int chipSelect = 8;
 
void setup() {
  LcdInitialise();
  
  LcdClear();
  gotoXY(0,0);
  LcdString("Test!");
  
  // Open serial communications and wait for port to open:
  pinMode(16, OUTPUT); digitalWrite(16, LOW);
  while (!Serial) {
    ; // wait for serial port to connect. Needed for native USB port only
  }
 
  LcdClear();
  gotoXY(0,0);
  LcdString("Initializing SD card...");
  
  //Serial.print("\nInitializing SD card...");
 
  // we'll use the initialization code from the utility libraries
  // since we're just testing if the card is working!
  if (!card.init(SPI_HALF_SPEED, chipSelect)) { digitalWrite(16, HIGH);
  
  LcdClear();
  gotoXY(0,0);
  LcdString("Initialization failed.");
  
    //Serial.println("initialization failed. Things to check:");
    //Serial.println("* is a card inserted?");
    //Serial.println("* is your wiring correct?");
    //Serial.println("* did you change the chipSelect pin to match your shield or module?");
    return;
  } else {
    
  LcdClear();
  gotoXY(0,0);
  LcdString("Wiring is correct and a card is present.");
  
    //Serial.println("Wiring is correct and a card is present.");
  }
 
  // print the type of card
  //Serial.print("\nCard type: ");
  switch (card.type()) {
    case SD_CARD_TYPE_SD1:
    
  LcdClear();
  gotoXY(0,0);
  LcdString("Card type: SD1");
  
      //Serial.println("SD1");
      break;
    case SD_CARD_TYPE_SD2:
    
  LcdClear();
  gotoXY(0,0);
  LcdString("Card type: SD2");
  
      //Serial.println("SD2");
      break;
    case SD_CARD_TYPE_SDHC:
    
  LcdClear();
  gotoXY(0,0);
  LcdString("Card type: SDHC");
  
      //Serial.println("SDHC");
      break;
    default:
    
  LcdClear();
  gotoXY(0,0);
  LcdString("Card type: Unknown");
  
      //Serial.println("Unknown");
      break;
  }
 
  // Now we will try to open the 'volume'/'partition' - it should be FAT16 or FAT32
  if (!volume.init(card)) { digitalWrite(16, HIGH);
  
  LcdClear();
  gotoXY(0,0);
  LcdString("Could not find FAT16/FAT32 partition.");
  
    //Serial.println("Could not find FAT16/FAT32 partition.\nMake sure you've formatted the card");
    return;
  }
  
  // print the type and size of the first FAT-type volume
  uint32_t volumesize;
  
  LcdClear();
  gotoXY(0,0);
  LcdString("Volume type is FAT.");
  
  //Serial.print("\nVolume type is FAT");
  //Serial.println(volume.fatType(), DEC);
  //Serial.println();
 
  volumesize = volume.blocksPerCluster();    // clusters are collections of blocks
  volumesize *= volume.clusterCount();       // we'll have a lot of clusters
  volumesize *= 512;                            // SD card blocks are always 512 bytes
  //Serial.print("Volume size (bytes): ");
  //Serial.println(volumesize);
  //Serial.print("Volume size (Kbytes): ");
  volumesize /= 1024;
  //Serial.println(volumesize);
  //Serial.print("Volume size (Mbytes): ");
  volumesize /= 1024;
  //Serial.println(volumesize);
 
 
  //Serial.println("\nFiles found on the card (name, date and size in bytes): ");
  root.openRoot(volume);
 
  // list all files in the card with date and size
  root.ls(LS_R | LS_DATE | LS_SIZE);
  
  LcdClear();
  gotoXY(0,0);
  LcdString("Test!");
}
 
 
void loop(void)
{
  
}

Очень прошу, помогите!
Нужно сделать до понедельника.
Спросить больше не у кого.

Підвал форуму