首先,要制作贪吃蛇游戏,就需要先了解它的游戏规则还有特点:
通过键盘上下左右控制蛇的方向,寻找吃的东西,每吃一口就能得到一定的积分,而且蛇的身子会越吃越长,身子越长玩的难度就越大,而且蛇的速度越来越快,不能碰墙,不能咬到自己的身体,更不能咬自己的尾巴。
需求分析:游戏的主界面,游戏开始的界面,显示得分的界面,蛇和食物的设计。
游戏界面需要合理使用各种控件布局,蛇移动的区域应该是两种颜色交替排布的方格组成,这样才能清晰的看见蛇的移动,也是为了增加游戏体验。
蛇的设计:根据面向对象的设计思想,可以以一个方格为单位,然后多个方格就可以组成一条蛇了,为了区分蛇头和蛇身,还需要加一个bool类型的字段判断这方格是不是蛇头。
源文件及说明
<Window x:Class="WpfApp1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:WpfApp1"
mc:Ignorable="d"
Title="WPF 贪吃蛇:0"
SizeToContent="WidthAndHeight"
Loaded="Window_Loaded"
ContentRendered="Window_ContentRendered" KeyUp="Window_KeyUp" WindowStyle="None" ResizeMode="NoResize" MouseLeftButtonDown="Window_MouseLeftButtonDown"
>
<DockPanel Background="Black">
<Grid DockPanel.Dock="Top" Name="pnlTitleBar">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="Auto"/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<Grid.Resources>
<Style TargetType="TextBlock">
<Setter Property="FontFamily" Value="Consolas"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="FontSize" Value="24"/>
<Setter Property="FontWeight" Value="Bold"/>
</Style>
<Style TargetType="Button">
<Setter Property="Background" Value="Transparent"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="FontWeight" Value="Bold"/>
<Setter Property="FontSize" Value="20"/>
<Setter Property="BorderThickness" Value="0"/>
<Setter Property="Padding" Value="10,0"/>
</Style>
</Grid.Resources>
<WrapPanel Margin="10,0,0,0">
<TextBlock>Score:</TextBlock>
<TextBlock x:Name="tbStatusScore">0</TextBlock>
</WrapPanel>
<WrapPanel Grid.Column="1">
<TextBlock>Speed:</TextBlock>
<TextBlock x:Name="tbStatusSpeed">0</TextBlock>
</WrapPanel>
<Button Focusable="False" Visibility="Hidden" x:Name="btPause" Grid.Column="2" Content="II" Background="Transparent" Click="BtPause_Click"/>
<Button Grid.Column="3" Content="X" Background="Transparent" Click="Button_Click"/>
</Grid>
<Border BorderThickness="5" BorderBrush="Black">
<Canvas x:Name="GameArea" ClipToBounds="True" Width="400" Height="400">
<Border Visibility="Collapsed" Panel.ZIndex="1" x:Name="bdrWelcomeMessage" Width=