No changes between revisions
/Designs/Measuring_instruments/LCTmetr01A/SW/lib/16f877_reg.h
0,0 → 1,288
////////////////////////////////////////////////////////////////////////////
// ////
// DEFINICE REGISTRU PROCESORU PIC16F877 ////
// ////
////////////////////////////////////////////////////////////////////////////
// ////
// PEFI S.ICZ a.s 2002 ////
// ////
// Verze 1.0 ////
// ////
////////////////////////////////////////////////////////////////////////////
 
 
 
// registry v bance 0
#define INDF 0x00
#define TMR0 0x01
#define PCL 0x02
#define STATUS 0x03
#define FSR 0x04
#define PORTA 0x05
#define PORTB 0x06
#define PORTC 0x07
#define PORTD 0x08
#define PORTE 0x09
#define PCLATH 0x0A
#define INTCON 0x0B
#define PIR1 0x0C
#define PIR2 0x0D
#define TMR1L 0x0E
#define TMR1H 0x0F
#define T1CON 0x10
#define TMR2 0x11
#define T2CON 0x12
#define SSPBUF 0x13
#define SSPCON 0x14
#define CCPR1L 0x15
#define CCPR1H 0x16
#define CCP1CON 0x17
#define RCSTA 0x18
#define TXREG 0x19
#define RCREG 0x1A
#define CCPR2L 0x1B
#define CCPR2H 0x1C
#define CCP2CON 0x1D
#define ADRESH 0x1E
#define ADCON0 0x1F
 
// registry v bance 1
#define OPTION 0x81
#define TRISA 0x85
#define TRISB 0x86
#define TRISC 0x87
#define TRISD 0x88
#define TRISE 0x89
#define PIE1 0x8C
#define PIE2 0x8D
#define PCON 0x8E
#define SSPCON2 0x91
#define PR2 0x92
#define SSPADD 0x93
#define SSPSTAT 0x94
#define TXSTA 0x98
#define SPBRG 0x99
#define ADRESL 0x9E
#define ADCON1 0x9F
 
// registry v bance 2
#define EEDATA 0x10C
#define EEADR 0x10D
#define EEDATH 0x10E
#define EEADRH 0x10F
 
// registry v bance 3
#define EECON1 0x18C
#define EECON2 0x18D
 
// bity v registru STATUS
#define _IRP 7
#define _RP1 6
#define _RP0 5
#define _NOT_TO 4
#define _NOT_PD 3
#define _Z 2
#define _DC 1
#define _C 0
 
// bity v registru INTCON
#define _GIE 7
#define _PEIE 6
#define _T0IE 5
#define _INTE 4
#define _RBIE 3
#define _T0IF 2
#define _INTF 1
#define _RBIF 0
 
// bity v registru PIR1
#define _PSPIF 7
#define _ADIF 6
#define _RCIF 5
#define _TXIF 4
#define _SSPIF 3
#define _CCP1IF 2
#define _TMR2IF 1
#define _TMR1IF 0
 
// bity v registru PIR2
#define _EEIF 4
#define _BCLIF 3
#define _CCP2IF 0
 
// bity v registru T1CON
#define _T1CKPS1 5
#define _T1CKPS0 4
#define _T1OSCEN 3
#define _NOT_T1SYNC 2
#define _T1SYNC 2
#define _TMR1CS 1
#define _TMR1ON 0
 
// bity v registru T2CON
#define _TOUTPS3 6
#define _TOUTPS2 5
#define _TOUTPS1 4
#define _TOUTPS0 3
#define _TMR2ON 2
#define _T2CKPS1 1
#define _T2CKPS0 0
 
// bity v registru SSPCON
#define _WCOL 7
#define _SSPOV 6
#define _SSPEN 5
#define _CKP 4
#define _SSPM3 3
#define _SSPM2 2
#define _SSPM1 1
#define _SSPM0 0
 
// bity v registru CCP1CON
#define _CCP1X 5
#define _CCP1Y 4
#define _CCP1M3 3
#define _CCP1M2 2
#define _CCP1M1 1
#define _CCP1M0 0
 
// bity v registru RCSTA
#define _SPEN 7
#define _RX9 6
#define _SREN 5
#define _CREN 4
#define _ADDEN 3
#define _FERR 2
#define _OERR 1
#define _RX9D 0
 
