当前位置: 首页 > 编程笔记 >

c# 绘制中国象棋棋盘与棋子

奚晟
2023-03-14
本文向大家介绍c# 绘制中国象棋棋盘与棋子,包括了c# 绘制中国象棋棋盘与棋子的使用技巧和注意事项,需要的朋友参考一下

本文是利用C# 实现中国象棋的棋盘绘制,以及初始化布局,并不实现中国象棋的对弈逻辑。仅供学习参考使用。

思路:

  1. 绘制中国象棋棋盘,竖线九条,横线十条。再中间绘制‘楚河',‘汉界' 。
  2. 绘制棋子,然后将棋子布局在棋盘上即可。

涉及知识点:

  1. 用户控件:用于实现棋盘的绘制,重写 OnPaint(PaintEventArgs e) 方法。
  2. Matrix:封装表示几何变换的 3x3 仿射矩阵。本例中主要用于旋转绘制反方的‘汉界'。
  3. GraphicsPath:表示一系列相互连接的直线和曲线。本例中主要用于绘制圆形棋子。

效果图如下:

(一)

(二)

核心代码

棋盘核心代码如下:

protected override void OnPaint(PaintEventArgs e)
  {
   base.OnPaint(e);

   //初始化数组
   InitArrPieceInfo();

   Graphics g = e.Graphics;
   int width = this.Width;
   int height = this.Height;
   int padding = this.Padding.All * 20;
   int center = height / 2;//垂直中心位置
   int s_width = (width - 2 * padding) / 8;//每一条横线的间距
   int s_heigth = (height - 2 * padding) / 9;//每一条竖线的间距
   int start_x = padding;//起始位置
   int start_y = padding;//起始位置
   Pen pen = new Pen(Brushes.Black, 1.5f);
   Dictionary<string, string[]> dicNums = new Dictionary<string, string[]>();
   dicNums.Add("up", new string[9] { "1", "2", "3", "4", "5", "6", "7", "8", "9" });
   dicNums.Add("down", new string[9] { "九", "八", "七", "六", "五", "四", "三", "二", "一" });
   Font font = new Font("宋体", 12, FontStyle.Regular);
   for (int i = 0; i < 9; i++)
   {
    //竖线九条
    Point p0 = new Point(start_x + i * s_width, start_y);
    Point p1 = new Point(start_x + i * s_width, start_y + (s_heigth * 4));
    Point p2 = new Point(start_x + i * s_width, start_y + (s_heigth * 5));
    Point p3 = new Point(start_x + i * s_width, start_y + (s_heigth * 9));
    g.DrawLine(pen, p0, p1);
    g.DrawLine(pen, p2, p3);
    //上下的文字
    Point p_up = new Point(start_x + i * s_width - 5, padding / 2);
    Point p_down = new Point(start_x + i * s_width - 5, start_y + (s_heigth * 9) + padding / 3);
    g.DrawString(dicNums["up"][i], font, Brushes.Black, p_up);
    g.DrawString(dicNums["down"][i], font, Brushes.Black, p_down);
    //数组赋值
    for (int j = 0; j < 10; j++)
    {
     Point absLocation = ArrPiece[i, j].AbsoluteLocation;
     absLocation.X = start_x + i * s_width;
     ArrPiece[i, j].AbsoluteLocation = absLocation;
    }
   }
   for (int i = 0; i < 10; i++)
   {
    //横线十条
    Point p0 = new Point(start_x, start_y + i * s_heigth);
    Point p1 = new Point(start_x + s_width * 8, start_y + i * s_heigth);
    g.DrawLine(pen, p0, p1);
    //数组赋值
    for (int j = 0; j < 9; j++)
    {
     Point absLocation = ArrPiece[j, i].AbsoluteLocation;
     absLocation.Y = start_y + i * s_heigth;
     ArrPiece[j, i].AbsoluteLocation = absLocation;
    }
   }
   //绘制九宫格
   for (int i = 0; i < 2; i++)
   {
    Point p0 = new Point(start_x + (3 + i * 2) * s_width, start_y);
    Point p1 = new Point(start_x + (5 - i * 2) * s_width, start_y + (s_heigth * 2));
    Point p2 = new Point(start_x + (3 + i * 2) * s_width, start_y + (s_heigth * 7));
    Point p3 = new Point(start_x + (5 - i * 2) * s_width, start_y + (s_heigth * 9));
    g.DrawLine(pen, p0, p1);
    g.DrawLine(pen, p2, p3);
   }

   //兵和卒处有拐角,从左往右
   for (int i = 0; i < 5; i++)
   {
    int p_x = start_x + 2 * i * s_width;
    int p_y = start_y + 3 * s_heigth;
    DrawCorner(g, pen, p_x, p_y);//兵
    p_y = start_y + 6 * s_heigth;
    DrawCorner(g, pen, p_x, p_y);//卒
   }
   //炮处的拐角,从左往右
   for (int i = 0; i < 2; i++)
   {
    int p_x = start_x + (1 + 6 * i) * s_width;
    int p_y = start_y + 2 * s_heigth;
    DrawCorner(g, pen, p_x, p_y);//炮
    p_y = start_y + 7 * s_heigth;
    DrawCorner(g, pen, p_x, p_y);//炮
   }
   //绘制楚河汉界
   Point p_0 = new Point(2 * s_width, center - 25);
   Point p_1 = new Point(7 * s_width, center + 20);
   font = new Font("方正隶二繁体", 30, FontStyle.Regular);
   g.DrawString("楚河", font, Brushes.Black, p_0);
   Matrix mtxSave = g.Transform;
   Matrix mtxRotate = g.Transform;
   mtxRotate.RotateAt(180, p_1);
   g.Transform = mtxRotate;
   g.DrawString("汉界", font, Brushes.Black, p_1);
   g.Transform = mtxSave;
   //绘制外边框
   g.DrawRectangle(pen, 3, 3, width - 6, height - 6);
   g.DrawRectangle(pen, 5, 5, width - 10, height - 10);
   g.DrawRectangle(pen, 7, 7, width - 14, height - 14);
  }

