﻿//ブログに張るSWF
var gsTickerSwf = "http://sheba.jp/download/blogparts04/blogparts.swf";
// var gsTickerSwf = "http://test.didi.jp/mars_sheba2008/http/download/blogparts04/blogparts.swf";
//クリック後のSWF
var gsFloatSwf = 'http://sheba.jp/download/blogparts04/full_blogparts.swf';
// var gsFloatSwf = 'http://test.didi.jp/mars_sheba2008/http/download/blogparts04/full_blogparts.swf';

//ブログに張るSWFのID
var gsTickerId = "blogparts";

//クリック後のSWFのID
var gsFloatId = "full_blogparts";
var gsFloatBgId = "full_blogparts";


var blogWidth = 150;
var blogHeight = 246;

var giFloatHeight = 200;
var giFloatLeft = 0;

// フロートTickerを表示する
var gbShowFlg = 0;
var giFloatNum = 0;

// MacIEチェックを行う
bMacIeFlg = CheckMacIe();

// Tikerを作成する
MakeTicker( blogWidth, blogHeight );

// onLoad時に実行する
//AddLoadFunction(ShowPage, 1);

/********************************************************************************
	関数名		AddLoadFunction
	機能		BodyのLoadイベント時に実行する関数を追加する
	
	入力		fFunction		関数名（「"」で囲まずに指定する）
				sArg			関数の引数（"AAA,BBB"というように、カンマ区切りの文字列）
	出力		なし
	
	使い方		この関数は、<body onLoad="">が出現する後に実行すること。
				同様に、この関数が実行されたあとに、window.onload=function();が設定されると
				それまでの関数は無効となる。
				
				引数を使用する場合は、カンマ区切りの文字列を渡す。
				実際の関数内で、カンマ区切りの文字を配列にsplitして使う。
********************************************************************************/
function AddLoadFunction(fFunction, sArg){
	var fBaseOnload = window.onload;
	
	// 既存のonLoadイベントが存在しない場合
	if(typeof window.onload != 'function'){
		// 追加された関数をonLoadイベントとする
		window.onload = function(){
			// 新しい関数を実行する
			fFunction(sArg);
		}
	// 既存のonLoadイベントが存在する場合
	}else{
		window.onload = function(){
			// 元の関数を実行する
			fBaseOnload();
			// 新しい関数を実行する
			fFunction(sArg);
		}
	}
}



/******************************************************************************
	関数名		MakeTicker
	機能		ティッカーを作成する
	
	入力		なし
	出力		document.writeによるHTML出力
******************************************************************************/
function MakeTicker(bWidth, bHeight){
	var sTickerUrl = gsTickerSwf;
	
	var sHtml = "";
	sHtml += '<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=8,0,0,0" width="' + bWidth + '" height="' + bHeight + '" id="' + gsTickerId + '" align="middle">';
	sHtml += '<param name="allowScriptAccess" value="always" />';
	sHtml += '<param name="movie" value="' + sTickerUrl + '" />';
	sHtml += '<param name="quality" value="high" />';
	sHtml += '<param name="bgcolor" value="#ffffff" />';
	sHtml += '<param name="wmode" value="transparent" />';
	sHtml += '<embed wmode="transparent" src="' + sTickerUrl + '" quality="high" bgcolor="#ffffff" width="' + bWidth + '" height="' + bHeight + '" name="' + gsTickerId + '" align="middle" allowScriptAccess="always" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" />';
	sHtml += '</object>';
	
	document.write(sHtml);
}


