/*tip_centerwindow.js  v. 1.21The latest version is available athttp://www.walterzorn.comor http://www.devira.comor http://www.walterzorn.deInitial author: Walter ZornLast modified: 3.6.2008Extension for the tooltip library wz_tooltip.js.Centers a sticky tooltip in the window's visible clientarea,optionally even if the window is being scrolled or resized.*/// Make sure that the core file wz_tooltip.js is included firstif(typeof config == "undefined")	alert("Error:\nThe core tooltip script file 'wz_tooltip.js' must be included first, before the plugin files!");// Here we define new global configuration variable(s) (as members of the// predefined "config." class).// From each of these config variables, wz_tooltip.js will automatically derive// a command which can be passed to Tip() or TagToTip() in order to customize// tooltips individually. These command names are just the config variable// name(s) translated to uppercase,// e.g. from config. CenterWindow a command CENTERWINDOW will automatically be// created.//===================  GLOBAL TOOPTIP CONFIGURATION  =========================//config. CenterWindow = false	// true or false - set to true if you want this to be the default behaviourconfig. CenterAlways = true	// true or false - recenter if window is resized or scrolled//=======  END OF TOOLTIP CONFIG, DO NOT CHANGE ANYTHING BELOW  ==============//// Create a new tt_Extension object (make sure that the name of that object,// here ctrwnd, is unique amongst the extensions available for// wz_tooltips.js):var ctrwnd = new tt_Extension();// Implement extension eventhandlers on which our extension should reactctrwnd.OnLoadConfig = function(){	if(tt_aV[CENTERWINDOW])	{		// Permit CENTERWINDOW only if the tooltip is sticky		if(tt_aV[STICKY])		{			if(tt_aV[CENTERALWAYS])			{				// IE doesn't support style.position "fixed"				if(tt_ie)					tt_AddEvtFnc(window, "scroll", Ctrwnd_DoCenter);				else					tt_aElt[0].style.position = "fixed";				tt_AddEvtFnc(window, "resize", Ctrwnd_DoCenter);			}			return true;		}		tt_aV[CENTERWINDOW] = false;	}	return false;};// We react on the first OnMouseMove event to center the tip on that occasionctrwnd.OnMoveBefore = Ctrwnd_DoCenter;ctrwnd.OnKill = function(){	if(tt_aV[CENTERWINDOW] && tt_aV[CENTERALWAYS])	{		tt_RemEvtFnc(window, "resize", Ctrwnd_DoCenter);		if(tt_ie)			tt_RemEvtFnc(window, "scroll", Ctrwnd_DoCenter);		else			tt_aElt[0].style.position = "absolute";	}	return false;};// Helper functionfunction Ctrwnd_DoCenter(){	if(tt_aV[CENTERWINDOW])	{		var x, y, dx, dy;		// Here we use some functions and variables (tt_w, tt_h) which the		// extension API of wz_tooltip.js provides for us		if(tt_ie || !tt_aV[CENTERALWAYS])		{			dx = tt_GetScrollX();			dy = tt_GetScrollY();		}		else		{			dx = 0;			dy = 0;		}		// Position the tip, offset from the center by OFFSETX and OFFSETY		x = (tt_GetClientW() - tt_w) / 2 + dx + tt_aV[OFFSETX];		y = (tt_GetClientH() - tt_h) / 2 + dy + tt_aV[OFFSETY];		tt_SetTipPos(x, y);		return true;	}	return false;}