代码实现ts: 1 'use strict' module Main { const FloorType = { space: "space", snack: "body", food: "food" } const enum Direction { left = 37, up = 38, right = 39, down = 40 } interface Block { pos: Pos type: string node: HTMLEleme…
最近遇到一个问题: year amount num 1991 1 1.1 1991 2 1.2 1991 3 1.3 1992 1 2.1 1992 2 2.2 1992 3 3.3 把上面表格的数据查询成: year m1 m2 m3 1991 1.1 1.2 1.3 1992 2.1 2.2 2.3 看到这样的需求,首先想到的是用case去统计以及 用group by来分组 第一版sql代码: SELECT `year`, ( THEN num END) AS n1, ( THEN num…
TypeScript是一种由微软开发的自由和开源的编程语言.它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程.安德斯·海尔斯伯格,C#的首席架构师,已工作于TypeScript的开发.2012年十月份,微软发布了首个公开版本的TypeScript,2013年6月19日,在经历了一个预览版之后微软正式发布了正式版TypeScript 0.9,向未来的TypeScript 1.0版迈进了很大一步.——摘自百度百科 我个人感觉这个最大的优势就是建模比较…
C++编写贪吃蛇小游戏快速入门 刚学完C++.一时兴起,就花几天时间手动做了个贪吃蛇,后来觉得不过瘾,于是又加入了AI功能.希望大家Enjoy It. 效果图示 AI模式演示 imageimage 整体规划+原理 image 大体上可以分为图上所示的几个类.不过……怎么看都有点强行面向对象的味道在里面..[哭笑][哭笑][哭笑].不管了……代码写得可能有点凌乱,下面我会为大家一一讲解. 整个程序设计的原理就是:主函数死循环,不断刷新打印贪吃蛇和食物.这样每循环一次,就类似电影里面的一帧,最终显示…
前言 上一篇<小菜学习Winform(一)贪吃蛇>中实现了简单版的贪吃蛇,在文章末也提到需要优化的地方,比如使用oo.得分模式.速度加快模式和减少界面重绘.因为是优化篇,实现方式上一篇有,这一篇大家看看代码就行.当然小菜不是搞游戏开发的,程序可能有很多问题,这里点到即止,有时间小菜会加强学习. 实现 说到oo可能一说一大堆,这里面小菜只是简单的把贪吃蛇抽象出来,先来说蛇,具有的属性和行为,属性比如蛇的长度.蛇的宽度.蛇的行动方向等:行为比如是否吃到食物.是否撞墙等,那我们可以抽象一个蛇的类,这…
由于食物是贪吃蛇游戏中最简单的一部分,而且和其他部分关联性不强,基本上是一个独立的部分,所以我打算先实现它. 我的想法是食物必须在世界中才能被创造出来,也就是说,先有世界再有食物,所以我得先判断世界是否存在,存在的话才可以创建食物. Food * SNK_CreateFood(World *world, int size) { Food *food; ) ; ) ; INIT_FOOD(world, size); return food; } 对于指针变量,我总是显式地将它和数值比较,这有助于避…
游戏中的食物没有那么多复杂属性,特别是贪吃蛇游戏中,我把食物看待的很简单: 1. 它必须属于世界,才能出现在世界.不可能一个不属于世界的食物,出现在世界中:但是可能存在着一个食物,它属于世界,但是却没有出现在世界中(即食物的颜色和世界的颜色相同,因此看不见食物).这就像鬼一样,它可能存在于这个世界上,但我们看不到它. 2. 一个属于世界的食物,具有在这个世界中的位置. 3. 它有颜色和大小. 因此,食物的结构体定义就显而易见了! typedef struct Food { World *worl…
一.ES6语法 ES6中对数组新增了几个函数:map().filter().reduce() ES5新增的forEach(). 都是一些语法糖. 1.1 forEach()遍历数组 forEach()方法用来循环遍历数组,方法中的function回调函数接收3个参数 参数1是遍历的数组内容(item):参数2是对应的数组索引(index),参数3是是数组本身(array). [].forEach(function(item,index,array){ ... }) var arr = ["白板&…
在贪吃蛇流程结构优化之后,我又不满足于亲自操刀控制这条蠢蠢的蛇,干脆就让它升级成AI,我来看程序自己玩,哈哈. 一.Dijkstra算法原理 作为一种广为人知的单源最短路径算法,Dijkstra用于求解带权有向图的单源最短路径的问题.所谓单源,就是一个源头,也即一个起点.该算法的本质就是一个广度优先搜索,由中心向外层层层拓展,直到遇到终点或者遍历结束.该算法在搜索的过程中需要两个表S及Q,S用来存储已扫描过的节点,Q存储剩下的节点.起点s距离dist[s] = 0;其余点的值为无穷大(具体实现时…
概述 JavaScript原生实现<贪吃蛇>,每吃掉一个食物,蛇的身体会变长,食物会重新换位置. 详细 代码下载:http://www.demodashi.com/demo/10728.html 贪吃蛇大家都不陌生吧~ 简单做一个. 一.思路 1.让我们的小蛇动起来 2.随机生成食物 3.每吃掉一个食物,蛇的身体会变长,食物会重新换位置 html界面 <div class="face"> <!-- 小蛇移动的操场 --> <div id=&qu…