forked from aybaras/VGA-based-screensaver
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate_square_pos.vhd
97 lines (72 loc) · 2.56 KB
/
update_square_pos.vhd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.NUMERIC_STD.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
entity update_square_pos is
port(
Clk : in STD_LOGIC;
Enable : in STD_LOGIC;
x : out integer range 0 to 639;
y : out integer range 0 to 479;
color : out STD_LOGIC_VECTOR(7 downto 0)
);
end update_square_pos;
architecture Behavioral of update_square_pos is
-- constant screen_width : integer := 640;
-- constant screen_height : integer := 480;
-- constant ball_width : integer := 60;
-- constant ball_height : integer := 60;
-- constant ball_width_half : integer := 30;
-- constant ball_height_half : integer := 30;
signal x_pos : integer range 0 to 639 := 320;
signal y_pos : integer range 0 to 479 := 240;
signal count : STD_LOGIC_VECTOR(2 downto 0) := (others => '0');
signal t_color : STD_LOGIC_VECTOR(7 downto 0) := (others => '0');
begin
update_sqr_pos_process : process(Enable)
variable direction : STD_LOGIC_VECTOR(1 downto 0) := (others => '0');
-- "00" : Down-Left -- "01" : Down-Right
-- "10" : Up-Left -- "11" : Up-Right
begin
if rising_edge(Clk) then
if Enable = '1' then
count <= count + 1;
if count = "111" then
t_color <= t_color + 1;
-- Check if the ball hits either the left or the right wall.
if x_pos = 20 or x_pos = 619 then
case direction is
when "00" => direction := "01";
when "01" => direction := "00";
when "10" => direction := "11";
when others => direction := "10";
end case;
end if;
-- Check if the ball hits either the bottom or the top wall (aka floor or ceiling).
if y_pos = 20 or y_pos = 459 then
case direction is
when "00" => direction := "10";
when "01" => direction := "11";
when "10" => direction := "00";
when others => direction := "01";
end case;
end if;
-- Move the ball 60/16 = 4 FPS (frames per second).
case direction is
when "00" => x_pos <= x_pos - 1; y_pos <= y_pos + 1;
when "01" => x_pos <= x_pos + 1; y_pos <= y_pos + 1;
when "10" => x_pos <= x_pos - 1; y_pos <= y_pos - 1;
when others => x_pos <= x_pos + 1; y_pos <= y_pos - 1;
end case;
count <= (others => '0');
end if;
end if;
end if;
x <= x_pos - 20;
y <= y_pos - 20;
color <= t_color;
end process update_sqr_pos_process;
-- x <= 320;
-- y <= 240;
end Behavioral;