Team:WHU-China/Team/Gallary

From 2011.igem.org

(Difference between revisions)
Line 1: Line 1:
 +
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<html>
<head>
<head>
-
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
+
<title>Weakening neighbors - interactive DHTML</title>
-
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>
+
<meta name="Author" content="Gerard Ferrandez at http://www.dhteumeuleu.com">
-
<script type="text/javascript" src="http://gettopup.com/releases/latest/top_up-min.js"></script>
+
<meta http-equiv="Content-type" content="text/html;charset=UTF-8">
 +
<meta http-equiv="imagetoolbar" content="no">
<style type="text/css">
<style type="text/css">
-
#countdown
 
-
{
 
-
display:none;
 
-
}
 
-
#visit
 
-
{
 
-
display:none;
 
-
}
 
-
#demo
 
-
{
 
-
position:relative;
 
-
top:15px;
 
-
height:260px;
 
-
width:1000px;
 
-
left:0px;
 
-
overflow:hidden;
 
-
}
 
-
#demo img {
 
-
top:20px;
 
-
height:260px;
 
-
width:300px;
 
-
}
 
-
#indemo {
 
-
float: left;
 
-
width: 800%;
 
-
}
 
-
#demo1 {
 
-
float: left;
 
-
}
 
-
#demo2 {
 
-
padding:0px 3px;
 
-
float: left;
 
-
}
 
-
#footer-box
 
-
{
 
-
position:absolute;
 
-
top:2000px;
 
-
}
 
-
.team_images img
 
-
{
 
-
height:280px;
+
#screen { position: absolute; background: #000; left: 50%; top: 50%; width: 960px; height: 520px; margin-left: -480px; margin-top: -260px; }
-
}
+
#a { position: absolute; font-family: arial; font-size: 12px; color: #FFF; cursor: pointer; overflow: hidden; width: 0px; }
-
#preview_images
+
#b{ position: absolute; }  
-
{
+
-
position:relative;
+
-
background:transparent;
+
-
height:600px;
+
-
width:980px;
+
-
top:10px;
+
-
left:10px;
+
-
}
+
-
#screen {
+
-
  position: absolute;
+
-
  width: 980px;
+
-
  height: 500px;
+
-
  background:transparent;
+
-
  top:50px;
+
-
}
+
-
#screen img {
+
-
  position: absolute;
+
-
  cursor: pointer;
+
-
  visibility: hidden;
+
-
  width: 10px;
+
-
  height: 10px;
+
-
}
+
-
#screen .tvover {
+
-
  border: solid #876;
+
-
  opacity: 1;
+
-
  filter: alpha(opacity=100);
+
-
}
+
-
#screen .tvout {
+
-
  border: solid #fff;
+
-
  opacity: 0.7;
+
-
}
+
-
#bankImages {
+
-
  display: none;