// bity registru CCP2CON
#define _CCP2X 5
#define _CCP2Y 4
#define _CCP2M3 3
#define _CCP2M2 2
#define _CCP2M1 1
#define _CCP2M0 0
 
// bity v registru ADCON0
#define _ADCS1 7
#define _ADCS0 6
#define _CHS2 5
#define _CHS1 4
#define _CHS0 3
#define _GO 2
#define _NOT_DONE 2
#define _GO_DONE 2
#define _ADON 0
 
// bity v registru OPTION
#define _NOT_RBPU 7
#define _INTEDG 6
#define _T0CS 5
#define _T0SE 4
#define _PSA 3
#define _PS2 2
#define _PS1 1
#define _PS0 0
 
// bity v registru TRISE
#define _IBF 7
#define _OBF 6
#define _IBOV 5
#define _PSPMODE 4
#define _TRISE2 2
#define _TRISE1 1
#define _TRISE0 0
 
// bity v registru PIE1
#define _PSPIE 7
#define _ADIE 6
#define _RCIE 5
#define _TXIE 4
#define _SSPIE 3
#define _CCP1IE 2
#define _TMR2IE 1
#define _TMR1IE 0
 
// bity v registru PIE2
#define _EEIE 4
#define _BCLIE 3
#define _CCP2IE 0
 
// bity v registru PCON
#define _NOT_POR 1
#define _NOT_BOR 0
 
// bity v registu
#define _GCEN 7
#define _ACKSTAT 6
#define _ACKDT 5
#define _ACKEN 4
#define _RCEN 3
#define _PEN 2
#define _RSEN 1
#define _SEN 0
 
//bity v registru SSPSTAT
#define _SMP 7
#define _CKE 6
#define _D 5
#define _I2C_DATA 5
#define _NOT_A 5
#define _NOT_ADDRESS 5
#define _D_A 5
#define _DATA_ADDRESS 5
#define _P 4
#define _I2C_STOP 4
#define _S 3
#define _I2C_START 3
#define _R 2
#define _I2C_READ 2
#define _NOT_W 2
#define _NOT_WRITE 2
#define _R_W 2
#define _READ_WRITE 2
#define _UA 1
#define _BF 0
 
// bity v registru TXSTA
#define CSRC 7
#define TX9 6
#define TXEN 5
#define SYNC 4
#define BRGH 2
#define TRMT 2
#define TX9D 0
 
// bity v registru ADCON1
#define _ADFM 7
#define _PCFG3 3
#define _PCFG2 2
#define _PCFG1 2
#define _PCFG0 0
 
// bity v registru EECON1
#define _EEPGD 7
#define _WRERR 3
#define _WREN 2
#define _WR 1
#define _RD 0
 
// masky pro nastaveni orientace I/O pinu
#define PIN0_IN 0x01
#define PIN1_IN 0x02
#define PIN2_IN 0x04
#define PIN3_IN 0x08
#define PIN4_IN 0x10
#define PIN5_IN 0x20
#define PIN6_IN 0x40
#define PIN7_IN 0x80
 
#define PIN0_OUT ~0x01
#define PIN1_OUT ~0x02
#define PIN2_OUT ~0x04
#define PIN3_OUT ~0x08
#define PIN4_OUT ~0x10
#define PIN5_OUT ~0x20
#define PIN6_OUT ~0x40
#define PIN7_OUT ~0x80
Property changes:
Added: svn:executable
+*
\ No newline at end of property
/Designs/Measuring_instruments/LCTmetr01A/SW/lib/TM.C
0,0 → 1,189
////////////////////////////////////////////////////////////////////////////
//
// KNIHOVNA PRO PRACI S TOUCH MEMORY FY DALLAS
//
////////////////////////////////////////////////////////////////////////////
//
// PEFI S.ICZ a.s. 2002, 2003
//
// Verze 1.0
// 1.1 - pridana podpora vypinani pullupu
// pres pin TOUCH_PULLUP_PIN
// 1.2 - vyrazena podpora pullupu, do obecne knihovny nepatri
// - funkce checkCRC se stala soucasti fce read_sn
// - upraveny nazvy funkci, zpetna kompatibilita neni potreba
// 1.3 - pridana samostatna funkce pro kontrolu CRC
//
///////////////////////////////////////////////////////////////////////////
//
// funkce:
// int8 TM_present()
// - vraci TRUE, pokud je TM pritomna
//
// int8 TM_read_byte()
// - precte bajt z TM
//
// int8 TM_write_byte(int8 data)
// - zapise bajt do TM a vraci TRUE, pokud se to povedlo
//
// int8 TM_read_sn(int8 *sn)
// - precte seriove cislo z TM pomoci prikazu 0x33
// - vraci TRUE, pokud je SN platne (spravne CRC)
//
// definice a prepinace
// #define TM_PIN /* pin, na kterem je touch memory pripojena */
// #bit TM_PIN_BIT /* totez, ale definovan jako bit */
//
//
// defaultni definice
#ifndef TM_PIN
#define TM_PIN PIN_B0
#bit TM_PIN_BIT = PORTB.0
#endif
 
 
 
 
 
