setFlags(\SplFileObject::READ_CSV | \SplFileObject::SKIP_EMPTY | \SplFileObject::READ_AHEAD); $file->setCsvControl("\t") ; foreach ($file as $lno => $line) { # if ( preg_match( '/^#/', $line[$lno][0] ) ) { if ( preg_match( '/^##/', $line[0] ) ) { // comment line continue ; } else if ( preg_match( '/^#[0-9a-zA-Z]/', $line[0] ) ) { // comment lines (dummy event) $wk_evid = $line[0] ; $wk_evid = preg_replace( '/^#/', "", $wk_evid ) ; $dmyevents[$wk_evid] = array() ; $dmyevents[$wk_evid]["event_id"] = $wk_evid ; $dmyevents[$wk_evid]["event_title"] = $line[1] ; $dmyevents[$wk_evid]["event_start"] = $line[2] ; $dmyevents[$wk_evid]["event_end"] = $line[3] ; $dmyevents[$wk_evid]["event_log_interval"] = $line[4] ; $dmyevents[$wk_evid]["event_log_preset"] = $line[5] ; $dmyevents[$wk_evid]["event_log_detailat"] = $line[6] ; $dmyevents[$wk_evid]["append_comment"] = $line[7] ; $dmyevents[$wk_evid]["event_env"] = $line[8] ; continue ; } else if ( preg_match( '/^#-/', $line[0] ) ) { // comment lines (pre event) $wk_evid = $line[0] ; $wk_evid = preg_replace( '/^#-/', "", $wk_evid ) ; $preevents[$wk_evid] = array() ; $preevents[$wk_evid]["event_id"] = $wk_evid ; $preevents[$wk_evid]["event_title"] = $line[1] ; $preevents[$wk_evid]["event_start"] = $line[2] ; $preevents[$wk_evid]["event_end"] = $line[3] ; $preevents[$wk_evid]["event_log_interval"] = $line[4] ; $preevents[$wk_evid]["event_log_preset"] = $line[5] ; $preevents[$wk_evid]["event_log_detailat"] = $line[6] ; $preevents[$wk_evid]["append_comment"] = $line[7] ; continue ; } else { $wk_evid = $line[0] ; $events[$wk_evid] = array() ; $events[$wk_evid]["event_id"] = $wk_evid ; $events[$wk_evid]["event_title"] = $line[1] ; $events[$wk_evid]["event_start"] = $line[2] ; $events[$wk_evid]["event_end"] = $line[3] ; $events[$wk_evid]["event_log_interval"] = $line[4] ; $events[$wk_evid]["event_log_preset"] = $line[5] ; $events[$wk_evid]["event_log_detailat"] = $line[6] ; $events[$wk_evid]["append_comment"] = $line[7] ; } } function puts_normalevent( $event_id, $events_array, $short_title = "" ) { global $base_host ; $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; $ev_title = ( $short_title == "" ) ? $events_array[$event_id]["event_title"] : $short_title ; $szrtn= sprintf('%s (%s~%s) SRページ', $base_host, $event_id, $event_id, $ev_title, // $event_id, $events_array[$event_id]["event_start"], $ev_endstr, $event_id ) ; return $szrtn ; } function puts_subevent( $event_id, $events_array, $with_period, $short_title = "" ) { global $base_host ; $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; if ( $short_title != "" ) { $ev_title = $short_title ; } else { $ev_title = $events_array[$event_id]["event_title"] ; // $ev_title = preg_replace( '/^(【[^】][^】]*】).*$/', "$1", $ev_title ) ; // $ev_title = preg_replace( '/^(【[^】]+】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(【.*】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(《.*》).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^([^:]*):.*$/', "$1", $ev_title ) ; } if ( $with_period == 1 ) { $ev_period = sprintf( " (%s~%s) ", $events_array[$event_id]["event_start"], $ev_endstr ) ; } else { $ev_period = " " ; } $szrtn= sprintf('%s%sSRページ', $base_host, $event_id, $event_id, $ev_title, // $event_id, $ev_period, $event_id ) ; return $szrtn ; } // normal event with hover function puts_normaleventR( $event_id, $events_array, $short_title = "" ) { global $base_host ; $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; $ev_title = ( $short_title == "" ) ? $events_array[$event_id]["event_title"] : $short_title ; $szrtn= sprintf('%sthumbnail (%s~%s) SRページ', $base_host, $event_id, $event_id, $ev_title, $event_id, $events_array[$event_id]["event_start"], $ev_endstr, $event_id ) ; return $szrtn ; } // sub event with hover function puts_subeventR( $event_id, $events_array, $with_period, $short_title = "" ) { global $base_host ; $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; if ( $short_title != "" ) { $ev_title = $short_title ; } else { $ev_title = $events_array[$event_id]["event_title"] ; // $ev_title = preg_replace( '/^(【[^】][^】]*】).*$/', "$1", $ev_title ) ; // $ev_title = preg_replace( '/^(【[^】]+】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(【.*】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(《.*》).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^([^:]*):.*$/', "$1", $ev_title ) ; } if ( $with_period == 1 ) { $ev_period = sprintf( " (%s~%s) ", $events_array[$event_id]["event_start"], $ev_endstr ) ; } else { $ev_period = " " ; } $szrtn= sprintf('%sthumbnail%sSRページ', $base_host, $event_id, $event_id, $ev_title, $event_id, $ev_period, $event_id ) ; return $szrtn ; } // pre event ( announced and not start yet, not yet registerd ) function puts_normaldmyevent( $event_id, $events_array, $short_title = "", $sr_linked = 0, $is_dmy = 0 ) { global $base_host ; global $events ; global $dmyevents ; global $preevents ; if ( array_key_exists( $event_id, $events ) ) { $is_dmy = 0 ; $sr_linked = 1 ; $events_array = $events ; } else if ( array_key_exists( $event_id, $dmyevents ) ) { $is_dmy = 1 ; // $sr_linked = 1 ; // both value supposed, so use function's parameter . // ' $events_array = $dmyevents ; } else if ( array_key_exists( $event_id, $preevents ) ) { $is_dmy = 0 ; // $sr_linked = 1 ; // both value supposed, so use function's parameter . // ' $events_array = $preevents ; } $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; $ev_title = ( $short_title == "" ) ? $events_array[$event_id]["event_title"] : $short_title ; if ( $sr_linked == 1 ) { $sr_link = sprintf( ' SRページ', $event_id ) ; } else { $sr_link = "" ; } if ( $is_dmy == 1 ) { $dmy_font_s = "" ; $dmy_font_e = "" ; $pre_str = '' ; } else { $dmy_font_s = '' ; $dmy_font_e = '' ; $pre_str = ' [予定]' ; } $szrtn= sprintf('%s%s (%s~%s)%s%s%s', $dmy_font_s, $event_id, $ev_title, $events_array[$event_id]["event_start"], $ev_endstr, $sr_link, $pre_str, $dmy_font_e ) ; return $szrtn ; } function puts_subdmyevent( $event_id, $events_array, $with_period, $short_title = "" , $sr_linked = 0, $is_dmy = 0 ) { global $base_host ; global $events ; global $dmyevents ; global $preevents ; if ( array_key_exists( $event_id, $events ) ) { $is_dmy = 0 ; // $sr_linked = 1 ; $events_array = $events ; } else if ( array_key_exists( $event_id, $dmyevents ) ) { $is_dmy = 1 ; // $sr_linked = 1 ; // both value supposed, so use function's parameter . // ' $events_array = $dmyevents ; } else if ( array_key_exists( $event_id, $preevents ) ) { $is_dmy = 0 ; // $sr_linked = 1 ; // both value supposed, so use function's parameter . // ' $events_array = $preevents ; } $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; if ( $short_title != "" ) { $ev_title = $short_title ; } else { $ev_title = $events_array[$event_id]["event_title"] ; // $ev_title = preg_replace( '/^(【[^】][^】]*】).*$/', "$1", $ev_title ) ; // $ev_title = preg_replace( '/^(【[^】]+】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(【.*】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(《.*》).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^([^:]*):.*$/', "$1", $ev_title ) ; } if ( $with_period == 1 ) { $ev_period = sprintf( " (%s~%s) ", $events_array[$event_id]["event_start"], $ev_endstr ) ; } else { $ev_period = " " ; } if ( $sr_linked == 1 ) { $sr_link = sprintf( 'SRページ ', $event_id ) ; } else { $sr_link = "" ; } if ( $is_dmy == 1 ) { $dmy_font_s = "" ; $dmy_font_e = "" ; $pre_str = '' ; } else { $dmy_font_s = '' ; $dmy_font_e = '' ; $pre_str = '[予定]' ; } $szrtn= sprintf('%s%s%s%s%s%s', $dmy_font_s, $event_id, $ev_title, $ev_period, $sr_link, $pre_str, $dmy_font_e ) ; return $szrtn ; } // ----- block event function puts_subblkeventR( $event_id, $events_array, $with_period, $short_title = "", $sr_linked = 0, $is_dmy = 0 ) { global $base_host ; global $dmyevents ; $events_array = $dmyevents ; /// Note: block event registerd like #major_debut_sf/block_ranking/29665-901 $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; if ( $short_title != "" ) { $ev_title = $short_title ; } else { $ev_title = $events_array[$event_id]["event_title"] ; // $ev_title = preg_replace( '/^(【[^】][^】]*】).*$/', "$1", $ev_title ) ; // $ev_title = preg_replace( '/^(【[^】]+】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(【.*】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(《.*》).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^([^:]*):.*$/', "$1", $ev_title ) ; } if ( $with_period == 1 ) { $ev_period = sprintf( " (%s~%s) ", $events_array[$event_id]["event_start"], $ev_endstr ) ; } else { $ev_period = " " ; } $event_id_base = preg_replace( '/^([^\/]*)\/*$/', "$1", $event_id ) ; $event_id_out_block = preg_replace( '/\//', "-_-", $event_id ) ; $event_id_out_direct = preg_replace( '/-_-block_ranking/', "", $event_id_out_block ) ; $srlnkstr="" ; if ( $sr_linked == 1 ) { $tmp_pos = strpos( $events_array[$event_id]["event_env"], "SRURL=" ) ; $tmp_srurl = "" ; if ( $tmp_pos !== false ) { $tmp_evenvs = explode( ';', $events_array[$event_id]["event_env"] ) ; $tmp_evenv_kv = array() ; foreach ( $tmp_evenvs as $evenv ) { $tmp_env_kv = explode('=', $evenv, 2 ) ; $tmp_evenv_kv[$tmp_env_kv[0]] = $tmp_env_kv[1] ; if ( $tmp_env_kv[0] == "SRURL" ) { $tmp_srurl = $tmp_env_kv[1] ; $tmp_srurl = preg_replace( '/"/', '', $tmp_srurl ) ; break ; } } $srlnkstr= sprintf('SRページ', $tmp_srurl ) ; } else { $srlnkstr= sprintf('SRページ', $event_id ) ; } } if ( $is_dmy == 0 ) { $szrtn= sprintf('%sthumbnail%s%s', $base_host, $event_id_out_block, $event_id_out_block, $ev_title, $event_id_out_block, $ev_period, $srlnkstr ) ; } else { ### dmy not has puimg class $szrtn= sprintf('%s%s%s', $event_id_out_block, $ev_title, $ev_period, $srlnkstr ) ; } /* $szrtn= sprintf('%sthumbnail%s', $base_host, $event_id_out_block, $event_id_out_block, $ev_title, $event_id_out_block, $ev_period ) ; */ return $szrtn ; } function puts_subblkevent( $event_id, $events_array, $with_period, $short_title = "", $sr_linked = 0, $is_dmy = 0 ) { global $base_host ; global $dmyevents ; $events_array = $dmyevents ; /// Note: block event registerd like #major_debut_sf/block_ranking/29665-901 $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; if ( $short_title != "" ) { $ev_title = $short_title ; } else { $ev_title = $events_array[$event_id]["event_title"] ; // $ev_title = preg_replace( '/^(【[^】][^】]*】).*$/', "$1", $ev_title ) ; // $ev_title = preg_replace( '/^(【[^】]+】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(【.*】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(《.*》).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^([^:]*):.*$/', "$1", $ev_title ) ; } if ( $with_period == 1 ) { $ev_period = sprintf( " (%s~%s) ", $events_array[$event_id]["event_start"], $ev_endstr ) ; } else { $ev_period = " " ; } $event_id_base = preg_replace( '/^([^\/]*)\/*$/', "$1", $event_id ) ; $event_id_out_block = preg_replace( '/\//', "-_-", $event_id ) ; $event_id_out_direct = preg_replace( '/-_-block_ranking/', "", $event_id_out_block ) ; $srlnkstr="" ; if ( $sr_linked == 1 ) { $tmp_pos = strpos( $events_array[$event_id]["event_env"], "SRURL=" ) ; $tmp_srurl = "" ; if ( $tmp_pos !== false ) { $tmp_evenvs = explode( ';', $events_array[$event_id]["event_env"] ) ; $tmp_evenv_kv = array() ; foreach ( $tmp_evenvs as $evenv ) { $tmp_env_kv = explode('=', $evenv, 2 ) ; $tmp_evenv_kv[$tmp_env_kv[0]] = $tmp_env_kv[1] ; if ( $tmp_env_kv[0] == "SRURL" ) { $tmp_srurl = $tmp_env_kv[1] ; $tmp_srurl = preg_replace( '/"/', '', $tmp_srurl ) ; break ; } } $srlnkstr= sprintf('SRページ', $tmp_srurl ) ; } else { $srlnkstr= sprintf('SRページ', $event_id ) ; } } if ( $is_dmy == 0 ) { /* $szrtn= sprintf('%sthumbnail%s%s', $base_host, $event_id_out_block, $event_id_out_block, $ev_title, $event_id_out_block, $ev_period, $srlnkstr ) ; */ $szrtn= sprintf('%s%s%s', $base_host, $event_id_out_block, $event_id_out_block, $ev_title, $ev_period, $srlnkstr ) ; } else { ### dmy not has puimg class $szrtn= sprintf('%s%s%s', $event_id_out_block, $ev_title, $ev_period, $srlnkstr ) ; } /* $szrtn= sprintf('%sthumbnail%s', $base_host, $event_id_out_block, $event_id_out_block, $ev_title, $event_id_out_block, $ev_period ) ; */ return $szrtn ; } // ----- gift ranking event function puts_subgifteventR( $event_id, $events_array, $with_period, $short_title = "", $sr_linked = 0, $is_dmy = 0 ) { global $base_host ; global $dmyevents ; $events_array = $dmyevents ; /// Note: gift_ranking event registerd like #major_debut_sf/gift_ranking/29665 $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; if ( $short_title != "" ) { $ev_title = $short_title ; } else { $ev_title = $events_array[$event_id]["event_title"] ; // $ev_title = preg_replace( '/^(【[^】][^】]*】).*$/', "$1", $ev_title ) ; // $ev_title = preg_replace( '/^(【[^】]+】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(【.*】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(《.*》).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^([^:]*):.*$/', "$1", $ev_title ) ; } if ( $with_period == 1 ) { $ev_period = sprintf( " (%s~%s) ", $events_array[$event_id]["event_start"], $ev_endstr ) ; } else { $ev_period = " " ; } $event_id_base = preg_replace( '/^([^\/]*)\/*$/', "$1", $event_id ) ; $event_id_out_block = preg_replace( '/\//', "-_-", $event_id ) ; $event_id_out_direct = preg_replace( '/-_-block_ranking/', "", $event_id_out_block ) ; $srlnkstr="" ; if ( $sr_linked == 1 ) { $tmp_pos = strpos( $events_array[$event_id]["event_env"], "SRURL=" ) ; $tmp_srurl = "" ; if ( $tmp_pos !== false ) { $tmp_evenvs = explode( ';', $events_array[$event_id]["event_env"] ) ; $tmp_evenv_kv = array() ; foreach ( $tmp_evenvs as $evenv ) { $tmp_env_kv = explode('=', $evenv, 2 ) ; $tmp_evenv_kv[$tmp_env_kv[0]] = $tmp_env_kv[1] ; if ( $tmp_env_kv[0] == "SRURL" ) { $tmp_srurl = $tmp_env_kv[1] ; $tmp_srurl = preg_replace( '/"/', '', $tmp_srurl ) ; break ; } } $srlnkstr= sprintf('SRページ', $tmp_srurl ) ; } else { $srlnkstr= sprintf('SRページ', $event_id ) ; } } if ( $is_dmy == 0 ) { $szrtn= sprintf('%sthumbnail%s%s', $base_host, $event_id_out_block, $event_id_out_block, $ev_title, $event_id_out_block, $ev_period, $srlnkstr ) ; } else { ### dmy not has puimg class $szrtn= sprintf('%s%s%s', $event_id_out_block, $ev_title, $ev_period, $srlnkstr ) ; } return $szrtn ; } function puts_subgiftevent( $event_id, $events_array, $with_period, $short_title = "", $sr_linked = 0, $is_dmy = 0 ) { global $base_host ; global $dmyevents ; $events_array = $dmyevents ; /// Note: gift_ranking event registerd like #major_debut_sf/gift_ranking/29665 $ev_endstr = $events_array[$event_id]["event_end"] ; $ev_endstr = preg_replace( '/^[0-9][0-9][0-9][0-9]\//', "", $ev_endstr ) ; if ( $short_title != "" ) { $ev_title = $short_title ; } else { $ev_title = $events_array[$event_id]["event_title"] ; // $ev_title = preg_replace( '/^(【[^】][^】]*】).*$/', "$1", $ev_title ) ; // $ev_title = preg_replace( '/^(【[^】]+】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(【.*】).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^(《.*》).*$/', "$1", $ev_title ) ; $ev_title = preg_replace( '/^([^:]*):.*$/', "$1", $ev_title ) ; } if ( $with_period == 1 ) { $ev_period = sprintf( " (%s~%s) ", $events_array[$event_id]["event_start"], $ev_endstr ) ; } else { $ev_period = " " ; } $event_id_base = preg_replace( '/^([^\/]*)\/*$/', "$1", $event_id ) ; $event_id_out_block = preg_replace( '/\//', "-_-", $event_id ) ; $event_id_out_direct = preg_replace( '/-_-block_ranking/', "", $event_id_out_block ) ; $srlnkstr="" ; if ( $sr_linked == 1 ) { $tmp_pos = strpos( $events_array[$event_id]["event_env"], "SRURL=" ) ; $tmp_srurl = "" ; if ( $tmp_pos !== false ) { $tmp_evenvs = explode( ';', $events_array[$event_id]["event_env"] ) ; $tmp_evenv_kv = array() ; foreach ( $tmp_evenvs as $evenv ) { $tmp_env_kv = explode('=', $evenv, 2 ) ; $tmp_evenv_kv[$tmp_env_kv[0]] = $tmp_env_kv[1] ; if ( $tmp_env_kv[0] == "SRURL" ) { $tmp_srurl = $tmp_env_kv[1] ; $tmp_srurl = preg_replace( '/"/', '', $tmp_srurl ) ; break ; } } $srlnkstr= sprintf('SRページ', $tmp_srurl ) ; } else { $srlnkstr= sprintf('SRページ', $event_id ) ; } } if ( $is_dmy == 0 ) { // $szrtn= sprintf('%sthumbnail%s%s', $szrtn= sprintf('%s%s%s', $base_host, $event_id_out_block, $event_id_out_block, $ev_title, $ev_period, $srlnkstr ) ; } else { ### dmy not has puimg class $szrtn= sprintf('%s%s%s', $event_id_out_block, $ev_title, $ev_period, $srlnkstr ) ; } return $szrtn ; } ?>

SHOWROOM イベント ポイント推移グラフ公開所 (開催中イベントは*ほぼ*リアルタイム更新)

--- 序文等

ここでは、SHOWROOM で開催されるイベントのポイント推移グラフと数値データを公開しています。

リアルタイム(約5分毎更新)でのポイントの推移をグラフでご覧いただき、どういった時間帯・曜日・配信内容を行った場合にどういうポイント推移をしたのか、などの傾向分析もできてタイムテーブル作成時の参考にもなるかと思いますので、有効活用していただけましたら幸いです

(当サイト運営者はSHOWROOM社とは全く関係がありませんので、このサイトにルーム間の(過度の)競争・課金を煽る意図は一切ありません。寧ろ、昨今 目に余る、不必要なまでにスタート~決勝・本選まで分割したイベント(敗者復活イベントを別トーナメントにして更に数戦に分割するまでありますよね…)、無闇と枠を分割して枠数を稼いでいるイベント、敗者復活を含め配信者を疲弊させる長期間にわたるイベント等の増加は如何なものかと思っています。当サイトがそういう過競争を助長するという事であれば、早々に閉鎖させて頂く所存です)

○長いイベントが増えてきて見辛く、またページ表示に時間がかかるようになってきたので、<details>タグによる折りたたみ機能を利用する事に致しました。これにより、これまでページ内検索でピックアップできていたイベントが、必要な部分の折りたたみを展開しないとピックアップできなくなりました。過去ログ検索機能はいずれ実装する予定なのですが、それまではお手数をお掛け致して申し訳ないのですが折りたたみを展開して検索して頂けますよう、お願い致します。(2020.08.05)

※プレミアムライブについてですが、その性質上、プレミアムライブ配信中(~次回の通常ライブ配信まで?)はポイントデータが取得できません。イベント期間中にプレミアムライブを実施した場合、ポイントデータが取得できなくなったり異常値となる可能性が有りますので、予めご了承ください。

◎派生サイトとして LINE LIVE イベント ポイント推移グラフミクチャ イベント ポイント推移グラフCHRRZ イベント ポイント推移グラフ のサイトもあります。
Pococha、Mystaについては各サービス制約上、現時点で作成の予定は有りません。17liveについては作成可能ではありますが、日本語カテゴリのみの対応としてもデータ量が大きく、そもそも需要があるのか?という所で未対応です。

●諸事情により当面の間 Twitter での返信等ができません。@ ツイート・DMについては拝読しておりますので、問題点やデータ採取リクエスト等を頂けましたら、これまで通り出来る限り対応させて頂きたく存じます。ご不便をお掛け致しますが宜しくお願い致します。Twitterにログインして見る事は出来ない為、DMを下さる場合は画像やリンクではなく文字のみでご連絡いただけますよう重ねてお願い致します。(DMはTwitterからの通知メールで内容を読ませて頂いている為、です。通知メールでは画像やリンクはTwitterにログインして閲覧しないと読めないリンクに変換されてしまう為、内容が分りません。また、この宛先が普段読まない宛先なので、気付くのが遅れるケースが多くなっております…m(__)m DMはフォロー外からでも大丈夫です)
Twitter社の仕様変更等々により、DMの通知が送られて来なかったり、FF外からDMを下さった方のアカウントが凍結される事態が起きているようです。代替手段を用意中ですので、今しばらくお待ちください。
※当サイトは個人 [ムム@SR]によって作成されているサイトであり、 SHOWROOM株式会社とは無関係です。また、当サイト作成に当たり、イベントポイント取得に関するアイデアやソースコードはセッピーナ様ココログにて公開して下さっている内容が元となっております。この場を借りて深くお礼申し上げます。現在、御本家が Zenn にて『SHOWROOMのAPI、その使い方とサンプルソース』 を公開されていて、その連動企画として 『SHOWROOM イベント 獲得ポイント一覧』 というページを公開されています。こちらでは、「一覧」とは有りますがグラフは勿論表示できますし、私がやりたいな…と思いつつ放置しっぱなしになっているWEBからの取得イベント登録や、グラフの編集、枠毎の獲得ポイント・貢献者表示や貢献者の履歴(名前が変わっても対応)等々が実現されているので、是非ご覧頂ければと思います(前述のchouette様のTwitterからもご覧頂けます)。私の方は元々あった余りに…なイベントに加え、昨今のP〇p月直イベや TGC Showroom枠 といった酷い(雑な)イベントや、徹底して途中のポイントを隠すようなイベント、そしてブロック制導入でのUIその他の改悪、そもそもそれぞれのイベント内容(イベンター、運営状況)等々で一層 SHOWROOMへの興味が薄れつつあり、データ取得リクエストを頂いたイベント以外の登録がほぼ無くなって来ています…
◎SRという商用サイトのイベントや配信ルーム数など外来データ主体というデータ元の性質上、当サイトには広告や Cookie等による付加的な閲覧者情報の取得手段を一切含んでおりません。御覧の環境で広告やCookie設定、閲覧者情報の取得スクリプト等が確認される場合は、当サイトのオリジナル情報ではない(改変やframe、填め込みされたもの、など)と考えられますのでご注意ください。尚、同じくデータ元の性質上、データ・グラフの転載や二次使用について特に制限はございません。当サイトのグラフやデータを改変して使用される場合のみ、改変したことや改変部分が判り易いようにお願い致します。
◎当ページに掲載している事で、当該イベントへの参加を推奨するものではありません。 SRのイベント主催やオーガナイザー登録のハードルは かなり低いので、参加を検討する際には当該主催者の過去のイベントの運営状況や過去参加者の現状、信用情報・IR等々をよく調べた上での御参加をお勧めします。有名人や有名企業の名前が単に「使われているだけ」のケースもありますし、有名人・有名団体・有名雑誌だからといってもジャンルによっては素人に過ぎないイベントも多々あります(イベント自体の運営状況が場当たり的で計画性に欠けていたり[SR側担当者の当たり外れも有りますが、イベント掲載・公開が遅かったり参加承認が遅い、等も含みます]、参加者に不親切な日程設定や参加者サポートが殆ど為されない、途中でルールやスケジュールが変更になる、等々拙い場合は特典獲得後の対応・体制も推して知るべしです。そもそも有名であっても現在の内情は…な所も少なくありません。特に昨今の雑誌系有名どころの状況は本当に要注意です…[各自で調べてみて下さい])。個人的印象ですが、例えばイベントを徒に長期化・細分化する主催者も、イベント中~終了後を通して参加者を軽視する傾向が強いように思います(イベント自体の目的が自己保身的な資金集めや実績作り等々、他所にある所為かもしれません。そういった所にとってSRは他所と比べてメリットが少なくなりつつあり、他配信サイトに移る主催者が増えていますが、それも一つのシグナルだと考えて良いと思います。そういった主催のオーディションに合格したとしても、数年後にどうなったかについては過去イベントに幾つか例が有りますが敢えて書きません。夢や希望・貴重な時間の搾取に遭わないように、参加前に充分に調査をして欲しいと思います)。

☆実験的に、SHOWROOMのサイトで公表される貢献ランキング100位までの和や統計情報を表示するページを作成しています。>こちらからご利用ください。
SHOWROOMのイベント一覧表(並べ替え・検索機能付き)  : 開催中イベント近日開催イベント開催終了イベント  ☆データ取得予定イベント一覧
◎減算や重複アカウント(複垢、複数アカウント、複アカ)について説明ページを別に設けました。SRによるコメントの間引き(「バグではなく仕様です」「障害ではなく元々そういう仕様です」案件)にも触れています。こちらからご参照ください。
◎コメントが読まれない、と怒る前にこちらをご一読下さい。 以前より更に況して 読まれない、飛ばされる、コメントが無い、というコメントが増えたように思いますが、決して配信者の所為ではありません。(上記ページ内ですが、未だに配信内で「コメント読んでくれなかった」と怒る方が少なくないようなので再掲します)→(説明部分)
◎減算対象アカウントを見つける方法を上記説明ページに追加致しました。
◎最近、SMS認証をしていないユーザを違反だとか不正だとか言って不当に攻撃し、排斥しようとするリスナーが増えているようです。SMS認証をしていなくても、貢献ポイントが0のまま貢献できないという以外、特に問題はありませんし複アカと違ってSR規約違反でもありません(イベント等でも最初から貢献 0ptのままなので当然減算も有りませんし、ペナルティも有りません)。悪意をもっているからSMS認証しないという人も勿論いるのでしょうが、SMS認証のできないキャリア・サービスや端末を使用している方も少なからずおられますし、そういった方でも応援したいと思った配信者に応援コメントをしたり配信を視聴できることがSRの良さでもあります。配信者さんが誹謗中傷・荒らしコメントへの対応として御自身の配信をSMS認証者のみとする選択は権利でありお決めになられたルームの方針として何ら問題はありませんが、リスナーが妄りにSMS未認証のリスナーを攻撃して排斥する行為は逆にSMS未認証リスナーへの誹謗中傷(=規約違反)に当る可能性が有る事を認識してください。
◎SRのTimeTableを作る上で考慮した方が良い事等を書いたページも掲載してみました。後者の tipsページは特に超ドラフト版(書きかけ)ですので誤字・脱字・文の乱れ等は取敢えずご容赦ください。所々説明が足りなかったり画像の割り振り等も未済ですが、途中段階でもご参考になれば、と掲載させて頂いています。
◎SRの配主に信者さん向けに配信準備や星集めや3周枠の捨て星時刻告知等のチェックリストのページを作成してみました。枠の開始時刻と終了時刻を入力すると星集め開始時刻や捨て星の目安時刻なども表示できるようにしてありますので、リスナーさんにも有益ではないかと思います。こちらも即席ものなので、細かい不具合等はご容赦ください。配信者さん向けですが、3周枠、2周枠の可否や星集め開始時刻や捨て星時刻の概算時刻も表示しておりますので、リスナーさんにも参考になるのではないかと思います。現時点の可否判定は配信時間(長さ)だけですが、今後、前後枠の関係での判定等も追加していく予定です。チェックリストの動的編集(項目追加などの編集機能)も考慮中ですが、javascriptだけで実装すると再利用性が低いため(ブラウザを閉じたり再読み込みすると消えてしまう)、このままExcel等に読み込ませて配信者さん御自身の状況に合わせてカスタマイズして頂く叩き台的な使用を想定しています。[2023.01.05]
◎ブロックランキングの結果について、結果の発表方法が統一されていない可能性が有り、結果取得に失敗するケースが出ています。対応検討中ですが、当面、ブロックランキング方式のイベントについては結果取得が出来ないケースが有るかもしれません(結果発表当日にお知らせ下さいましたら対応できる事もあるかもしれませんが確約は致しかねます… [2023.01.12]
データの取得に関しては、イベントが始まった時点で初めてブロック制である事がわかるので、データ取得は自動判定でブロック制のデータ取得に移行でき量にしているのですが、URLが特殊な為、当ページやデータ取得イベント一覧のページにに自動で反映する事が出来ておりません。[2023/04/24 追記]
【要注意!】SHOWROOM配信内でのBGMについて (※ 2022/06/09 重大な誤りが有った為、大幅修正。2022/07/08追記)  最近、BGMを流して配信している配信者さんで、フリー音源ではないBGMを楽曲申請せずに使用している方が居られるようです。SHOWROOMでは、各自で全著作権者に許可を貰った楽曲か、フリー音源以外はBGMとして使用できません。つまり、自分で購入したものであっても、単に購入しただけでは市販の楽曲(ダウンロード曲やCD・DVD等)は BGMとしては使用できません (その楽曲を自分のSHOWROOM配信内でBGMとして使用してよいか、当該楽曲に紐づく全ての著作権者に自分で許可を貰う必要があります≒ほぼ不可能)。
 また、YouTube等の他の動画配信プラットホームの動画・BGMをその動画配信プラットホームを使用してBGMとして流すのも基本的にNGです(生活音と認められるケースを除く)。これは、テレビやラジオの番組を自分の配信で意図的に流しているのにほぼ等しい、と考えれば当然ダメな事は理解できると思いますが、例えば YouTube で公開されているフリー素材であっても、YouTube を使用して流す場合(=YouTubeアプリや、ブラウザ等でYouTubeを開いて流している状態)はコンテンツ制作関係者以外にYouTube社からも二次使用への使用許諾が必要となります(個人にはほぼ不可能。別途ダウンロードしてローカルファイル等、フリーコンテンツのみの状態にして使用する一手間が必要。勿論、途中にCMなどが入る場合はその部分はカットする必要がある[CMにも個別に著作権が有る])。そもそも、YouTubeで「著作権フリー」として公開されているコンテンツは、YouTube内で使用する事は通常はOKだと思われますが、YouTube以外の配信にも使用できるか、という部分は曖昧都度確認する必要があります(「フリー」の用途が限定的で、配信での使用はYouTube内でもNG、というフリーコンテンツも有り得ます)。著作物の利用に於いて、配信利用というのは特殊な用途だという事を常に意識する事が必要なのです。もっと基本的な事として、YouTube の動画・音声をSHOWROOMで流す、という行為自体が基本的にタブーです(これも例えるなら TB〇の番組内でフ〇テレビの番組を許可なく意図的に流す行為に等しい)。これらの行為については全てYouTubeやSHOWROOM以外でも同様です。
 楽曲の無断使用は配信プラットホームでは重い部類のコンプライアンス違反になりますので、発覚次第、配信中ならばBAN(配信の強制終了)、配信終了後でもアカウント停止や獲得ポイント没収などの処分になり得ます[誤解されている方がいますが、通報対応等の為にSRは全配信を一定期間録画保存しています。通報されても放送終了すれば大丈夫などという事はなく、普通に事後調査の上で該当違反等が確認されれば処分を受けます]。楽曲申請自体は配信管理画面から簡単(?)にできるので、手間を惜しまず申請しておいてください(この一手間が大事なのです)。配信者さんは御自身も著作権者に成り得るのですから、こういった著作権侵害は他人事ではなく、将来の自分へ返ってくる我が事として認識してください(自覚と責任を持ってください)。本来はオーガナイザーが事前にレクチャーした上、各配信をチェックして必要ならば適切な手順を案内すべきなのですが、SRのオーガナイザーでそういうことをしているオーガナイザーは極めて少数のようですので、配信者さん自身が気を付けて手続きの確認・使用申請をしておきましょう。
以下のSR内のページでは分かり辛いですが、BGMを流す行為も一般的に「音楽を配信する」行為に含まれます。これらの理由から楽曲申請が個別に全ての著作権者に許可を貰う事は面倒(というかほぼ不可能!)だけれどBGMは欲しい、という場合は、SRのカラオケ機能でカラオケ音源を(歌わないけれど)流しておくという方法も有ります(外部マイク[イヤホンマイク含]必須、という欠点もありますが)。
参照URL:
※ SHOWROOMでは、フリー音源以外の市販曲をBGMに使う事はSRに使用楽曲申請をしてもNG (使用許諾範囲外)、という情報を頂きましたが、どうも本当のようです。BGMに使う場合は、配信者若しくはオーガナイザーが、使用する楽曲全ての著作権利者に対して個別に許可を貰う必要がなる、との事です(詳細は各自オーガナイザー経由でSRに確認してください [YouTube 等ではJASRAC管理曲については申請すればOKだったと思うのですが、SHOWROOMではダメな[=そこまでの使用許諾は得ていない]のかもしれません[著作権関係は許諾契約時、個別に用途・範囲が非常に細かく細かく細かく[大事な事なので(ry]規定(限定)・制約されるので、プラットホーム毎に異なる事自体は承知しています]])。
上記リンクの「BGMを流しましょう」の「3.BGMと「権利」について」の説明を読んでもこの辺りが非常に分かり辛い(が、確かに、よく読み込めば[逆説的に]そうなる事が判る)ので、『但し BGMに使用できる楽曲は、各配信者・オーガナイザーが自分で著作権者に許可を得た楽曲か、フリー音源の物に限る』位の解り易く噛み砕いた注意書きが有っても良さそうな気がするのですが、SHOWROOMさん、これは高度なトラップか何かでしょうか?!
 まとめると、実質的にBGMに使えるのは
の二種類だけ、という事になります (諄いですが、これに追加で[非現実的ではありますが]自分で全ての著作権者に配信使用許可を得た楽曲、という事)。
◎ブロックランキングの最終結果が取得できていないイベントが幾つかあったようです(というか最近のは殆ど取れていない感じですね…)。お知らせ下さっていた方、有難うございます&気付かず、申し訳ございませんでした。以前から最終結果の取得に失敗するブロックランキングイベントがある事は把握していたのですが、現時点で対策はとれておりません(結果取得部分、歴史的経緯(結果発表後のポイント不当操作疑惑のアレです)から意外と複雑な処理をしてたりするので、単純に原因解析・対応できないという…また、結果発表が大体月曜、という事で、これまたシンプルに見る時間が取れなかったりします 仕掛けていた別手法の結果データ取得ツールが巧く動いていたものについては、少しお時間を頂きますが反映していく予定です。リアルタイム反映の実装まではさらにもう少しお時間を下さい) [2023.09.26 update]
・秋の超豪華イベント!SHOWROOMシルバーウィーク祭について、結果の反映を致しました。既知の不具合として、途中棄権されたルームの情報がグラフ上に0点までの減算として残ってしまっていますが、まずは表示反映まで取り急ぎ実施致しました [2023.09.26 append]
・上記不具合、解消済みです。フレキャン2023, ミスサー2023 のブロックランキングイベントにつきましてもイベント終了後の結果記録は残っておりましたので、遅ればせながら反映作業にとりかかります。[2023.09.27]
○その他のお知らせ [表示する]

■SHOWROOM配信ルーム数等の推移グラフ  (グラフの自動更新状態:on)
・SHOWROOM配信ルーム数
[SRの配信中ルーム数の推移グラフ]
SHOWROOM視聴者増(盛り上がり数増(?))
[SRの盛り上がり数増分の推移グラフ]
流動視聴者(盛り上がり数流動量(?))
[盛り上がり数流動量 推移グラフ]
自動更新:
on
 
[簡単な説明] ※SHOWROOM視聴者増は各ルームの累積視聴者数の増分の総和です。正確さの非常に低い「SR視聴者数変化量」として目安程度にお考え下さい(減ったユーザ数を知る術が無い為、データとしては非常に不完全)。流動視聴者数は単純に『SHOWROOM視聴者増 ÷ 配信ルーム数』です。こちらも同様に、1ルーム当たりで平均して何人の視聴者が増えているか(『新規視聴+ルーム間を移動しているユーザ』)≒新たにカウントできるユーザ数の目安、程度にお考え下さい。
過去データにつきましてはGIF版(MRTG版)ではそのデータ仕様上 遡り表示が出来ない為、単純に定時にGIFを保存するしかないのですが、現時点まで保存しておりません…。大元のデータ自体は引き出せるので、amCharts版であれば遡り表示や期間指定等も可能ではあるのですが、こちらはamChartsの性能上いくつかの制約を設ける必要がある為、現時点では未実装となっております…。
(こんなのもあります(amCharts 4 版試験中) → 「配信ルーム数( ジャンル別累積ジャンル比較用 ) | リスナー数
データダウンロードや、表示域選択、表示項目選択[分かりにくいですが、項目名をクリックすると表示・非表示トグル切替]が可能です。ジャンル別の累積視聴者数の合計は今は計算していません(各ルームの累積視聴者数とジャンルは保存されいるので、その気になればデータ化可能ですが)。表示するルームや表示期間を閲覧される方が選択・変更できるメリットはかなり大きいかな、と、本当はこれをイベントグラフにも適用したいのですが、未だ準備中ステータスです)

 ■SHOWROOMイベントのグラフとデータ
当ページは手作業更新で追加漏れや反映遅れが増えてきた為、データ取得リストと連動した一覧をこちらでご参照頂けるよう致しました。検索・並べ替えも可能です。--> データ取得リスト連動一覧