我发现教程上LCD1602 和 LCD12864 关于显示字符个数计数的方法不一样
LCD1602 是将计数在状态机语句中直接累加实现
write_ram2:
begin
if(char_cnt <=5'd26)
begin
char_cnt <= char_cnt + 1'b1;
lcd_rs<=1'b1;
lcd_data <= data_disp;
state <= write_ram2;
end
else
begin
char_cnt <=5'd0;
state <= shift;
end
end
LCD12864 则将计数器cnt单独写在了一个always语句中
always @(posedge sys_clk)
begin
if(clk_div)
begin
if(cnt_rst)
cnt <= 10'd0;
else if(state == wr_data_2 || state == wr_data_4 || state == wr_data_6 || state == wr_data_8)
cnt <= cnt + 1'b1;
end
end
而且当我尝试将LCD12864 的字符计数cnt也写在状态机语句中时候,出现了错误,显示结果很不规律,感觉像是cnt计数失败
这是为什么呢?谢谢!
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |