From efc59098772814b38b7705e6867c8d57243c7c7e Mon Sep 17 00:00:00 2001 From: anekos Date: Wed, 4 Feb 2009 11:49:59 +0000 Subject: 自動フルスクリーン git-svn-id: http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk@29531 d0d07461-0603-4401-acd4-de1884942a52 --- stella.js | 80 +++++++++++++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 65 insertions(+), 15 deletions(-) diff --git a/stella.js b/stella.js index 1b41f27..41e8f49 100644 --- a/stella.js +++ b/stella.js @@ -113,21 +113,20 @@ let PLUGIN_INFO = /* {{{ TODO ・Icons - ・Other video hosting websites ・auto fullscreen ・動的な command の追加削除 (nice rabbit!) ・ツールチップみたいな物で、マウスオー馬したときに動画情報を得られるようにしておく。 ・外から呼ぶべきでない関数(プライベート)をわかりやすくしたい ・argCount の指定が適当なのを修正 (動的な userCommand と平行でうまくできそう?) ・実際のプレイヤーが表示されるまで待機できようにしたい(未表示に時にフルスクリーン化すると…) - ・コメント欄でリンクされている動画も関連動画として扱いたい - -> "その3=>sm666" みたいなやつ - -> リンクはともかくタイトルの取得がムツカシー ・isValid とは別にプレイヤーの準備が出来ているか?などをチェックできる関数があるほうがいいかも -> isValid ってなまえはどうなの? -> isReady とか ・パネルなどの要素にクラス名をつける +FIXME + ・this.last.fullscreen = value; + MEMO ・prototype での定義順: 単純な値 initialize finalize (get|set)ter メソッド ・関数やプロパティは基本的にアルファベット順にならべる。 @@ -352,6 +351,10 @@ Thanks: this.initialize.apply(this, arguments); + this.last = { + fullscreen: false + }; + function setf (name, value) ((self.functions[name] === undefined) && (self.functions[name] = value || '')); @@ -442,11 +445,16 @@ Thanks: get fileURL () undefined, + get large () this.fullscreen, + set large (value) (this.fullscreen = value), + get maxVolume () 100, get muted () undefined, set muted (value) value, + get ready () undefined, + get relatedIDs () undefined, get relations () { @@ -463,9 +471,6 @@ Thanks: get repeating () undefined, set repeating (value) value, - get large () this.fullscreen, - set large (value) (this.fullscreen = value), - get state () undefined, get statusText () this.timeCodes, @@ -655,13 +660,13 @@ Thanks: YouTubePlayer.OUTER_NODES.forEach( function (id) { let (node = U.getElementById(id)) { - liberator.log(node) node && f(node); } } ); } + this.last.fullscreen = value; this.storage.fullscreen = value; // changeOuterNodes(value); @@ -690,6 +695,8 @@ Thanks: get player () U.getElementByIdEx('movie_player'), + get ready () !!this.player, + get relatedIDs () { let result = []; let doc = content.document; @@ -820,7 +827,14 @@ Thanks: get comment () this.player.ext_isCommentVisible(), set comment (value) (this.player.ext_setCommentVisible(value), value), - get currentTime () parseInt(this.player.ext_getPlayheadTime()), + get currentTime () { + try { + return parseInt(this.player.ext_getPlayheadTime()) + } catch (e) { + liberator.log(e) + liberator.log(e.stack) + } + }, set currentTime (value) (this.player.ext_setPlayheadTime(U.fromTimeCode(value)), this.currentTime), get fileExtension () '.flv', @@ -895,6 +909,8 @@ Thanks: function fixFullscreen () ((InVimperator && liberator.mode === modes.COMMAND_LINE) || setTimeout(turnOnMain, 500)); + this.last.fullscreen = value; + // メイン value = !!value; if (this.storage.fullscreen === value) @@ -923,6 +939,8 @@ Thanks: get playerContainer () U.getElementByIdEx('flvplayer_container'), + get ready () !!(this.player && this.player.ext_getVideoSize), + get relatedIDs () { if (this.__rid_last_url == U.currentURL()) return this.__rid_cache || []; @@ -956,7 +974,6 @@ Thanks: let links = U.xpathGets(xpath + '/a') .filter(function (it) /watch\//.test(it.href)) .map(function(v) v.textContent); - liberator.log(comment) links.forEach(function (link) { let r = RegExp('(?:^|[\u3000\\s\\>])([^\u3000\\s\\>]+)\\s*').exec(comment); if (r) @@ -1423,9 +1440,12 @@ Thanks: disable: function () { this.hidden = true; - if (this.timerHandle) { - clearInterval(this.timerHandle); - this.timerHandle = null; + if (this.__updateTimer) { + clearInterval(this.__updateTimer); + delete this.__updateTimer; + } + if (this.__autoFullscreenTimer) { + clearInterval(this.__autoFullscreenTimer); } }, @@ -1435,8 +1455,8 @@ Thanks: for (let name in this.toggles) { this.toggles[name].hidden = !this.player.has(name, 't'); } - if (!this.timerHandle) { - this.timerHandle = setInterval(U.bindr(this, this.update), 500); + if (!this.__updateTimer) { + this.__updateTimer = setInterval(U.bindr(this, this.update), 500); } }, @@ -1447,6 +1467,8 @@ Thanks: }, update: function () { + if (!(this.isValid && this.player.ready)) + return; this.labels.main.text = this.player.statusText; this.labels.volume.text = this.player.volume; for (let name in this.toggles) { @@ -1479,6 +1501,19 @@ Thanks: if (this.__valid !== this.isValid) { (this.__valid = this.isValid) ? this.enable() : this.disable(); } + if (this.isValid) { + clearInterval(this.__onReadyTimer); + this.__onReadyTimer = setInterval( + U.bindr(this, function () { + if (this.player && this.player.ready) { + clearInterval(this.__onReadyTimer); + delete this.__onReadyTimer; + this.onReady(); + } + }), + 200 + ); + } }, onMainClick: function (event) { @@ -1499,6 +1534,21 @@ Thanks: onPlayClick: function () this.player.play(), + onReady: function () { + if (this.player.last.fullscreen && !this.__autoFullscreenTimer) { + this.__autoFullscreenTimer = setInterval( + U.bindr(this, function () { + if (!this.player.ready) + return; + clearInterval(this.__autoFullscreenTimer) + setTimeout(U.bindr(this, function () (this.player.fullscreen = true), 1000)); + delete this.__autoFullscreenTimer; + }), + 200 + ); + } + }, + onRepeatClick: function () this.player.toggle('repeating'), onRelationsRootPopupshowing: function () { -- cgit v1.2.3