Bookclick.as

From Organic Design wiki

// Compile and run in [[E-book_comb]]Template:As margin = 50; i = 0; speed = 12; w = (Stage.width-margin*2)/2; h = Stage.height-margin*2; gf = 4; gh = 1;

//main clip this.createEmptyMovieClip("book",1);

//this.createEmptyMovieClip("right_next",17); this.createEmptyMovieClip("pg1",3);

this.createEmptyMovieClip("maskee",8); this.createEmptyMovieClip("masker",9); this.createEmptyMovieClip("tasker",6); this.createEmptyMovieClip("taskee",7);

pg1.loadMovie("aqua.jpg");

//create following page masker.createEmptyMovieClip("RightFill",12); tasker.createEmptyMovieClip("MidFill", 13); /*right_next.createTextField('content',0,0,0,100,50); with (right_next.content) { autosize = 'left'; selectable = false; _quality = 'BEST'; border = false; multiline = true; wordWrap = false; html = true; _visible = false; // embedFonts = true; htmlText = 'Hello right world!'; }*/

book.animate = function(i,Tx,Ty){

var animpass = new Object(); ox = animpass.ac = margin+w; oy = animpass.ad = margin;

//onmousemove if (!i) { x = animpass.aa = _xmouse-ox; y = animpass.ab = _ymouse-oy; x = x*Tx; if (Ty == 1) { oy = animpass.ad = margin + h; y = animpass.ab = oy-_ymouse; } } //onclick if (i) { v = i; if (Tx == -1) { v = 800-i; } x = animpass.aa = (v-ox)*Tx; y = animpass.ab = 50; if (Ty == 1) { oy = animpass.ad = margin + h; } }

book.pageTurn(x,y,ox,oy,Tx,Ty); };

// main function book.pageTurn = function(x,y,ox,oy,Tx,Ty) { //calculate fold a = Math.atan2(y,x); r = Math.sqrt(x*x+y*y); if (r>w) r=w; x = Math.cos(a)*r; y = Math.sin(a)*r; // Calculate point Z and dy,dx of line C dx = w-x; dy = y; Zx = x+dx/2; Zy = y-dy/2; // Calculate line D Px = Zx-Zy*dy/dx; Py = 0; Qx = w;

if (dy*dy<1) { a = 0; Qx = x>w ? w : x; Qy = Ry = h; Rx = (Qx+w)/2;} else { Qy = Zy+(w-Zx)*dx/dy; if (Qy>h || Qy<0) { a = Math.atan2(Qy-y,Qx-x); if (Qy<0) a += Math.PI; Qx = x+Math.cos(a)*h; Qy = y+Math.sin(a)*h; Rx = Qx+(Qy-h)/(y-Py)*(Px-x); Ry = h; } else { Rx = Qx; Ry = Qy; } if (Qy==0) Rx = w-Qx; if (Rx<0) return; } //draw lines book.clear(); book.lineStyle(1,100); book.moveTo(ox,oy-h*Ty); book.lineTo(ox+w*Tx,oy-h*Ty); book.lineTo(ox+w*Tx,oy); book.lineTo(ox,oy); book.moveTo(ox-w*Tx,oy); book.lineTo(ox+Px*Tx,oy-Py*Ty); book.lineTo(ox+Rx*Tx,oy-Ry*Ty); book.lineTo(ox+Rx*Tx,oy-h*Ty); book.lineTo(ox-w*Tx,oy-h*Ty); book.lineTo(ox-w*Tx,oy); book.moveTo(ox+x*Tx,oy-y*Ty); book.lineTo(ox+Px*Tx,oy-Py*Ty); book.lineTo(ox+Rx*Tx,oy-Ry*Ty); book.lineTo(ox+Qx*Tx,oy-Qy*Ty); book.lineTo(ox+x*Tx,oy-y*Ty); //book.endFill();

with (masker.RightFill) { clear(); lineStyle(1,100); moveTo(ox,oy-h*Ty); lineTo(ox+w*Tx,oy-h*Ty); lineTo(ox+w*Tx,oy); lineTo(ox,oy); moveTo(ox-w*Tx,oy); lineTo(ox+Px*Tx,oy-Py*Ty); lineTo(ox+Rx*Tx,oy-Ry*Ty); lineTo(ox+Rx*Tx,oy-h*Ty); lineTo(ox-w*Tx,oy-h*Ty); lineTo(ox-w*Tx,oy); beginFill(0xffffff,100); moveTo(ox+x*Tx,oy-y*Ty); lineTo(ox+Px*Tx,oy-Py*Ty); lineTo(ox+Rx*Tx,oy-Ry*Ty); lineTo(ox+Qx*Tx,oy-Qy*Ty); lineTo(ox+x*Tx,oy-y*Ty); endFill(); }