棋子核心代码如下:

protected override void OnPaint(PaintEventArgs e)
  {
   base.OnPaint(e);
   Graphics g = e.Graphics;
   GraphicsPath gPath = new GraphicsPath();
   // Set a new rectangle to the same size as the button's ClientRectangle property.
   Rectangle rectangle = this.ClientRectangle;
   g.DrawEllipse(new Pen(this.FlatAppearance.BorderColor), rectangle);
   gPath.AddEllipse(rectangle);

   // Set the button's Region property to the newly created circle region.
   this.Region = new Region(gPath);
   Rectangle inRect = new Rectangle(2, 2, this.Width - 4, this.Height - 3);
   g.FillEllipse(new SolidBrush(this.BackColor), rectangle);
   g.DrawEllipse(new Pen(Color.Black,2), inRect);

   Font font = new Font("楷体", 25, FontStyle.Regular);
   g.DrawString(this.Text, font, new SolidBrush(this.ForeColor), 0,5);
  }

以上就是c# 绘制中国象棋棋盘与棋子的详细内容,更多关于c# 绘制棋盘与棋子的资料请关注小牛知识库其它相关文章!

 类似资料:
  • 本文向大家介绍java绘制五子棋棋盘,包括了java绘制五子棋棋盘的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了java绘制五子棋棋盘的具体代码,供大家参考,具体内容如下 源码: 效果图: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 我已经有一个Board对象,包含一个碎片列表。Piece是一个抽象类,有一个位置(x,y)和一个颜色(黑色或白色)。然后是King、Queen、Knight这三个类,实现了Piece类。 谢谢

  • 我正在使用在固定深度工作的alpha-beta修剪算法对Chess AI进行编程。我相当惊讶地看到,通过将AI设置为更高的深度,它玩得更糟。但我认为我想通了为什么会这样。 它目前是这样工作的:所有的职位都被列出来了,对于每个职位,其他的职位都会被列出来,以此类推。。。直到达到固定深度:通过检查存在哪些工件,并为每种工件类型设置一个值来评估电路板。然后,使用带有alpha-beta的minimax算

  • 上面的代码显示了一个可以上下移动的部分的示例。这不是一个有效的棋步。所以,如果我要移动一个皇后,我该怎么做呢?我们只是假设我们已经有了一个矩阵(x,y)8×8的板。

  • 本文向大家介绍python输出国际象棋棋盘的实例分享,包括了python输出国际象棋棋盘的实例分享的使用技巧和注意事项,需要的朋友参考一下 国际象棋是当今国际上最流行的智力体育运动项目。青年人下棋可以锻炼思维、增强记忆力和培养坚强的意志;中年人下棋可以享受美学;老年下棋可以很好的休息娱乐。国际象棋游戏有自己的规则,需要两个人将棋子落在棋盘上。 棋子落在棋盘上事件,在计算机看来,是一段程序,而这些程

  • 我目前正在编写我的第一盘国际象棋,我的棋子有一个小问题。我将在下面添加一些代码,但通常我想检查玩家移动某个棋子(在本例中为国王)的棋盘是否已经被另一个棋子占据,因为在这种情况下,另一个棋子将被杀死(如果棋子属于另一个玩家),或者移动是错误的(棋子被自己的棋子占据)。如果你对如何做有任何想法,我将不胜感激。顺致敬意, 公共抽象类文章{ } 公共类国王延伸件{ }