/********************************************************************************
	関数名		ShowPage
	機能		Flashレイヤーを表示、非表示する
	
	ポイント	フローティングレイヤーの表示サイズは
				SWFをクリックするたびに再計算する。
				
				フローティングレイヤーの中身を新しいSWFソースで入れ替えることで
				Flashを初期化する。
				
				MacIEの場合のみ、表示、非表示のたびに
				レンダリングしなおすために、スクロール処理を入れる。
	
	入力		sMode	1:表示  0:非表示
	出力		なし
	
	処理概要	
				1. 現在表示されている場合
				 1.0. オブジェクト名を作成する
				 1.1. 表示モードの場合
				  1.1.2. ポジションを移動して終了する
				 1.2. 非表示モードの場合
				  1.2.2. 対象オブジェクトを削除する
				2. 現在表示されていない場合
				 2.1. 表示モードの場合
				  2.1. フロートオブジェクトを作成する
				  2.2. フロートオブジェクトIDを作成する
				  2.3. フロートオブジェクトをbodyに追加する
				 2.2. 非表示モードの場合
				  2.2.1. 何もしない
				3. MacIEの場合
				 3.1. 再レンダリングする
********************************************************************************/
function ShowPage(sMode){
	var oLayer;
	var sId;
	var iLayerTop;
	var iLayerWidth;
	var iLayerHeight;


	// 非表示モードの場合
	if(sMode != 1) {
		
		//location.reload();
		//return;
		
		// オブジェクトIDを作成する
		sId = gsFloatId;
		oLayer = document.getElementById(sId);
		
		// オブジェクトを削除する
		oLayer.style.display='none';
		oLayer.innerHTML='';
		document.getElementsByTagName('body')[0].removeChild(oLayer);

		// オブジェクトIDを作成する
		sId = gsFloatBgId;
		oLayer = document.getElementById(sId);
		
		// オブジェクトを削除する
		oLayer.style.display='none';
		oLayer.innerHTML='';
		document.getElementsByTagName('body')[0].removeChild(oLayer);
		
		// フラグを更新する
		gbShowFlg = 0;
		
		// 自動調整をオフにする
		clearInterval(iIntervalId);
		clearInterval(iIntervalBgId);
		
		//Flash内の関数を呼び出す
		callASFunction();
		
		return;
	}
	
	
	// 現在表示されている場合
	if(gbShowFlg == 1){

		return;
			
		
	// 現在表示されていない場合
	} else {
		
		// 表示モードの場合
		if(sMode == 1){


			// 背景ボックスを作成する ***************************************

			// オブジェクトを作成する
			oLayer = document.createElement('DIV');
			oLayer.id = gsFloatBgId;
			oLayer.bNotResize = false;
			oLayer.style.position = "absolute";
			oLayer.style.zIndex = 999;
			oLayer.style.display = "block";
			//oLayer.style.backgroundColor="white";
			
			
			// フローティングレイヤーのサイズを算出する
			iLayerWidth = GetWindowSize("width");
			iLayerHeight = GetWindowSize("height");
			
			oLayer.style.width = "100%";
			oLayer.style.height = "100%";
			// フローティングレイヤーにスタイルを指定する
			oLayer.style.top = GetScrollPosition("top") + "px";
			oLayer.style.left = GetScrollPosition("left") + "px";
			

			// SWFタグを作成する
			var sHtml = "&nbsp;";
			
			// SWFを挿入する
			oLayer.innerHTML = sHtml;
			
			// オブジェクトを追加する
			document.getElementsByTagName('body')[0].appendChild(oLayer);

			iIntervalBgId = setInterval("setLayPosition('" + gsFloatBgId + "')", 100);


			
			// Flash表示用レイヤー { ***************************************
			
			// オブジェクトを作成する
			oLayer = document.createElement('DIV');
			oLayer.id = gsFloatId;

			oLayer.style.position = "absolute";
			oLayer.style.zIndex = 1000;
			oLayer.style.display = "block";
			
			// フローティングレイヤーのサイズを算出する
			iLayerWidth = GetWindowSize("width");
			iLayerHeight = GetWindowSize("height");
			
			oLayer.style.width = "100%";
			oLayer.style.height = "100%";
			// フローティングレイヤーにスタイルを指定する
			oLayer.style.top = GetScrollPosition("top") + "px";
			oLayer.style.left = GetScrollPosition("left") + "px";
					
			// SWFタグを作成する
			var sHtml = "";
			sHtml += '<body style="margin: 0; padding: 0;">';
			sHtml += '<table style="background-color:transparent; border:0; padding:0; margin:0; padding-right:0; text-align:center; vertical-align:middle"  border="0" cellpadding="0" cellspacing="0" width="100%" height="100%">';
			sHtml += '<tr><td align="center" valign="middle" style="padding:0; margin:0; border:none; background-color:transparent; text-align:center; vertical-align:middle" width="100%" height="100%">';
			sHtml += '<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=8,0,0,0" width="100%" height="100%" align="middle">';
			sHtml += '<param name="allowScriptAccess" value="always" />';
			sHtml += '<param name="movie" value="' + gsFloatSwf + '" />';
			sHtml += '<param name="quality" value="high" />';
			sHtml += '<param name="wmode" value="transparent" />';
			sHtml += '<param name="salign" value="lt" />';
			sHtml += '<param name="SWLIVECONNECT" value="TRUE" />';
			sHtml += '<embed SWLIVECONNECT="TRUE" salign="lt" align="middle" src="' + gsFloatSwf + '" quality="high" wmode="transparent" width="100%" height="100%" align="middle" allowScriptAccess="always" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" />';
			sHtml += '</object></td></tr></table></body>';
					
			// SWFを挿入する
			oLayer.innerHTML = sHtml;
			
			// オブジェクトを追加する

			document.getElementsByTagName('body')[0].appendChild(oLayer);

			iIntervalId = setInterval("setLayPosition('" + gsFloatId + "')", 100);
			
			//スクロール対応
			try {  
				window.addEventListener("scroll", function(e){
					oLayer.style.top = GetScrollPosition("top") + "px";
					oLayer.style.left = GetScrollPosition("left") + "px";	
				},false);
			} catch (e) {  
				window.attachEvent("onscroll", function(e){
					oLayer.style.top = GetScrollPosition("top") + "px";
					oLayer.style.left = GetScrollPosition("left") + "px";	
				});
			}  
			
			// フラグを変更する
			gbShowFlg = 1;
		}
	}
	
	// MacIEの場合
	if(bMacIeFlg == 1){
		// 再レンダリングする
		window.scrollBy(0, 1);
	}
	
}

function callASFunction(){
  	document[gsTickerId].setMessage();
}

function replaceResize(){
	alert("scroll");
}
function tagheuerProductsResize(){
	tagheuerProductsObject.replaceResize();
}

function require( uri ) {
  var script  = document.createElement( 'script' );
  script.type = 'text/javascript';
  script.src  = uri;
  var head    = document.getElementsByTagName( 'head' )[0];
  head.appendChild( script );
}


function setMenu() {
　　x = document.body.scrollLeft;
　　y = document.body.scrollTop;
  oLayer.style.left = x;
  oLayer.style.top = y;　
}

function setLayPosition(sId){
	var oTarget = document.getElementById(sId);

	if(CheckBrowserModeForTicker()){
		oTarget.style.width = GetWindowSize("width") + "px";
		oTarget.style.height = GetWindowSize("height") + "px";
	}
	
	oTarget.style.top = GetScrollPosition("top") + "px";
	oTarget.style.left = GetScrollPosition("left") + "px";
}

/********************************************************************************
	関数名		GetMiddlePosition
	機能		現在のスクロール位置でのミドルポジションを取得する
	
	入力		sMode			top / left
	出力		iPositionX		X座標
				iPositionY		Y座標
	
	処理概要	1. Windowサイズを取得する
				2. スクロール位置を取得する
				3. ミドルポジションを算出する
				4. ミドルポジションを返して終了する
********************************************************************************/
function GetMiddlePosition(sMode){
	
	// Windowサイズを取得する
	var iWindowWidth, iWindowHeight;
	iWindowWidth = GetWindowSize('width');
	iWindowHeight = GetWindowSize('height');
	
	// スクロール位置を取得する
	var iScrollTop, iScrollLeft;
	iScrollTop = GetScrollPosition('top');
	iScrollLeft = GetScrollPosition('left');
	
	// ミドルポジションを算出する
	var iMiddleTop = iWindowHeight / 2 + iScrollTop;
	var iMiddleLeft = iWindowWidth / 2 + iScrollLeft;
	
	// topを返す場合
	if(sMode == "top"){
		return iMiddleTop;
	} else {
		return iMiddleLeft;
	}
	
}

