/*****************************************************
This program was produced by the
CodeWizardAVR V1.25.5 Standard
Automatic Program Generator
© Copyright 1998-2007 Pavel Haiduc, HP InfoTech s.r.l.
http://www.hpinfotech.com
Project :
Version :
Date : 28/12/2012
Author : DODIT
Company : ITATS
Comments:
Chip type :
ATmega16
Program type :
Application
Clock frequency :
8.000000 MHz
Memory model :
Small
External SRAM size :
0
Data Stack size :
256
*****************************************************/
#include
#include
// Declare your global variables here
//void display(angka):
//unsigned char bin7seg(unsigned char c/*,char status*/);
unsigned char bin7seg(unsigned char c/*,char status*/)
{
//char
d7seg_dt_off[10]={0X3F,0X06,0X5B,0X4F,0X66,0X6D,0X7D,0X07,0X7F,0X6F}; //CK
// char d7seg_dt_on[10]=
{0XBF,0X86,0XDB,0XCF,0XE6,0XED,0XFD,0X87,0XFF,0XEF};
char
d7seg_dt_off[10]={0XC0,0XF9,0XA4,0XB0,0X99,0X92,0X82,0XF8,0X80,0X90}; //CA
// char d7seg_dt_on[10]=
{0XBF,0X86,0XDB,0XCF,0XE6,0XED,0XFD,0X87,0XFF,0XEF};
//if (status)
return
d7seg_dt_off[c];
//else
// return
d7seg_dt_off[c];
}
void display(int angka)
{
char i;
unsigned char sat.pul.rat,rib;
rib=angka/1000;
angka%=1000;
rat=angka/100;
angka%=100;
pul=angka/10;
sat=angka%10;
for(i=0;i<20 i="i" p="p">
{
PORTC=bin7seg(rib);
//PORTB=0xFE;
//PORTB=0x7F;
PORTB.3=0;
PORTB.2=1;
PORTB.1=1;
PORTB.0=1;
delay_ms(5);
//
PORTC=bin7seg(rat);
//
PORTB=0xFB;
//PORTB=0xBF;
PORTB.3=1;
PORTB.2=0;
PORTB.1=1;
PORTB.0=1;
delay_ms(5);
//
PORTC=bin7seg(pul);
//
PORTB=0xEF;
//PORTB=0xDF;
PORTB.3=1;
PORTB.2=1;
PORTB.1=0;
PORTB.0=1;
delay_ms(5);
//
PORTC=bin7seg(sat); // satuan
// PORTB=0xBF;
//PORTB=0xEF;
PORTB.3=1;
PORTB.2=1;
PORTB.1=1;
PORTB.0=0;
delay_ms(5);
}
}
void main(void)
{
// Declare your local variables here
int i=0;
// Input/Output Ports initialization
// Port A initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In
Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T
State1=T State0=T
PORTA=0xFF;
DDRA=0xFF;
// Port B initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In
Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T
State1=T State0=T
PORTB=0xFF;
DDRB=0xff;
// Port C initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In
Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T
State1=T State0=T
PORTC=0xff;
DDRC=0xff;
// Port D initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In
Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T
State1=T State0=T
PORTD=0xff;
DDRD=0xff;
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
// Mode: Normal top=FFh
// OC0 output: Disconnected
TCCR0=0x00;
TCNT0=0x00;
OCR0=0x00;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: Timer 1 Stopped
// Mode: Normal top=FFFFh
// OC1A output: Discon.
// OC1B output: Discon.
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer 1 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=0x00;
TCCR1B=0x00;
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer 2 Stopped
// Mode: Normal top=FFh
// OC2 output: Disconnected
ASSR=0x00;
TCCR2=0x00;
TCNT2=0x00;
OCR2=0x00;
// External Interrupt(s) initialization
// INT0: Off
// INT1: Off
// INT2: Off
MCUCR=0x00;
MCUCSR=0x00;
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x00;
// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
ACSR=0x80;
SFIOR=0x00;
while (1)
{
for(i=0;i<10 i="i" p="p">
20>
{
display(i);
// delay_ms(500);
}
};
}
10>