用verilog语言实现一个8x8点阵的变换,点阵可以顺时针或逆时针旋转,也可以用红灯或绿灯显示,显示的是一个风车的形状!
3'b101:begin col=8'b00100000; left=8'b11110110; right=8'b11111111; end 3'b110:begin col=8'b01000000; left=8'b11101110; right=8'b11111111; end 3'b111:begin col=8'b10000000; left=8'b10011111; right=8'b11111111; end endcase
else if(cnt<=2048) case(a) 3'b0:begin col=8'b00000001; left=8'b01111100; right=8'b11111111; end 3'b1:begin col=8'b00000010; left=8'b01111011; right=8'b11111111; end 3'b10:begin col=8'b00000100; left=8'b10110111; right=8'b11111111; end 3'b11:begin col=8'b00001000; left=8'b11000111; right=8'b11111111; end 3'b100:begin col=8'b00010000; left=8'b11100011; right=8'b11111111; end 3'b101:begin col=8'b00100000; left=8'b11101101; right=8'b11111111; end 3'b110:begin col=8'b01000000; left=8'b11011110; right=8'b11111111; end 3'b111:begin col=8'b10000000; left=8'b00111110; right=8'b11111111; end endcase else begin col=8'b00000000; left=8'b11111111; right=8'b11111111; end
if(cnt>=2048)
cnt=0; else cnt=cnt+1;
case(cnt_turn) 1'b0:begin if(a==7) a=0; else a=a+1; end 1'b1:begin if(a==0) a=7; else a=a-1; end
endcase if(cnt_color)
{left[7:0],right[7:0]}={right[7:0],left[7:0]}; end
assign out[7:0]= {col[7],~col[6],~col[5],col[4],
col[3],~col[2],~col[1],col[0]};
assign out[15:8]={~left[7],~left[6],left[5],~left[4],
~left[3],left[2],~left[1],~left[0]};
assign out[23:16]={~right[7],~right[6],right[5],
~right[4],~right[3],right[2],~right[1],~right[0]}; endmodule
百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库verilog点阵模式显示(2)在线全文阅读。
相关推荐: