x01.Weiqi.7: 调整重绘

GitHub

谁方便谁拍,谁重要拍谁。在这个砖头满天飞的时代,一个好的生态显得尤为重要。

      红颜小头发,要的很简单。

    也许成绝唱,只因鱼心火。

姚贝福娃的离去,除感叹人生无常外,活着做点有意义的事情,同样显得尤为重要。

数年前为学习人工智能,写了围棋程序,却发现其难度超出了我的想象。特将其放到 GitHub 上,希望有人斧正。注意,是斧正,而非小修小改。

调整重绘

窗口大小改变时,棋盘也要作相应的重绘。这个比较简单,我的方法是把 BoardBase 类中的 m_sbSteps 字段改成 public,在主窗口 MainWindows 中保存之。具体的操作参考了 StepBoard 类中的办法,复制粘贴,略作修改而已,代码如下:

 1     // For Size Change and Show Number
 2
 3         List<StepContent> m_steps = new List<StepContent>();
 4         public void FillSteps()
 5         {
 6             m_steps.Clear();
 7             string s = m_sbSteps.ToString();
 8             if (s.Length < 1) return;
 9             string[] steps = s.Substring(0, s.Length - 1).Split(‘,‘);
10             StepContent step = new StepContent();
11             for (int i = 0; i < steps.Length; i++)
12             {
13                 if (i % 3 == 0)
14                 {
15                     step = new StepContent();
16                     step.Col = Convert.ToInt32(steps[i]);
17                 }
18                 else if (i % 3 == 1)
19                 {
20                     step.Row = Convert.ToInt32(steps[i]);
21                 }
22                 else if (i % 3 == 2)
23                 {
24                     step.Count = Convert.ToInt32(steps[i]);
25                     m_steps.Add(step);
26                 }
27             }
28         }
29         public void RenderChess()
30         {
31             m_sbSteps.Clear();
32             foreach (var item in m_steps)
33             {
34                 NextOne();
35             }
36         }
37
38         int m_count = 1;
39         public void NextOne()
40         {
41             if (m_count > m_steps.Count)
42             {
43                 return;
44             }
45
46             foreach (var item in m_steps)
47             {
48                 if (item.Count == m_count)
49                 {
50                     int col = item.Col;
51                     int row = item.Row;
52
53                     if (Steps[col, row].Color != ChessColor.Empty)
54                     {
55                         return;
56                     }
57
58                     if (NotInPos.X == col && NotInPos.Y == row)
59                     {
60                         return;
61                     }
62                     else
63                     {
64                         // If Pos(struct) is property, must use new.
65                         NotInPos = new Pos(-1, -1);
66                     }
67
68                     DrawChess(col, row);
69
70                     Eat(col, row);
71                 }
72             }
73             m_count++;
74         }
75
76         public bool IsShowNumber { get; set; }

for size change

显示步数

为了显示步数,在 Chess 类中加了几个属性,然后在 BoardBase 的 DrawChess 方法中也作了相应的调整。代码如下:

 1 public string NumberText
 2         {
 3             get { return m_TxtNumber.Text; }
 4             set { m_TxtNumber.Text = value; }
 5         }
 6
 7         public double NumberFontSize
 8         {
 9             get { return m_TxtNumber.FontSize; }
10             set { m_TxtNumber.FontSize = value; }
11         }
12
13         public System.Windows.Thickness NumberPadding
14         {
15             get { return m_TxtNumber.Padding; }
16             set { m_TxtNumber.Padding = value; }
17         }

Chess properties

 1     if (Steps[col, row].Chess == null)
 2             {
 3                 Chess chess = new Chess(brush, ChessSize);
 4                 if (IsShowNumber)
 5                 {
 6                     double size = (double)ChessSize;
 7                     chess.NumberFontSize = (m_StepCount + 1) > 99
 8                         ? size / 2 : (m_StepCount + 1) > 9
 9                         ? size / 1.6 : size / 1.2;
10                     chess.NumberPadding = (m_StepCount + 1) > 99
11                         ? new Thickness(size/28, size / 5.5, 0, 0) : (m_StepCount + 1) > 9
12                         ? new Thickness(size / 8, size / 8, 0, 0) : new Thickness(size / 4, 0, 0, 0);
13                     chess.NumberText = (m_StepCount + 1).ToString();
14                     chess.NumberBrush = (m_StepCount % 2 == 1) ? Brushes.Black : Brushes.White;
15                 }
16                 chess.SetShow(IsShowNumber);
17                 Canvas.SetLeft(chess, left);
18                 Canvas.SetTop(chess, top);
19                 m_Canvas.Children.Add(chess);
20                 Steps[col, row].Chess = chess;
21             }

in the DrawChess()

效果图

代码下载链接:https://github.com/chinax01/x01.Weiqi

时间: 2024-10-25 03:39:01

x01.Weiqi.7: 调整重绘的相关文章

浏览器的重绘与重排

在项目的交互或视觉评审中,前端同学常常会对一些交互效果质疑,提出这样做不好那样做不好.主要原因是这些效果通常会产生一系列的浏览器重绘(redraw)和重排(reflow),需要付出高昂的性能代价.那么,什么是浏览器的重绘和重排呢?二者何时发生以及如何权衡?如何在具体的开发过程中将重绘和重排引发的性能问题考虑进去?本文期待可以部分解释以上三个问题. 浏览器从下载文档到显示页面的过程是个复杂的过程,这里包含了重绘和重排.各家浏览器引擎的工作原理略有差别,但也有一定规则.简单讲,通常在文档初次加载时,

x01.Weiqi.12: 定式布局

定式 下一步当将定式保存到数据库中,如布局中的代码所示,但其初始的代码更有利于理解.以小飞挂为例: // 0 // + 0 0 // + // // + List<Pos> P_LuStar_UpFlyOne { get { var temp = new List<Pos>(); temp.Add(new Pos(3, 3)); // 第一步:左上星 temp.Add(new Pos(2, 5)); // 第二步:小飞挂 temp.Add(new Pos(5, 2)); // 第三

浏览器的重绘和重排(转)

浏览器从下载文档到显示页面的过程是个复杂的过程,这里包含了重绘和重排.各家浏览器引擎的工作原理略有差别,但也有一定规则.简单讲,通常在文档初次加载时,浏览器引擎会解析HTML文档来构建DOM树,之后根据DOM元素的几何属性构建一棵用于渲染的树.渲染树的每个节点都有大小和边距等属性,类似于盒子模型(由于隐藏元素不需要显示,渲染树中并不包含DOM树中隐藏的元素).当渲染树构建完成后,浏览器就可以将元素放置到正确的位置了,再根据渲染树节点的样式属性绘制出页面.由于浏览器的流布局,对渲染树的计算通常只需

窗体皮肤实现 - 重绘窗体非客户区(二)

第一个实现了基本处理.窗体边框的宽度有些肥大,需要进行瘦身. 实现:     1.改变外框线宽度 (WM_NCCALCSIZE)     2.改变外框样式 (WM_WINDOWPOSCHANGING) 通过 WM_NCCALCSIZE 消息可以实现目的. procedure WMNCCalcSize(var message: TWMNCCalcSize); message WM_NCCALCSIZE; procedure TTest.WMNCCalcSize(var message: TWMNC

WinForm中重绘TabControl选项卡标题

最近开发WinForm频繁使用了TabControl控件,这个控件的选项卡没有BackgroundImage这个属性,那么如何为其各个选项卡添加背景图片呢?(这里说的是每个TabPage的头部,也就是标题,不是工作区域.) 最开始用到TabControl的时候,我的每个选项卡是写死的,而后由于项目需求又动态添加了TabControl并生成各个选项卡,而两次我都要重绘其标题,因此在这里把我当时两种情形下重绘的方法通过一个例子一起分享出来. 首先先在窗体拖个Tabcontrol控件,然后更改了其Al

浏览器渲染页面的过程,以及重绘与重排

浏览器的渲染过程 1,浏览器解析html源码,然后创建一个 DOM树.在DOM树中,每一个HTML标签都有一个对应的节点,并且每一个文本也都会有一个对应的文本节点.DOM树的根节点就是 documentElement,对应的是html标签. 2,浏览器解析CSS代码,计算出最终的样式数据.对CSS代码中非法的语法她会直接忽略掉.解析CSS的时候会按照如下顺序来定义优先级:浏览器默认设置,用户设置,外链样式,内联样式,html中的style. 3,构建出DOM树,并且计算出样式数据后,下一步就是构

浏览器的重绘repaints与重排reflows深入分析

重绘是一个元素外观的改变所触发的浏览器行为,浏览器会根据元素的新属性重新绘制,使元素呈现新的外观,接下来将详细介绍,需要了解的朋友可以参考下: 在项目的交互或视觉评审中,前端同学常常会对一些交互效果质疑,提出这样做不好那样做不好.主要原因是这些效果通常会产生一系列的浏览器重绘和重排,需要付出高昂的性能代价.那么,什么是浏览器的重绘和重排呢?二者何时发生以及如何权衡?如何在具体的开发过程中将重绘和重排引发的性能问题考虑进去?本文期待可以部分解释以上三个问题. 浏览器从下载文档到显示页面的过程是个复

深入Windows窗体原理及控件重绘技巧

之前有学MFC的同学告诉我觉得Windows的控件重绘难以理解,就算重绘成功了还是有些地方不明白,我觉得可能很多人都有这样的问题,在这里我从Windows窗体的最基本原理来讲解,如果你有类似的疑惑希望这篇文章可以帮你解惑. 1.Windows窗体原理 首先,如果看过Win32 SDK编程的都知道Windows的三大核心系统:负责窗口对象产生和消息分发的USER模块,负责图像显示绘制的GDI模块,负责内存.进程.IO管理的KERNEL模块.试想象一下如何在一个像素阵列上产生窗口对象,其实就是使用G

浏览器的重绘(repaints)与重排(reflows)

转:http://www.css88.com/archives/4991#more-4991 在项目的交互或视觉评审中,前端同学常常会对一些交互效果质疑,提出这样做不好那样做不好.主要原因是这些效果通常会产生一系列的浏览器重绘和重排,需要 付出高昂的性能代价.那么,什么是浏览器的重绘和重排呢?二者何时发生以及如何权衡?如何在具体的开发过程中将重绘和重排引发的性能问题考虑进去?本文期 待可以部分解释以上三个问题. 浏览器从下载文档到显示页面的过程是个复杂的过程,这里包含了重绘和重排.各家浏览器引擎