<html>
<head>
<title>盒子游戏</title>
<style type="text/css">
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
body
{font-size:10pt;}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
.table_back
{width:300px;height:300px;}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
.floor
{border:1px solid black;cursor:pointer;}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
.closed
{background-color:#808080;cursor:default;}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
.edge
{border-color:#dfdfdf;}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
.mickey
{background:red;cursor:default;}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
.spider
{background:green;cursor:default;}
</style>
</head>
<body>
<script type="text/javascript">
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
/**//*--
标题:盒子游戏
设计:王集鹄
博客:http://blog.csdn.net/zswang
日期:2009年12月5日
--*/
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function Box(options)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
options = options ||
{};
var self = this;
this.rowCount = options.rowCount || 15; // 行数
this.colCount = options.colCount || 15; // 列数
this.closedCount = options.closedCount || 3; // 起始关闭数
this.mickeyCount = options.mickeyCount || 1; // 老鼠的数量
this.parent = options.parent || document.body; // 容器
this.onnewmickey = options.onnewmickey; // 初始化老鼠的事件
this.table_back = document.createElement("table");
this.table_back.className = "table_back";
this.table_back.border = 1;
this.playing = false; // 是否在进行中
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.floors =
{}; // 矩阵地板矩阵 [y,x]
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.rowCount; i++)
{
var tr = this.table_back.insertRow(-1);
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var j = 0; j < this.colCount; j++)
{
var td = tr.insertCell(-1);
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.floors[i + "," + j] = new Floor(
{
td: td
, box: this
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
, pos:
{ x: j, y: i }
});
}
}
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
this.mickeys = []; // 老鼠集合
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.mickeyCount; i++)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
var mickey = new Mickey(
{box: this});
mickey.index = i;
if (this.onnewmickey) this.onnewmickey(mickey);
this.mickeys.push(mickey);
}
this.parent.appendChild(this.table_back);
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 重新开始
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Box.prototype.replay = function ()
{
this.playing = true;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.rowCount; i++)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var j = 0; j < this.colCount; j++)
{
this.floors[i + "," + j].setState("blank");
}
}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.closedCount; i++)
{
this.floors[
Math.floor(this.rowCount * Math.random())
+ "," + Math.floor(this.colCount * Math.random())
].setState("closed");
}
var j = -(this.mickeys.length / 2);
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.mickeys.length; i++, j++)
{
if (this.mickeys.length % 2 == 0 && i == this.mickeys.length / 2)
j++;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.mickeys[i].move(
{
x: Math.floor(this.colCount / 2)
, y: Math.floor(this.rowCount / 2 + j)
});
}
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 下一个周期
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Box.prototype.kick = function()
{
if (!this.playing) return;
var count = 0;
var freedom = false;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.mickeys.length; i++)
{
if (this.mickeys[i].run()) count++;
if (this.mickeys[i].freedom) freedom = true;
}
if (freedom) // 有老鼠跑了
this.gameover();
else if (!count) this.win();
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 游戏结束
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Box.prototype.gameover = function()
{
if (!this.playing) return;
this.playing = false;
if (this.ongameover) this.ongameover();
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Box.prototype.win = function()
{
if (!this.playing) return;
this.playing = false;
if (this.onwin) this.onwin();
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 地板
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function Floor(options)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
options = options ||
{};
var self = this;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.td = options.td ||
{};
this.td.innerHTML = " ";
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.td.onclick = function()
{
if (!self.box.playing) return; // 游戏已经结束
if (self.state != "blank") return;
self.setState("closed");
self.box.kick();
}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.box = options.box ||
{};
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.pos = options.pos ||
{};
this.state = "blank";
this.doChange();
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 状态变化
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Floor.prototype.doChange = function()
{
var className = "floor";
if (this.pos.x * this.pos.y == 0
|| this.pos.x == this.box.colCount - 1
|| this.pos.y == this.box.rowCount - 1) // 边缘
className += " edge";
className += " " + this.state;
if (this.td.className != className)
this.td.className = className;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Floor.prototype.setState = function(state)
{
if (this.state == state) return;
this.state = state;
if (this.box.next) this.box.next();
this.doChange();
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 老鼠类
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function Mickey(options)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
options = options ||
{};
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.box = options.box ||
{};
this.route = null; // 逃跑路线
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.pos =
{}; // 所在位置
this.move(this.pos);
this.freedom = false;
this.name = "mickey";
this.offsets = [ // 移动规则
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{x: -1, y: 0}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: 0, y: -1}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: +1, y: 0}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: 0, y: +1}
];
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 移动位置
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Mickey.prototype.move = function(pos)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
pos = pos ||
{};
if (pos.x == this.x && pos.y == this.y) return;
if (this.box.floors[this.pos.y + "," + this.pos.x])
this.box.floors[this.pos.y + "," + this.pos.x].setState("blank");
this.pos = pos;
this.box.floors[this.pos.y + "," + this.pos.x].setState(this.name);
this.freedom = this.pos.x == 0 || this.pos.y == 0
|| this.pos.x == this.box.colCount - 1
|| this.pos.y == this.box.rowCount - 1;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 老鼠跑
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Mickey.prototype.run = function()
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
var directions =
{ route: [], pos: this.pos };
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
this.flags =
{};
this.route = [];
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (this.search(this.pos, this.route))
{
this.move(this.route.shift());
return true;
}
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
// 搜索逃跑路径
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
Mickey.prototype.search = function(pos, route)
{
if (this.flags[pos.y + "," + pos.x]) return false;
this.flags[pos.y + "," + pos.x] = true; // 标记已经扫描
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
// 搜索直观的路径
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
var directions =
{}; // 每个方向的路径
var min = -1; // 最短的距离
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.offsets.length; i++)
{
directions[i] = [];
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var j = 1; ; j++)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
var test =
{
x: pos.x + this.offsets[i].x * j
, y: pos.y + this.offsets[i].y * j
};
if (!(test.x >= 0 && test.y >= 0
&& test.x < this.box.colCount && test.y < this.box.rowCount
&& !this.flags[test.y + "," + test.x] // 未搜索过
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
&& this.box.floors[test.y + "," + test.x].state == "blank"))
{
directions[i] = [];
break;
}
directions[i].push(test);
if (test.x == 0 || test.y == 0
|| test.x == this.box.colCount - 1
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
|| test.y == this.box.rowCount -1)
{
if (min < 0 || directions[min].length > directions[i].length) min = i;
break;
}
}
}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (min >= 0)
{
for (var i = 0; i < directions[min].length; i++)
route.push(directions[min][i]);
return true;
}
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
// 回溯搜索
var k = Math.floor(Math.random() * this.offsets.length);
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var i = 0; i < this.offsets.length; i++)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
var test =
{
x: pos.x + this.offsets[(k + i) % this.offsets.length].x
, y: pos.y + this.offsets[(k + i) % this.offsets.length].y
};
if (test.x >= 0 && test.y >= 0
&& test.x < this.box.colCount && test.y < this.box.rowCount
&& !this.flags[test.y + "," + test.x] // 未搜索过
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
&& this.box.floors[test.y + "," + test.x].state == "blank")
{ // 非空地
route.push(test);
if (test.x == 0 || test.y == 0
|| test.x == this.box.colCount - 1
|| test.y == this.box.rowCount -1)
return true;
if (this.search(test, route)) return true;
route.pop();
}
}
return false;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
var button = document.createElement("input");
button.type = "button";
button.value = "第一关";
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
button.onclick = function()
{
box1.replay();
};
document.body.appendChild(button);
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
var box1 = new Box();
box1.replay();
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
var button = document.createElement("input");
button.type = "button";
button.value = "第二关";
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
button.onclick = function()
{
box2.replay();
};
document.body.appendChild(button);
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
var box2 = new Box(
{mickeyCount: 2});
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
box2.replay();
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
var button = document.createElement("input");
button.type = "button";
button.value = "第三关";
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
button.onclick = function()
{
box3.replay();
};
document.body.appendChild(button);
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
var box3 = new Box(
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
onnewmickey: function(mickey)
{
mickey.offsets = [
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{x: -1, y: 0}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: 0, y: -1}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: +1, y: 0}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: 0, y: +1}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: -1, y: +1}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: -1, y: -1}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: +1, y: -1}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
,
{x: +1, y: +1}
];
mickey.name = 'spider';
}
});
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
box3.replay();
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
box1.ongameover = box2.ongameover = box3.ongameover = function()
{
alert("跑掉了。o(╯□╰)o");
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
box1.onwin = box2.onwin = box3.onwin = function()
{
alert("O(∩_∩)O成功!");
}
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
两个脚本都是在csdn上无意中看到的..第一个挺有意思的游戏..堵箱子..玩法就不说了..很简单..
第二个是一个烟花的脚本..08奥运会那个大脚烟花..这个是真的很有意思..
<html>
<head>
<title>K.G Script3D 2.00 Beta - Map UpFire</title>
</head>
<body bgcolor="#000000" text="#ffffff" style="overflow:hidden;">
<!--<p id="idText" style="color:rgb(255,255,255)">提示:改变窗口大小后请刷新,以便观赏最大视野效果。</p>-->
</body>
<script type="text/javascript">
//K.G Script3D 2.00 Beta
//3D Script for DHTML
//Copyright - KiteGirl [China] 2009
var pubElements = null;
var pubX = pubY = pubZ = 0;
var pubR = pubG = pubB = 0;
var pubViewAngle = 0;
var pubViewWidth = 0;
var pubViewHeight = 0;
var pubViewFogOver = 0;
var pubViewFogFull = 0;
var pubAt = 0;
var pubCellLen = 0;
var pubBaseX = pubBaseY = pubScale = 0;
var pubBaseZ = 0;
var pubTimerCode = 0;
var pubOnTimer = 0;
var pubTimeout = 0;
var pubMapValStrs = 0;
var pubPy = 0;
var pubPyDt = 0;
var pubSSG_reCosVa = 0;
var pubSSG_reVa = 0;
var pubMapsIndex = 0;
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function rgb(b, g, r)
{
return "#" +
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
("00" + Math.floor(r).toString(16)).replace(/^.*(\w
{2}$)/g, "$1") +
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
("00" + Math.floor(g).toString(16)).replace(/^.*(\w
{2}$)/g, "$1") +
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
("00" + Math.floor(b).toString(16)).replace(/^.*(\w
{2}$)/g, "$1");
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
window.onload = function()
{
pubSSG_reCosVa = 0;
pubSSG_reVa = 0;
pubViewAngle = 45;
pubViewWidth = (document.body.clientWidth || document.documentElement.clientWidth) - 10;
pubViewHeight = (document.body.clientHeight || document.documentElement.clientHeight) - 10;
pubBaseZ = 2000;
pubViewFogOver = 3700;
pubViewFogFull = 1500;
pubCellLen = 255;
pubPy = 0;
pubPyDt = 110;
tMap = "21,3,22,3,23,3,18,4,19,4,20,4,24,4,25,4,17,5,26,5,17,6,26,6,17,7,26,7,17,8,26,8,17,9," +
"26,9,16,10,26,10,16,11,26,11,15,12,26,12,13,13,14,13,26,13,11,14,12,14,26,14,9,15,10,15," +
"26,15,8,16,25,16,8,17,25,17,4,18,5,18,8,18,25,18,2,19,3,19,6,19,8,19,25,19,2,20,6,20,8," +
"20,25,20,2,21,6,21,9,21,10,21,24,21,2,22,6,22,10,22,11,22,12,22,23,22,3,23,4,23,5,23,13," +
"23,14,23,15,23,16,23,17,23,18,23,19,23,20,23,21,23,22,23,10,24,11,24,25,24,26,24,9,25,12," +
"25,15,25,16,25,24,25,27,25,8,26,12,26,14,26,17,26,20,26,21,26,24,26,28,26,9,27,11,27,14," +
"27,17,27,19,27,22,27,25,27,27,27,10,28,14,28,17,28,19,28,22,28,26,28,15,29,16,29,19,29," +
"22,29,20,30,21,30";
pubMapValStrs = tMap.split(/,/);
tValLen = pubMapValStrs.length;
pubCellLen = tValLen / 2;
pubX = new Array(pubCellLen);
pubY = new Array(pubCellLen);
pubZ = new Array(pubCellLen)
GetMap1();
pubElements = ElementsCreate(pubCellLen);
NewColor();
ElementsView(pubElements, pubX, pubY, pubZ, pubCellLen, pubViewAngle, pubViewWidth, pubViewHeight, pubViewWidth / 2, pubViewHeight / 2, pubBaseZ, pubViewFogFull, pubViewFogOver, pubR, pubG, pubB, 9);
TimeLoop();
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function GetMap1()
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var tCi = 0; tCi < pubCellLen; tCi++)
{
pubX[tCi] = 16 - parseInt(pubMapValStrs[tCi * 2]) - 16;
pubZ[tCi] = (parseInt(pubMapValStrs[tCi * 2 + 1]) - 16) * 2;
pubY[tCi] = 500 - pubZ[tCi];
}
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function GetMap2()
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (var tCi = 0; tCi < pubCellLen; tCi++)
{
pubX[tCi] = parseInt(pubMapValStrs[tCi * 2]) - 16 + 16;
pubZ[tCi] = (parseInt(pubMapValStrs[tCi * 2 + 1]) - 16) * 2;
pubY[tCi] = 500 - pubZ[tCi];
}
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function NewColor()
{
var tRGB = new Array(3);
tRGB[0] = Math.random() * 0.5 + 0.5;
tRGB[1] = Math.random() * 0.5 + 0.5;
tRGB[2] = Math.random() * 0.5 + 0.5;
tRGB[Math.floor(Math.random() * 3)] = 1;
pubR = tRGB[0] * 255;
pubG = tRGB[1] * 255;
pubB = tRGB[2] * 255;
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function TimeLoop()
{
//pubOnTimer = Timer;
if (pubAt < 1500) pubAt = pubAt + 50;
pubPy = pubPy + pubPyDt;
pubPyDt = pubPyDt - 5;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (pubAt > 1440)
{
pubAt = pubPy = 0;
pubPyDt = 110;
pubMapsIndex = (pubMapsIndex + 1) % 2;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (pubMapsIndex == 0)
{
GetMap1();
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
} else
{
GetMap2();
}
NewColor();
}
ElementsView(pubElements, pubX, pubY, pubZ, pubCellLen, pubViewAngle, pubViewWidth, pubViewHeight,
pubViewWidth / 2, pubViewHeight / 2, pubBaseZ, pubViewFogFull, pubViewFogOver, pubR, pubG, pubB, 9);
pubTimerCode = window.setTimeout("TimeLoop();", 33);
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function ElementsCreate(pLength)
{
var oElms = new Array(pLength + 1);
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (tEi = 0; tEi < pLength; tEi++)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
with (document)
{
oElms[tEi] = createElement("SPAN");
body.appendChild(oElms[tEi]);
}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
with (oElms[tEi])
{
innerHTML = "*";
style.position = "absolute";
style.color = "#000000";
}
}
return oElms;
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function ElementsView(pElements, pXs, pYs, pZs, pLength, pVa, pVw, pVh, pBx, pBy, pBz, pCf, pCe, pRs, pGs, pBs, pVcs)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
for (tEi = 0; tEi < pLength; tEi++)
{
tSc = ((pubAt / 100) + 1);
tZ = pZs[tEi] * tSc + pBz + (1000 - pubAt) * 2;
tX = pXs[tEi] * tSc;
tY = pYs[tEi] + 500 - pubPy;
var tVx = tVy = tVcs = 0;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (tZ > 0) ShadowScenoGraph(tX, tY, tZ, pVa, pVw, pBx, pBy, pVcs, function (oVx, oVy, oVcs)
{ tVx = oVx; tVy = oVy; tVcs = oVcs; });
if (tVcs < 0) tVcs = Math.abs(tVcs);
tVc = LocateOverView(tVx, tVy, tZ, pVw, pVh);
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (tVc)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
with (pElements[tEi].style)
{
color = "#000000";
fontSize = "9";
top = 0
left = 0
}
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
} else
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
with (pElements[tEi].style)
{
color = FogColor(tZ, pCf, pCe, pRs, pGs, pBs);
fontSize = tVcs + 1;
top = tVy;
left = tVx;
zIndex = tVcs + 1;
}
}
}
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function FogColor(pZ, pVf, pVe, pR, pG, pB)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (pZ > pVe)
{
tCs = 0;
oColor = 0;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
} else if (pZ < pVf)
{
tCs = 1;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
} else
{
tCs = (pVe - pZ) / (pVe - pVf);
}
tB = tCs * pB;
tG = tCs * pG;
tR = tCs * pR;
return rgb(tB, tG, tR);
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function LocateOverView(pX, pY, pZ, pVw, pVh)
{
return (pX > pVw) | (pX < 0) | (pY > pVh) | (pY < 0) | (pZ < 0);
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function ShadowScenoGraph(iX, iY, iZ, iVa, iVw, iVbx, iVby, iVcs, func)
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (pubSSG_reVa != iVa)
{
pubSSG_reVa = iVa;
pubSSG_reCosVa = Math.cos(Radian(pubSSG_reVa));
}
tZw = iZ * pubSSG_reCosVa;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
if (tZw != 0)
{
oVcs = iVcs * iVw / tZw;
tVps = oVcs / 2;
oVx = (iX * iVw) / tZw + iVbx - tVps;
oVy = (iY * iVw) / tZw + iVby - tVps;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
} else
{
oVcs = oVx = oVy = 0;
}
func(oVx, oVy, oVcs);
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function SphereLocate(iR, iAv, iAp, oX, oY, oZ)
{
tRv = Radian(iAv);
tRp = Radian(iAp);
tR_Sin_Rv = iR * Math.sin(tRv);
oX = tR_Sin_Rv * Math.cos(tRp);
oY = tR_Sin_Rv * Math.sin(tRp);
oZ = iR * Math.cos(tRv);
}
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
function Radian(pA)
{
return pA * 71 / 4068;
}
</script>
</html>
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zswang/archive/2009/01/13/3771948.aspx