with (tasker.MidFill) { clear(); lineStyle(1,100); moveTo(ox,oy-h*Ty); lineTo(ox+w*Tx,oy-h*Ty); lineTo(ox+w*Tx,oy); lineTo(ox,oy); moveTo(ox-w*Tx,oy); lineTo(ox+Px*Tx,oy-Py*Ty); lineTo(ox+Rx*Tx,oy-Ry*Ty); lineTo(ox+Rx*Tx,oy-h*Ty); lineTo(ox-w*Tx,oy-h*Ty); lineTo(ox-w*Tx,oy); beginFill (0xffffff,100); moveTo (ox-w*Tx,oy);; lineTo (ox+Px*Tx,oy); lineTo(ox+Rx*Tx,oy-Ry*Ty); lineTo(ox+Rx*Tx,oy-h*Ty); lineTo (ox-w*Tx,oy-h*Ty); lineTo (ox-w*Tx,oy); endFill(); } // orient next page /* right_next.content._visible = true; _root.right_next._x = ox+Rx*Tx; _root.right_next._y = oy-Ry*Ty; //_root.right_next._rotation = a*57.29578;*/ };

var mclListener = new Object();

mclListener.onLoadInit = function(target_mc) {

   target_mc.setMask(masker.RightFill);

};

var my_mcl = new MovieClipLoader(); my_mcl.addListener(mclListener); my_mcl.loadClip("purple.jpg", maskee);

var tclListener = new Object();

tclListener.onLoadInit = function(marget_mc) {

   marget_mc.setMask(tasker.MidFill);

};

var ty_mcl = new MovieClipLoader(); ty_mcl.addListener(tclListener); ty_mcl.loadClip("green.jpg", taskee);

//iterate over frames book.reduce = function() {

   if (i) _root.book.animate(i-=speed,Tx,Ty);

}; // for multiple parameters in main function var coords = new Object();

zoom = function() { pg1._xscale = 150; pg1._yscale=150; book._visible= false; taskee._visible= false; tasker._visible= false; maskee._visible= false; masker._visible= false; createEmptyMovieClip("zoommask",14); zoommask.loadMovie("zoom.gif"); Mouse.hide(); zoommask.startDrag(); zoommask._x = _xmouse; zoommask._y = _ymouse; glass = true; i = 0; };

var mouseListener = new Object();

mouseListener.onMouseMove = function(){ //trace(_xmouse); //trace(_ymouse); if (glass == true) { createEmptyMovieClip("zoommask",14); zoommask.loadMovie("zoom.gif"); Mouse.hide(); zoommask.startDrag(); zoommask._x = _xmouse; zoommask._y = _ymouse; }

zoommask._visible = false;

if (_xmouse >=400) { Tx = coords.j = 1; } if (_xmouse < 400) { Tx = coords.j = -1; } if (_ymouse <= 300) Ty = coords.k = -1; if (_ymouse > 300) Ty = coords.k = 1; if (Tx==-1) gn=gf; if (Tx==1) gn=gh;


_root.book.animate(0,Tx,Ty); };

mouseListener.onMouseDown = function(){

	if (_xmouse >= 600 ) {

Tx = coords.j = 1; } if (_xmouse < 600 && _xmouse >= 400) { Tx = coords.j = 1; }

  	if (_xmouse >= 200 && _xmouse < 400) {

Tx = coords.j = -1; }

   if (_xmouse < 200) {

Tx = coords.j = -1; } if (_ymouse <= 300) Ty = coords.k = -1; if (_ymouse > 300) Ty = coords.k = 1; };

mouseListener.onMouseUp = function(){

gv = gn+".jpg"; pg1.loadMovie(gv); if (_xmouse>275 && _xmouse<=400) { if ((_ymouse<50) || (_ymouse>550 && _ymouse<=600)) { zoom(); } }

if (_xmouse>400 && _xmouse<=525) { if ((_ymouse<50) || (_ymouse>550 && _ymouse<=600)) { zoom(); } }

if (_xmouse<=275 || _xmouse>525){ zoommask.stopDrag(); Mouse.show(); pg1._xscale = 100; pg1._yscale=100; zoommask._visible = false; book._visible= true; taskee._visible= true; tasker._visible= true; maskee._visible= true; masker._visible= true; glass = false; i=612; }

		gn = gn + (1*Tx);

};

Mouse.addListener(mouseListener);