/****************************************************************************************************/
// Privatni sekce, cist jen v pripade, ze neco nefunguje
/****************************************************************************************************/
// precte bajt z touch memory
//
int8 TM_read_byte() {
int8 i,data;
 
for(i=0;i<8;++i) {
output_low(TM_PIN);
delay_us(14);
output_float(TM_PIN);
delay_us(5);
shift_right(&data,1,input(TM_PIN));
delay_us(100);
}
return(data);
}
 
 
// zapise bajt do touch memory
//
int8 TM_write_byte(int8 data) {
int8 i;
 
for(i=0;i<8;++i) {
output_low(TM_PIN);
delay_us(10);
if(shift_right(&data,1,0)) {
output_float(TM_PIN);
delay_us(1); // k vuli nabehu jednicky pres pullup
if(!TM_PIN_BIT) return(0);
} else {
output_low(TM_PIN);
if(TM_PIN_BIT) return(0); // k vuli nabehu nuly
}
delay_us(50);
output_float(TM_PIN);
// delay_us(50);
}
return(TRUE);
}
 
 
// testuje pritomnost touch memory, pri pritomnosti vraci TRUE
//
int8 TM_present() {
int1 present;
 
output_low(TM_PIN);
delay_us(500);
output_float(TM_PIN);
if(!input(TM_PIN))
return(FALSE);
delay_us(65);
present=!input(TM_PIN);
delay_us(240);
if(present)
return(TRUE);
else
return(FALSE);
}
 
// zkontroluje CRC zaznamu, vraci TRUE, pokud je zanam spravny
//
int8 TM_check_CRC(unsigned int8 *sn, unsigned int8 num)
{
#ifdef CRC_TAB
// tabulka pro vypocet CRC
const int8 TouchCRC[256]= {
0, 94, 188, 226, 97, 63, 221, 131, 194, 156, 126, 32, 163, 253, 31, 65,
157, 195, 33, 127, 252, 162, 64, 30, 95, 1, 227, 189, 62, 96, 130, 220,
35, 125, 159, 193, 66, 28, 254, 160, 225, 191, 93, 3, 128, 222, 60, 98,
190, 224, 2, 92, 223, 129, 99, 61, 124, 34, 192, 158, 29, 67, 161, 255,
70, 24, 250, 164, 39, 121, 155, 197, 132, 218, 56, 102, 229, 187, 89, 7,
219, 133, 103, 57, 186, 228, 6, 88, 25, 71, 165, 251, 120, 38, 196, 154,
101, 59, 217, 135, 4, 90, 184, 230, 167, 249, 27, 69, 198, 152, 122, 36,
248, 166, 68, 26, 153, 199, 37, 123, 58, 100, 134, 216, 91, 5, 231, 185,
140, 210, 48, 110, 237, 179, 81, 15, 78, 16, 242, 172, 47, 113, 147, 205,
17, 79, 173, 243, 112, 46, 204, 146, 211, 141, 111, 49, 178, 236, 14, 80,
175, 241, 19, 77, 206, 144, 114, 44, 109, 51, 209, 143, 12, 82, 176, 238,
50, 108, 142, 208, 83, 13, 239, 177, 240, 174, 76, 18, 145, 207, 45, 115,
202, 148, 118, 40, 171, 245, 23, 73, 8, 86, 180, 234, 105, 55, 213, 139,
87, 9, 235, 181, 54, 104, 138, 212, 149, 203, 41, 119, 244, 170, 72, 22,
233, 183, 85, 11, 136, 214, 52, 106, 43, 117, 151, 201, 74, 20, 246, 168,
116, 42, 200, 150, 21, 75, 169, 247, 182, 232, 10, 84, 215, 137, 107, 53};
#else
int8 j,k,l; // promenne potrebne pro algoritmicky vypocet CRC
#endif
int8 CRC; // prubezne CRC
int8 i;
 
 
#ifdef CRC_TAB
// vypocet CRC tabulkou
CRC=0;
for(i=0;i<num;i++) CRC=TouchCRC[CRC ^ *(sn+i)];
if(CRC!=*(sn+7)) return(0);
else return(1);
#else
// vypocet CRC algoritmicky
CRC=0;
for(i=0 ;i<num;i++) {
k=*(sn+i);
#asm
movlw 8
movwf j // citac bitu
loop:
movf k,W // presun bajt do W
xorwf CRC,W // prixoruj CRC a uloz do w
movwf l
rrf l,F // naxorovany bit do CY
movf CRC,W
btfsc 3.0 // preskoc, je-li CY nulove
xorlw 0x18
movwf CRC
rrf CRC,F // rotuj CRC
rrf k // na dalsi bit
decfsz j,F
goto loop
#endasm
}
if(CRC!=0) return(0);
else return(1);
#endif
}
 
 
// precte seriove cislo z touch memory, vraci TRUE je-li platne (spravne CRC)
//
int8 TM_read_sn(unsigned int8 *sn)
{
int8 i;
// precteni SN z touch memory
TM_write_byte(0x33);
for(i=0;i<8;i++) *(SN+i)=TM_read_byte(); // precti SN do buferu
 
if(*sn==0) return(0); // family kod je nulovy a to je chyba, timto nahrazujeme precteni samych nul, coz ma platne CRC, ale neexistuje
return(TM_check_CRC(SN,8));
}
// End of FIle
 