+
-
}
+
</style>
</style>
-
<script type="text/javascript">
+
<script type="text/javascript">  
-
var Library = {};
+
// ======================================================================
-
Library.ease = function () {
+
// script by Gerard Ferrandez | February, 2010
-
this.target = 0;
+
// --------------------------------------------------------------------
-
this.position = 0;
+
// http://www.dhteumeuleu.com | http://www.twitter.com/ge1doot
-
this.move = function (target, speed)
+
// Javascript code licensed under CC-BY-NC - Do not remove this notice
-
{
+
// ======================================================================
-
  this.position += (target - this.position) * speed;
+
   
-
  }
+
var res = function () {  
-
}
+
// ---- private vars ----
-
var tv = {
+
var scr, a0, a1,  
-
O : [],
+
divs   = new Array(),  
-
screen : {},
+
moves  = new Array(),
-
grid : {
+
idle = false,  
-
  size      : 4,
+
nw, nh, wu, hu,  
-
  borderSize : 6,
+
mx = [1,0,-1,0,2,0,-2,0,3,0,-3,0,4,0,-4,0],  
-
   zoomed    : false
+
my = [0,1,0,-1,0,2,0,-2,0,3,0,-3,0,4,0,-4],  
-
},
+
bw = 10;
-
angle : {
+
   
-
  x : new Library.ease(),
+
////////////////////////////////////////////////////////////////////////////
-
  y : new Library.ease()
+
// ============== grid class =============
-
},
+
var grid = {
-
camera : {
+
// ===== calculate grid =====
-
  x    : new Library.ease(),
+
calc : function () {  
-
  y    : new Library.ease(),
+
// ---- empty grid ----
-
  zoom : new Library.ease(),
+
this.grid = new Array(24);  
-
  focalLength : 750
+
for (var i = 0; i < 24; i++)
-
  },
+
this.grid[i] = 0;
-
init : function ()
+
// ---- load grid ----
-
{
+
var i = 0, o;
-
  this.screen.obj = document.getElementById('screen');
+
while ( o = divs[i++] )  
-
  var img = document.getElementById('bankImages').getElementsByTagName('img');
+
this.add(o);  
-
  this.screen.obj.onselectstart = function () { return false; }
+
},
-
  this.screen.obj.ondrag        = function () { return false; }
+
// ===== return cell value =====
-
  var ni = 0;
+
cell : function (x, y) {  
-
  var n = (tv.grid.size / 2) - .5;
+
return this.grid[x * 4 + y];  
-
  for (var y = -n; y <= n; y++)
+
},
-
  {
+
// ===== area weight =====
-
  for (var x = -n; x <= n; x++)
+
weight : function (x, y, w, h) {  
-
  {
+
var gw = 0;  
-
    var o = document.createElement('img');
+
for(var i = 0; i < w; i++)  
-
    var i = img[(ni++) % img.length];
+
for(var j = 0; j < h; j++)  
-
    o.className = 'tvout';
+
gw += this.cell(i + x, j + y);  
-
    o.src = i.src;
+
return gw;
-
    tv.screen.obj.appendChild(o);
+
},
-
    o.point3D = {
+
// ===== add div =====
-
    x : x,
+
add : function (o) {
-
    y : y,
+
for(var i = 0; i < o.w; i++)  
-
    z  : new Library.ease()
+
for(var j = 0; j < o.h; j++)
-
    };
+
this.grid[(i + o.x) * 4 + (j + o.y)] += o.f ? 20 : 1;
-
    o.point2D = {};
+
}
-
    o.ratioImage = 1;
+
}
-
    tv.O.push(o);
+
-
    o.onmouseover = function ()
+
////////////////////////////////////////////////////////////////////////////
-
    {
+
// ============== tween class =============
-
    if (!tv.grid.zoomed)
+
var tween = {  
-
    {
+
// ===== tween stack =====
-
      if (tv.o)
+
divs : new Array(),
-
      {
+
// ===== create tween object =====
-
      tv.o.point3D.z.target = 0;
+
tween : function (o, x, y, w, h) {
-
      tv.o.className = 'tvout';
+
return {
-
      }
+
div : o,
-
      this.className = 'tvover';
+
x : x,  
-
      this.point3D.z.target = -.5;
+
y : y,  
-
      tv.o = this;
+
w : w,
-
    }
+
h : h
-
    }
+
};  
-
    o.onclick = function ()
+
},
-
    {
+
// ===== add new tween =====  
-
    if (!tv.grid.zoomed)
+
add : function (o, x, y, w, h) {
-
    {
+
if (o == true) return false;
-
      tv.camera.x.target = this.point3D.x;
+
// ---- consolidate with last move ----
-
      tv.camera.y.target = this.point3D.y;
+
var t = this.divs.length - 1;
-
      tv.camera.zoom.target = tv.screen.w * 1.25;
+
if (t >= 0 && this.divs[t].div == o)  
-
      tv.grid.zoomed = this;
+
this.divs[t] = this.tween(o, x, y, w, h);  
-
    } else {
+
else {
-
      if (this == tv.grid.zoomed){
+
// ---- push tween ----
-
      tv.camera.x.target = 0;
+
this.divs.push(
-
      tv.camera.y.target = 0;
+
this.tween(o, x, y, w, h)
-
      tv.camera.zoom.target = tv.screen.w / (tv.grid.size + .1);
+
);  
-
      tv.grid.zoomed = false;
+
}  
-
      }
+
},
-
    }
+
// ======== start next tween =========
-
    }
+
next : function () {  
-
    o.calc = function ()
+
if (this.divs.length) {  
-
    {
+
var t = this.divs[0];  
-
    this.point3D.z.move(this.point3D.z.target, .5);
+
var o = t.div;  
-
    var x = (this.point3D.x - tv.camera.x.position) * tv.camera.zoom.position;
+
o.dx = t.x - o.xc;  
-
    var y = (this.point3D.y - tv.camera.y.position) * tv.camera.zoom.position;
+
o.dy = t.y - o.yc;
-
    var z = this.point3D.z.position * tv.camera.zoom.position;
+
o.dw = t.w - o.wc;  
-
    var xy = tv.angle.cx * y  - tv.angle.sx * z;
+
o.dh = t.h - o.hc;  
-
    var xz = tv.angle.sx * y  + tv.angle.cx * z;
+
o.s = 1;  
-
    var yz = tv.angle.cy * xz - tv.angle.sy * x;
+
o.p = 0;
-
    var yx = tv.angle.sy * xz + tv.angle.cy * x;
+
return o;  
-
    this.point2D.scale = tv.camera.focalLength / (tv.camera.focalLength + yz);
+
} else return false;
-
    this.point2D.x = yx * this.point2D.scale;
+
}  
-
    this.point2D.y = xy * this.point2D.scale;
+
}  
-
    this.point2D.w = Math.round(
+
////////////////////////////////////////////////////////////////////////////
-
                        Math.max(
+
// =============== Div constructor ===============
-
                          0,
+
var Frame = function (i, div) {
-
                          this.point2D.scale * tv.camera.zoom.position * .8
+
// ---- random position ----
-
                        )
+
do {  
-
                      );
+
this.x = this.x0 = Math.floor(Math.random() * 6);  
-
    if (this.ratioImage > 1)
+
this.y = this.y0 = Math.floor(Math.random() * 4);  
-
      this.point2D.h = Math.round(this.point2D.w / this.ratioImage);
+
} while (moves[this.x * 4 + this.y]);  
-
    else
+
moves[this.x * 4 + this.y] = true;  
-
    {
+
// ---- dimensions ----
-
      this.point2D.h = this.point2D.w;
+
var img = div.getElementsByTagName("img")[0];  
-
      this.point2D.w = Math.round(this.point2D.h * this.ratioImage);
+
var wh = img.alt.split(",");
-
    }
+
img.alt = "";
-
    }
+
this.w = 1;  
-
    o.draw = function ()
+
this.h = 1;
-
    {
+
this.xc = this.x + .5;  
-
    if (this.complete)
+
this.yc = this.y + .5;
-
    {
+
this.wc = 0;  
-
      if (!this.loaded)
+
this.hc = 0;
-
      {
+
this.w1 = wh[0] * 1;  
-
      if (!this.img)
+
this.h1 = wh[1] * 1;
-
      {
+
this.i = i;  
-
        this.img = new Image();
+
this.s = 0;
-
        this.img.src = this.src;
+
div.parent = this;
-
      }
+
div.onclick = function () { this.parent.click(); }
-
      if (this.img.complete)
+
this.css = div.style;
-
      {
+
// ---- push tween ----
-
        this.style.visibility = 'visible';
+
tween.add(this, this.x, this.y, 1, 1);
-
        this.ratioImage = this.img.width / this.img.height;
+
}
-
        this.loaded = true;
+
-
        this.img = false;
+
// ========== calculate moving cost ===========
-
      }
+
Frame.prototype.costMove = function (m) {
-
      }
+
// ---- what direction ----
-
      this.style.left = Math.round(
+
var sx = mx[m] > 0 ? 1 : mx[m] < 0 ? -1 : 0,
-
                          this.point2D.x * this.point2D.scale +
+
    sy = my[m] > 0 ? 1 : my[m] < 0 ? -1 : 0,
-
                          tv.screen.w - this.point2D.w * .5
+
    cm = 0;  
-
                        ) + 'px';
+
// ---- horizontal ----
-
      this.style.top = Math.round(
+
if (sx != 0) {
-
                          this.point2D.y * this.point2D.scale +
+
for (var i = this.x; i != this.x + mx[m]; i += sx)
-
                          tv.screen.h - this.point2D.h * .5
+
cm += grid.weight(i, this.y, this.w, this.h);  
-
                        ) + 'px';
+
// ---- vertical ----
-
      this.style.width  = this.point2D.w + 'px';
+
} else if (sy != 0) {  
-
      this.style.height = this.point2D.h + 'px';
+
for (var i = this.y; i != this.y + my[m]; i += sy)
-
      this.style.borderWidth = Math.round(
+
cm += grid.weight(this.x, i, this.w, this.h);  
-
                                Math.max(
+
}  
-
                                  this.point2D.w,
+
// ---- return cost ----
-
                                  this.point2D.h
+
return cm;
-
                                ) * tv.grid.borderSize * .01
+
}  
-
                              ) + 'px';
+
-
      this.style.zIndex = Math.floor(this.point2D.scale * 100);
+
// ============ determine moving direction =============
-
    }
+
Frame.prototype.findMove = function () {  
-
    }
+
var d = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
-
  }
+
    mx = 1000,
-
  }
+
    cm, m;
-
  tv.resize();
+
// =========== loop distance ============
-
  mouse.y = tv.screen.y + tv.screen.h;
+
for (var p = 0; p < 4 && mx >= 20; p++) {  
-
  mouse.x = tv.screen.x + tv.screen.w;
+
// ======== vertical neighbors weights ========
-
  tv.run();
+
for (var i = 0; i < this.w; i++) {  
-
},
+
// ---- up ----
-
resize : function ()
+
if (this.y - p > 0)  
-
{
+
d[3 + p * 4] += grid.cell(this.x + i, this.y - (p + 1));  
-
  var o = tv.screen.obj;
+
else
-
  tv.screen.w = o.offsetWidth / 2;
+
// ---- border ----
-
  tv.screen.h = o.offsetHeight / 2;
+
d[3 + p * 4] = 100;
-
  tv.camera.zoom.target = tv.screen.w / (tv.grid.size + .1);
+
// ---- bottom ----
-
  for (tv.screen.x = 0, tv.screen.y = 0; o != null; o = o.offsetParent)
+
if (this.y + p + this.h < 4)
-
  {
+
d[1 + p * 4] += grid.cell(this.x + i, this.y + this.h + p);  
-
  tv.screen.x += o.offsetLeft;
+
else
-
  tv.screen.y += o.offsetTop;
+
// ---- border ----
-
  }
+
d[1 + p * 4] = 100;
-
},
+
}  
-
run : function ()
+
// ======== horizontal neighbors weights ========
-
{
+
for (var j = 0; j < this.h; j++) {  
-
  tv.angle.x.move(-(mouse.y - tv.screen.h - tv.screen.y) * .0025, .1);
+
// ---- left ----
-
  tv.angle.y.move( (mouse.x - tv.screen.w - tv.screen.x) * .0025, .1);
+
if (this.x - p > 0)
-
  tv.camera.x.move(tv.camera.x.target, tv.grid.zoomed ? .25 : .025);
+
d[2 + p * 4] += grid.cell(this.x - (p + 1), this.y + j);
-
  tv.camera.y.move(tv.camera.y.target, tv.grid.zoomed ? .25 : .025);
+
else
-
  tv.camera.zoom.move(tv.camera.zoom.target, .05);
+
// ---- border ----
-
  tv.angle.cx = Math.cos(tv.angle.x.position);
+
d[2 + p * 4] = 100;  
-
  tv.angle.sx = Math.sin(tv.angle.x.position);
+
// ---- right ----
-
  tv.angle.cy = Math.cos(tv.angle.y.position);
+
if (this.x + this.w + p < 6)
-
  tv.angle.sy = Math.sin(tv.angle.y.position);
+
d[0 + p * 4] += grid.cell(this.x + this.w + p, this.y + j);  
-
  for (var i = 0, o; o = tv.O[i]; i++)
+
else
-
  {
+
// ---- border ----
-
  o.calc();
+
d[0 + p * 4] = 100;
-
  o.draw();
+
}
-
  }
+
// =============== find direction to the weakest neighbor ================
-
  setTimeout(tv.run, 32);
+
mx = 1000;
-
}
+
for (var i = 0; i < 4 * (p + 1); i++) {
-
}
+
if ( d[i] < mx) {
-
var mouse = {
+
// ---- store min values ----
-
x : 0,
+
mx = d[i];
-
y : 0
+
m = i;
-
}
+
cm = this.costMove(i);  
-
document.onmousemove = function(e)
+
// ---- equality case ----
-
{
+
} else if ( d[i] == mx) {
-
if (window.event) e = window.event;
+
// ---- less costly move ----
-
mouse.x = e.clientX;
+
var cmm = this.costMove(i);
-
mouse.y = e.clientY;
+
if (cmm < cm) {
-
return false;
+
cm = cmm;  
-
}
+
m = i;
 +
mx = d[i];
 +
}  
 +
}  
 +
}
 +
}
 +
// ====== return direction [0 = right, 1 = bottom, 2 = left, 3 = up] ======
 +
return m;
 +
}
 +
 +
// ============ HTML rendering =============
 +
Frame.prototype.paint = function () {
 +
this.css.left  = Math.round(bw + this.xc * wu) + "px";  
 +
this.css.top   = Math.round(bw + this.yc * hu) + "px";  
 +
this.css.width  = Math.round(Math.max(0, this.wc * wu - bw)) + "px";  
 +
this.css.height = Math.round(Math.max(0, this.hc * hu - bw)) + "px";  
 +
}
 +
 +
// ========== easing function ==============
 +
Frame.prototype.tween = function () {
 +
if (this.s != 0) {
 +
// ---- easing ----
 +
this.p += this.s;
 +
this.xc += this.dx * this.p * .01;  
 +
this.yc += this.dy * this.p * .01;  
 +
this.wc += this.dw * this.p * .01;  
 +
this.hc += this.dh * this.p * .01;  
 +
// ---- HTML rendering ----
 +
this.paint();  
 +
// ---- percentage steps [1+2+3+4+5+6+7+8+9+10+9+8+7+6+5+4+3+2+1=100] ----
 +
if (this.p == 10)  
 +
// ---- reverse acceleration
 +
this.s = -1;  
 +
else if (this.p == 0)
 +
// ---- moving end
 +
this.s = false;  
 +
}
 +
return this.s;
 +
}
 +
 +
// ============= Main IA function for moving divs ===============
 +
Frame.prototype.click = function () {
 +
if (moves.length) {
 +
var i = 0, o;
 +
while ( o = moves[i++] ) {
 +
o.f = false;  
 +
// ---- zoom out ----
 +
if (o.w != 1 || o.h != 1) {  
 +
o.w = 1;
 +
o.h = 1;  
 +
tween.add(o, o.x, o.y, o.w, o.h);  
 +
}  
 +
}  
 +
}
 +
// ---- stop here if same div ----
 +
if (moves[0] == this)  
 +
moves = new Array();
 +
else {  
 +
// ---- init grid weights ----
 +
moves = new Array();
 +
grid.calc();
 +
// =========== find the best place for the zoomed div ===========
 +
var mvx = 0,
 +
    mvy = 0;
 +
// ---- right border limit ----
 +
if (this.y + this.h1 > 3)
 +
this.y -= this.y + this.h1 - 4;
 +
else {
 +
// ---- vertical backward move ----
 +
for (var i = this.y - 1; i > this.y - this.h - 1; i--)  
 +
if (i >= 0 && grid.weight(this.x, i, this.w1, 1) == 0)
 +
mvy++;  
 +
}
 +
// ---- bottom border limit ----
 +
if (this.x + this.w1 > 5)
 +
this.x -= this.x + this.w1 - 6;
 +
else if (!mvy) {
 +
// ---- horizontal backward move ----
 +
for (var i = this.x - 1; i > this.x - this.w - 1; i--)  
 +
if (i >= 0 && grid.weight(i, this.y, 1, this.h1) == 0)
 +
mvx++;  
 +
}
 +
// ============ move zoomed div =============
 +
this.x -= mvx;
 +
this.y -= mvy;
 +
this.w = this.w1;
 +
this.h = this.h1;
 +
this.f = true;
 +
this.findMove();
 +
grid.add(this);  
 +
moves.push(this);
 +
// ========= cascading child moves ==========
 +
var k = 0, o;
 +
// ---- loop through all divs ----
 +
while ( o = divs[k++] ) {
 +
// ---- skip frozen div ----
 +
if (o.f != true) {
 +
// ---- loop through all cells ----
 +
for (var i = 0; i < o.w; i++) {
 +
for (var j = 0; j < o.h; j++) {
 +
// ---- collision (non empty cell) ----
 +
if (grid.cell(i + o.x, j + o.y) > 1) {
 +
// ---- move to a better place ----
 +
var m = o.findMove();  
 +
o.x += mx[m];
 +
o.y += my[m];
 +
// ---- not inside another one ? ----
 +
if (grid.weight(o.x, o.y, o.w, o.h) < 20) {
 +
// ---- freeze div and push move ----
 +
o.f = true;
 +
grid.add(o);  
 +
moves.push(o);
 +
// ---- reset main loop and exit ----
 +
k = 0;
 +
break;
 +
}
 +
}
 +
}
 +
if (o.f) break;  
 +
}
 +
}
 +
}
 +
// ========= push moves in reverse order =========
 +
var i = moves.length, o;
 +
while ( o = moves[--i] )
 +
tween.add(o, o.x, o.y, o.w, o.h);  
 +
}
 +
// ---- start tweens engine ----
 +
a0 = tween.next();  
 +
if (idle) {
 +
idle = false;
 +
run();
 +
}
 +
}
 +
 +
// ============== main loop ================
 +
var run = function () {
 +
// ---- first tween ----
 +
if (a0) {
 +
a0.tween();
 +
if (a0.p == 10) {
 +
// ---- next ----
 +
a1 = a0;
 +
tween.divs.splice(0,1);  
 +
a0 = tween.next();
 +
}
 +
}
 +
// ---- second tween ----
 +
if (a1) {  
 +
a1.tween();  
 +
// ---- end anim ----
 +
if (a1.s === false)  
 +
a1 = false;  
 +
}  
 +
// ---- loop ----
 +
if (a0 || a1) setTimeout(run, 32);  
 +
else idle = true;
 +
}  
 +
// ============== init script ==============
 +
var init = function () {  
 +
// ---- init container ----
 +
scr = document.getElementById('screen');
 +
// ---- load divs ----
 +
var k = 0, o;
 +
while ( o = scr.getElementsByTagName("div")[k++] )
 +
divs.push(
 +
new Frame(k, o)
 +
);  
 +
// ---- ajust dimensions ----
 +
nw = scr.offsetWidth - bw;  
 +
nh = scr.offsetHeight - bw;
 +
wu = nw / 6;
 +
hu = nh / 4;
 +
// ---- start animation -----
 +
a0 = tween.next();  
 +
run();  
 +
}  
 +
return {
 +
// ==== public bloc ====
 +
init : init
 +
}
 +
}();
 +
