共阴极数码管60秒表显示

#include <reg52.h>

unsigned char segcode[10]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
unsigned char shiwei[6] = {0x3F,0x06,0x5B,0x4F,0x66,0x6D};
unsigned char bitcode[8] = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f}; //??
 // 0-9

#define Dataport P0 
sbit Latch_seg = P2^2;
sbit Latch_bit = P2^3;

void delay_1s()
{
    unsigned char i;
    for(i = 0; i < 20; i++)
    {
        while(!TF0);
        TF0 = 0;   //???
        TH0 = 0x3c;
        TL0 = 0xb0;

    }

}

void delay_10s()
{
    unsigned char i,j;
    for(j = 0; j < 10; j++)
    {
        for(i = 0; i < 20; i++)
        {
            while(!TF0);
            TF0 = 0;   
            TH0 = 0x3c;
            TL0 = 0xb0;

        }
    }   

}
void displaygewei(unsigned char firstbit,unsigned char num)  //从第几个数开始显示,控制几个数码管
{
    unsigned char i;
    while(1)
    {
        Dataport = 0;
        Latch_seg = 1;
        Latch_seg = 0;


        Dataport = segcode[i];
        Latch_seg = 1;
        Latch_seg = 0;
    //  Dataport = ~w;

        Dataport = bitcode[i + firstbit];   
        Latch_bit = 1;
        Latch_bit = 0;
        delay_1s();
    //  w <<= 1;
        i++;
        if(i == num)
        {
            i = 0;
    //      w = 0x01;
        }

    }   
}

/*void displayshiwei(unsigned char firstbit,unsigned char num)  //从第几个数开始显示,控制几个数码管
{
    unsigned char i;
    while(1)
    {
        Dataport = 0;
        Latch_seg = 1;
        Latch_seg = 0;


        Dataport = shiwei[i];
        Latch_seg = 1;
        Latch_seg = 0;
    //  Dataport = ~w;

        Dataport = bitcode[i + firstbit];   
        Latch_bit = 1;
        Latch_bit = 0;
        delay_1s();
    //  w <<= 1;
        i++;
        if(i == num)
        {
            i = 0;
    //      w = 0x01;
        }

    }   
}*/
void main()
{
    unsigned char i,firstbit,num,w;
    firstbit = 0,num = 2;
    w = 0x01;

    TMOD = 0x01;  //方式1
    TH0 = 0x3c;
    TL0 = 0xb0;
    TR0 = 1;   
    while(1)
    {

        for(i = 0; i < 10; i++)
        {
            w = 0x01;

        Dataport = segcode[i];
        Latch_seg = 1;
        Latch_seg = 0;
        Dataport = ~w;
        Latch_bit = 1;
        Latch_bit = 0;
        delay_1s();
        w <<= 1;
        i++;
        if(i == 8)
        {
            i = 0;
            w = 0x01;
        }


        }
        for(i = 0; i < 6; i++)
        {
            w = 0x01;


        Dataport = segcode[i];
        Latch_seg = 1;
        Latch_seg = 0;
        Dataport = ~w;
        Latch_bit = 1;
        Latch_bit = 0;
        delay_10s();
        w <<= 1;
        i++;
        if(i == 8)
        {
            i = 0;
            w = 0x01;
        }

        }       


    }
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
以下是一个简单的Verilog代码,实现了数字秒表程序,测量范围为0-100s,有效数字达到0.01s,测试结果用阴极数码管显示。 ``` module stopwatch( input clk, input rst, output reg [3:0] seg, // 输出阴极数码管的段选信号 output reg [7:0] digit // 输出阴极数码管的位选信号 ); reg [15:0] count = 0; // 计数器,用于计算时间,初始值为0 reg [15:0] tick = 500000; // 每个时钟周期的计数值,用于控制时间 always @(posedge clk) begin if (rst) begin // 复位 count <= 0; seg <= 4'b1111; // 数码管显示 digit <= 8'b11111110; // 数码管第一位选通 end else begin if (count == 10000) begin // 达到100s,停止计时 seg <= 4'b1111; // 数码管显示 digit <= 8'b11111110; // 数码管第一位选通 end else begin count <= count + 1; // 计数器加1 if (count % tick == 0) begin // 达到一个时钟周期 seg <= count[3:0]; // 将个位数码显示数码管 digit <= 8'b11111101; // 数码管第二位选通 seg <= count[7:4]; // 将十位数码显示数码管 digit <= 8'b11111011; // 数码管第三位选通 seg <= count[11:8]; // 将百位数码显示数码管 digit <= 8'b11110111; // 数码管第四位选通 end end end end endmodule ``` 该代码使用了一个计数器 `count` 来计算时间,初始值为0。每次时钟上升沿触发,计数器加1。当计数器达到10000时,即100s,停止计时。 每个时钟周期的计数值 `tick` 为500000,可以根据时钟频率进行调整,以实现0.01s的精度。在每个时钟周期内,判断计数器是否达到一个时钟周期,若达到,则将个位、十位、百位数码分别显示数码管上,同时控制数码管的位选信号,以便逐个显示。 由于使用的是阴极数码管,因此需要将 `seg` 和 `digit` 的输出信号反向,即输出低电平时对应的数码管段或位被选通,并显示相应的数字。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

XuLujuncsdn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值