Property changes:
Added: svn:executable
+*
\ No newline at end of property
/Designs/Measuring_instruments/LCTmetr01A/SW/lib/lcd.c
0,0 → 1,300
// LCD modul pro ovladani dvouradkoveho LCD modulu se standardnim Hitachi radicem
// (c)miho 2002
//
// Historie:
//
// 0.00 Uvodni verze se snadnou definici portu LCD displeje
// 0.01 Oprava portu (zapomenute stare identifikatory)
// 0.02 Doplnena moznost pripojeni datoveho portu LCD na libovolne porty
//
//
// Funkce:
//
// lcd_init() inicializuje LCD displej a porty, nutno volat jako prvni
//
// lcd_putc(c) zapis snaku do lcd displeje, zpracovava nasledujici ridici znaky
// \f = \x0C - nova stranka - smazani displeje
// \n = \x0A - odradkovani (prechod na druhou radku)
// \b = \x08 - backspace - posunuti kurzoru o 1 pozici zpet
// \r = \x0D - goto home to position 1,1
// \0 .. \7 - definovatelne znaky v pozicich 0 az 7 v CGRAM
// \20 .. \27 - alternativne zapsane znaky (oktalove) v pozicich 0 az 7 CGRAM
// Pozor na to, ze funkce printf konci tisk pokud narazi na \0 (konec retezce)
//
// lcd_gotoxy(x,y) presune kurzor na uvedenou adresu
// nekontroluje parametry
//
// lcd_cursor_on zapne kurzor
// lcd_cursor_off vypne kurzor
//
// lcd_define_char(Index, Def) Makro, ktere definuje znaky od pozice Index obsahem definicniho
// retezce Def. Kazdych 8 znaku retezce Def definuje dalsi znak v CGRAM.
// Kapacita CGRAM je celkem 8 znaku s indexem 0 az 7.
// Na konci se provede lcd_gotoxy(1,1).
// Na konci teto knihovny je priklad pouziti definovanych znaku
//
//
// Definice portu: // Datovy port displeje pripojeny na 4 bity za sebou na jeden port
//
// #define LCD_RS PIN_B2 // rizeni registru LCD displeje
// #define LCD_E PIN_B1 // enable LCD displeje
// #define LCD_DATA_LSB PIN_C2 // pripojeni LSB bitu datoveho portu LCD displeje (celkem 4 bity vzestupne za sebou)
//
//
// Alternativni definice: // Datovy port displeje pripojeny na libovolne 4 bitove porty (vede na kod delsi asi o 25 slov)
//
// #define LCD_RS PIN_B2 // rizeni registru LCD displeje
// #define LCD_E PIN_B1 // enable LCD displeje
// #define LCD_D0 PIN_C2 // D0 - datove bity pripojene na libovolne porty
// #define LCD_D1 PIN_C3 // D1
// #define LCD_D2 PIN_C4 // D2
// #define LCD_D3 PIN_C5 // D3
 
 
 
 
// Privatni sekce, cist jen v pripade, ze neco nefunguje
 
 
 
 
#ifdef LCD_DATA_LSB
// Generovane defince portu pro ucely teto knihovny aby kod generoval spravne IO operace a soucasne
// bylo mozne jednoduse deklarovat pripojene piny LCD displeje pri pouziti teto knihovny. Problem spociva
// v tom, ze se musi spravne ridit smery portu a soucasne datovy port zabira jen 4 bity ze zadaneho portu
//
#define LCD_SHIFT (LCD_DATA_LSB&7) // pocet bitu posuvu datoveho kanalu v datovem portu
#define LCD_PORT (LCD_DATA_LSB>>3) // adresa LCD datoveho portu
#define LCD_TRIS (LCD_PORT+0x80) // adresa prislusneho TRIS registru
#define LCD_MASK (0xF<<LCD_SHIFT) // maska platnych bitu
//
#if LCD_SHIFT>4 // kontrola mezi
#error LCD data port LSB bit not in range 0..4
#endif
#endif
 
 
// Definice konstant pro LCD display
//
#define LCD_CURSOR_ON_ 0x0E // kurzor jako blikajici radka pod znakem
#define LCD_CURSOR_OFF_ 0x0C // zadny kurzor
#define LCD_LINE_2 0x40 // adresa 1. znaku 2. radky
 
 
// Definice rezimu LCD displeje
//
BYTE const LCD_INIT_STRING[4] =
{
0x28, // intrfejs 4 bity, 2 radky, font 5x7
LCD_CURSOR_OFF_, // display on, kurzor off,
0x01, // clear displeje
0x06 // inkrement pozice kurzoru (posun kurzoru doprava)
};
 
 
// Odesle nibble do displeje (posle data a klikne signalem e)
//
void lcd_send_nibble( BYTE n )
{
#ifdef LCD_DATA_LSB
// data jsou za sebou na 4 bitech jednoho portu
*LCD_PORT = (*LCD_PORT & ~LCD_MASK) | ((n << LCD_SHIFT) & LCD_MASK); // nastav datove bity portu a ostatni zachovej
#else
// data jsou na libovolnych 4 bitech libovolnych portu
output_bit(LCD_D0,bit_test(n,0));
output_bit(LCD_D1,bit_test(n,1));
output_bit(LCD_D2,bit_test(n,2));
output_bit(LCD_D3,bit_test(n,3));
#endif
output_bit(LCD_E,1); // vzestupna hrana
delay_us(1); // pockej alespon 450ns od e nebo alespon 195ns od dat
output_bit(LCD_E,0); // sestupna hrana (minimalni perioda e je 1us)
}
 
 
// Odesle bajt do registru LCD
//
// Pokud je Adr=0 .. instrukcni registr
// Pokud je Adr=1 .. datovy registr
//
void lcd_send_byte( BOOLEAN Adr, BYTE n )
{
output_bit(LCD_RS,Adr); // vyber registr
swap(n);
lcd_send_nibble(n); // posli horni pulku bajtu
swap(n);
lcd_send_nibble(n); // posli spodni pulku bajtu
delay_us(40); // minimalni doba na provedeni prikazu
}
 
 
// Provede inicializaci LCD displeje, smaze obsah a nastavi mod displeje
//
// Tato procedura se musi volat pred pouzitim ostatnich lcd_ procedur
//
void lcd_init()
{
 
int i; // pocitadlo cyklu
 
delay_ms(20); // spozdeni pro provedeni startu displeje po zapnuti napajeni
 
#ifdef LCD_DATA_LSB
// data jsou na 4 bitech za sebou, nastav smer pro vsechny dalsi prenosy
*LCD_TRIS = *LCD_TRIS & ~LCD_MASK; // nuluj odpovidajici bity tris registru datoveho portu LCD
#endif
 
output_bit(LCD_RS,0); // nastav jako vystup a nastav klidovy stav
output_bit(LCD_E, 0); // nastav jako vystup a nastav klidovy stav
 
for (i=0; i<3; i++) // nastav lcd do rezimu 8 bitu sbernice
{
delay_ms(2); // muze byt rozdelany prenos dat (2x 4 bity) nebo pomaly povel
lcd_send_nibble(3); // rezim 8 bitu
}
 
delay_us(40); // cas na zpracovani
lcd_send_nibble(2); // nastav rezim 4 bitu (plati od nasledujiciho prenosu)
delay_us(40); // cas na zpracovani
 
for (i=0;i<3;i++) // proved inicializaci (nastaveni modu, smazani apod)
{
lcd_send_byte(0,LCD_INIT_STRING[i]);
delay_ms(2);
}
}
 
 
// Proved presun kurzoru
//
// Pozice 1.1 je domu
//
void lcd_gotoxy( BYTE x, BYTE y)
{
 
BYTE Adr;
 
Adr=x-1;
if(y==2)
Adr+=LCD_LINE_2;
 
lcd_send_byte(0,0x80|Adr);
}
 
 
// Zapis znaku na displej, zpracovani ridicich znaku
//
void lcd_putc( char c)
{
 
switch (c)
{
case '\f' : lcd_send_byte(0,1); // smaz displej
delay_ms(2);
break;
case '\n' : lcd_gotoxy(1,2); break; // presun se na 1. znak 2. radky
case '\r' : lcd_gotoxy(1,1); break; // presun home
case '\b' : lcd_send_byte(0,0x10); break; // posun kurzor o 1 zpet
default : if (c<0x20) c&=0x7; // preklopeni definovatelnych znaku na rozsah 0 az 0x1F
lcd_send_byte(1,c); break; // zapis znak
}
}
 
 
// Zapni kurzor
//
void lcd_cursor_on()
{
lcd_send_byte(0,LCD_CURSOR_ON_);
}
 
 
// Vypni kurzor
//
void lcd_cursor_off()
{
lcd_send_byte(0,LCD_CURSOR_OFF_);
}
 
 
// Definice vlastnich fontu
//
// Vlastnich definic muze byt jen 8 do pozic 0 az 7 pameti CGRAM radice lcd displeje
// Pro snadne definovani jsou pripraveny nasledujici definice a na konci souboru je uveden
// priklad pouziti definovanych znaku.
 
 
// Pomocna procedura pro posilani ridicich dat do radice displeje
//
void lcd_putc2(int Data)
{
lcd_send_byte(1,Data);
}
 
 
// Pomocne definice pro programovani obsahu CGRAM
//
#define lcd_define_start(Code) lcd_send_byte(0,0x40+(Code<<3)); delay_ms(2)
#define lcd_define_def(String) printf(lcd_putc2,String);
#define lcd_define_end() lcd_send_byte(0,3); delay_ms(2)
 
 
// Vlastni vykonne makro pro definovani fontu do pozice Index CGRAM s definicnim retezcem Def
//
#define lcd_define_char(Index, Def) lcd_define_start(Index); lcd_define_def(Def); lcd_define_end();
 
 
// Pripravene definice fontu vybranych znaku
// V tabulce nesmi byt 00 (konec retezce v printf()), misto toho davame 80
//
#define LCD_CHAR_BAT100 "\x0E\x1F\x1F\x1F\x1F\x1F\x1F\x1F" /* symbol plne baterie */
#define LCD_CHAR_BAT50 "\x0E\x1F\x11\x11\x13\x17\x1F\x1F" /* symbol polovicni baterie */
#define LCD_CHAR_BAT0 "\x0E\x1F\x11\x11\x11\x11\x11\x1F" /* symbol vybite baterie */
#define LCD_CHAR_UP "\x80\x04\x0E\x15\x04\x04\x04\x80" /* symbol sipka nahoru */
#define LCD_CHAR_DOWN "\x80\x04\x04\x04\x15\x0E\x04\x80" /* symbol Sipka dolu */
#define LCD_CHAR_LUA "\x04\x0E\x11\x11\x1F\x11\x11\x80" /* A s carkou */
#define LCD_CHAR_LLA "\x01\x02\x0E\x01\x1F\x11\x0F\x80" /* a s carkou */
#define LCD_CHAR_HUC "\x0A\x0E\x11\x10\x10\x11\x0E\x80" /* C s hackem */
#define LCD_CHAR_HLC "\x0A\x04\x0E\x10\x10\x11\x0E\x80" /* c s hackem */
#define LCD_CHAR_HUD "\x0A\x1C\x12\x11\x11\x12\x1C\x80" /* D s hackem */
#define LCD_CHAR_HLD "\x05\x03\x0D\x13\x11\x11\x0F\x80" /* d s hackem */
#define LCD_CHAR_LUE "\x04\x1F\x10\x10\x1E\x10\x1F\x80" /* E s carkou */
#define LCD_CHAR_LLE "\x01\x02\x0E\x11\x1F\x10\x0E\x80" /* e s carkou */
#define LCD_CHAR_HUE "\x0A\x1F\x10\x1E\x10\x10\x1F\x80" /* E s hackem */
#define LCD_CHAR_HLE "\x0A\x04\x0E\x11\x1F\x10\x0E\x80" /* e s hackem */
#define LCD_CHAR_LUI "\x04\x0E\x04\x04\x04\x04\x0E\x80" /* I s carkou */
#define LCD_CHAR_LLI "\x02\x04\x80\x0C\x04\x04\x0E\x80" /* i s carkou */
#define LCD_CHAR_HUN "\x0A\x15\x11\x19\x15\x13\x11\x80" /* N s hackem */
#define LCD_CHAR_HLN "\x0A\x04\x16\x19\x11\x11\x11\x80" /* n s hackem */
#define LCD_CHAR_LUO "\x04\x0E\x11\x11\x11\x11\x0E\x80" /* O s carkou */
#define LCD_CHAR_LLO "\x02\x04\x0E\x11\x11\x11\x0E\x80" /* o s carkou */
#define LCD_CHAR_HUR "\x0A\x1E\x11\x1E\x14\x12\x11\x80" /* R s hackem */
#define LCD_CHAR_HLR "\x0A\x04\x16\x19\x10\x10\x10\x80" /* r s hackem */
#define LCD_CHAR_HUS "\x0A\x0F\x10\x0E\x01\x01\x1E\x80" /* S s hackem */
#define LCD_CHAR_HLS "\x0A\x04\x0E\x10\x0E\x01\x1E\x80" /* s s hackem */
#define LCD_CHAR_HUT "\x0A\x1F\x04\x04\x04\x04\x04\x80" /* T s hackem */
#define LCD_CHAR_HLT "\x0A\x0C\x1C\x08\x08\x09\x06\x80" /* t s hackem */
#define LCD_CHAR_LUU "\x02\x15\x11\x11\x11\x11\x0E\x80" /* U s carkou */
#define LCD_CHAR_LLU "\x02\x04\x11\x11\x11\x13\x0D\x80" /* u s carkou */
#define LCD_CHAR_CUU "\x06\x17\x11\x11\x11\x11\x0E\x80" /* U s krouzkem */
#define LCD_CHAR_CLU "\x06\x06\x11\x11\x11\x11\x0E\x80" /* u s krouzkem */
#define LCD_CHAR_LUY "\x02\x15\x11\x0A\x04\x04\x04\x80" /* Y s carkou */
#define LCD_CHAR_LLY "\x02\x04\x11\x11\x0F\x01\x0E\x80" /* y s carkou */
#define LCD_CHAR_HUZ "\x0A\x1F\x01\x02\x04\x08\x1F\x80" /* Z s hackem */
#define LCD_CHAR_HLZ "\x0A\x04\x1F\x02\x04\x08\x1F\x80" /* z s hackem */
 
 
// Priklad pouziti definovanych znaku
//
//
//void lcd_sample()
//{
// lcd_define_char(0,LCD_CHAR_BAT50); // Priklad definice znaku baterie do pozice 0
// lcd_define_char(2,LCD_CHAR_HLE LCD_CHAR_LUI); // Priklad definice znaku e s hackem a I s carkou od pozice 2
// // vsimnete si, ze neni carka mezi retezci s definici (oba retezce definuji
// // jediny definicni retezec)
// printf(lcd_putc,"\fZnaky:\20\22\23"); // priklad vypisu znaku z pozice 0, 2 a 3
// delay_ms(1000);
// lcd_define_char(0,LCD_CHAR_BAT0); // Predefinovani tvaru znaku v pozici 0
// delay_ms(1000);
//}
Property changes:
Added: svn:executable
+*
\ No newline at end of property