</script>
</script>
</head>
</head>
<body>
<body>
-
<div id="content1">
+
<div id="screen">
-
<div id="demo">
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/e/e6/Whu-1.jpg" width="503" height="376" alt="3,3"></div>
-
<div id="indemo">
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/f/f1/Whu-4-2.jpg" width="465" height="373" alt="3,3"></div>
-
<div id="demo1">
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/c/c4/Whu-8.jpg" width="465" height="373" alt="3,3"></div>
-
<a ><img src="/wiki/images/e/e6/Whu-1.jpg" border="1" /></a>
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/f/f6/Whu-10.jpg" width="301" height="503" alt="2,4"></div>
-
<a ><img src="/wiki/images/f/f1/Whu-4-2.jpg" border="1" /></a>
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/6/69/Whu-13.jpg" width="375" height="500" alt="2,4"></div>
-
<a ><img src="/wiki/images/c/c4/Whu-8.jpg" border="1" /></a>
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/e/e1/Whu-18.jpg" width="370" height="501" alt="2,4"></div>
-
<a ><img src="/wiki/images/f/f6/Whu-10.jpg" border="1" /></a>
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/5/57/Whu-47.jpg" width="465" height="373" alt="3,3"></div>
-
<a ><img src="/wiki/images/6/69/Whu-13.jpg" border="1" /></a>
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/a/a8/Whu-61.jpg" width="307" height="499" alt="2,4"></div>
-
<a ><img src="/wiki/images/e/e1/Whu-18.jpg" border="1" /></a>
+
  <div id="a"><img id="b" src="https://static.igem.org/mediawiki/2011/f/fc/Whu-43.jpg" width="500" height="376" alt="3,3"></div>