/********************************************************************************
	関数名		GetScrollPosition
	機能		スクロール位置を算出する
	
	入力		sMode		top / left
	出力		iPosition
********************************************************************************/
function GetScrollPosition(sMode){

	var iScrollPosition;

	if(sMode == "left"){
		if(self.pageXOffset){
			iScrollPosition = self.pageXOffset;
		// Explorer 6 Strict
		}else if(document.documentElement && document.documentElement.scrollLeft){
			iScrollPosition = document.documentElement.scrollLeft;
		// all other Explorers
		}else if(document.body){
			iScrollPosition = document.body.scrollLeft;
		}
	} else {

		if(self.pageYOffset){
			iScrollPosition = self.pageYOffset;
		// Explorer 6 Strict
		}else if(document.documentElement && document.documentElement.scrollTop){
			iScrollPosition = document.documentElement.scrollTop;
		// all other Explorers
		}else if(document.body){
			iScrollPosition = document.body.scrollTop;
		}
	}
	
	return iScrollPosition;
}

/********************************************************************************
	関数名		GetWindowSize
	機能		ウィンドウサイズを取得する
	
	入力		sMoe		"width" | "height"
*********************************************************************************/
function GetWindowSize(sMode){
	var iWindowWidth, iWindowHeight;
	
	// all except Explorer
	if(self.innerHeight){
		iWindowWidth = self.innerWidth;
		iWindowHeight = self.innerHeight;
	// Explorer 6 Strict Mode
	}else if(document.getElementById && (document.compatMode=='CSS1Compat')){
		iWindowWidth = document.documentElement.clientWidth;
		iWindowHeight = document.documentElement.clientHeight;
	// other Explorers
	}else if(document.body){
		iWindowWidth = document.body.clientWidth;
		iWindowHeight = document.body.clientHeight;
	}
	
	if(sMode == "width"){
		return (iWindowWidth);
	} else {
		return (iWindowHeight);
	}
}
	

/********************************************************************************
	関数名		CheckMacIe
	機能		MacIEであることをチェックする
********************************************************************************/
function CheckMacIe(){
	var sOs = ds_GetOsName();
	var sNavigator = ds_GetNavigatorName();
	
	if((sOs == "MacOSX" || sOs == "MacOS") && sNavigator == "Explorer"){
		return true;
	} else {
		return false;
	}
}

/********************************************************************************
	関数名		CheckBrowserModeForTicker
				ds_GetOsName
				ds_GetNavigatorName
	
	機能		ブラウザチェック
*********************************************************************************/
function CheckBrowserModeForTicker(){
	var sOs = ds_GetOsName();
	var sBrowser = ds_GetNavigatorName();

	if(sOs == "Windows" && sBrowser == "Explorer"){
		return true;
	}
	return false;
}


	
/********************************************************************************
	関数名		ds_GetOsName
	機能		OS情報を取得する
	
	入力		なし
	出力		sOsData		Os情報 ("MacOSX","Windows")
********************************************************************************/
function ds_GetOsName()
{
	var uAgent  = navigator.userAgent.toUpperCase();
	if (uAgent.indexOf("MAC OS X") >= 0) return "MacOSX";
	if (uAgent.indexOf("MAC") >= 0) return "MacOS";
	if (uAgent.indexOf("WIN") >= 0) return "Windows";
	if (uAgent.indexOf("X11") >= 0) return "UNIX";
	return "";
}
function ds_GetNavigatorName(){
	if(navigator.IBM_HPR) return "HomepageReader";
	
	aName  = navigator.userAgent.toUpperCase();
	if (aName.indexOf("SAFARI") >= 0) return "Safari";
	if (aName.indexOf("CHIMERA") >= 0) return "Camino";
	if (aName.indexOf("OPERA") >= 0) return "Opera";
	
	aName = navigator.appName.toUpperCase();
	if (aName.indexOf("NETSCAPE") >= 0)  return "Netscape";
	if (aName.indexOf("MICROSOFT") >= 0) return "Explorer";
	return "";
}