-
<a><img src="/wiki/images/4/42/Whu-32.jpg" border="1" /></a>
+
-
<a ><img src="/wiki/images/f/fc/Whu-43.jpg" border="1" /></a>
+
-
<a ><img src="/wiki/images/a/a8/Whu-61.jpg" border="1" /></a>
+
-
<a><img src="/wiki/images/5/57/Whu-47.jpg" border="1" /></a>
+
</div>
</div>
-
<div id="demo2"></div>
+
<script type="text/javascript">  
-
<script>
+
// ==== start script ====  
-
var speed=20;
+
setTimeout(function() {  
-
var tab=document.getElementById("demo");
+
res.init();  
-
var tab1=document.getElementById("demo1");
+
}, 100);  
-
var tab2=document.getElementById("demo2");
+
-
tab2.innerHTML=tab1.innerHTML;
+
-
function Marquee(){
+
-
if(tab.scrollLeft<=0)
+
-
tab.scrollLeft+=tab2.offsetWidth
+
-
else{
+
-
tab.scrollLeft--;
+
-
}
+
-
}
+
-
var MyMar=setInterval(Marquee,speed);
+
-
tab.onmouseover=function() {clearInterval(MyMar)};
+
-
tab.onmouseout=function() {MyMar=setInterval(Marquee,speed)};
+
-
 
+
-
</script>
+
-
</div>
+
-
</div>
+
-
 
+
-
<div id="preview_images">
+
-
<div id="screen"></div>
+
-
<div id="bankImages">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
<img src="/wiki/images/e/e6/Whu-1.jpg">
+
-
</div>
+
-
<script type="text/javascript">
+
-
onresize = tv.resize;
+
-
tv.init();
+
</script>
</script>
-
</div>
 
-
</div>
 
</body>
</body>
-
 
</html>
</html>
-
{{WHUcss}}
 

Revision as of 07:06, 2 October 2011

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> Weakening neighbors - interactive DHTML

3,3
3,3
3,3
2,4
2,4
2,4
3,3
2,4
3,3