# [メタ情報] # 識別子: vimeo埋め込みコード及びphp_シーク付き字幕使用可能_exe # システム名: vimeo埋め込みコード及びphp_シーク付き字幕使用可能 # 技術種別: Misc # 機能名: Misc # 使用言語: カスタムhtml php # 状態: 実行用 # [/メタ情報] 要約: このテキストは、Vimeo動画の埋め込み、インタラクティブな再生制御、字幕連携、および多言語翻訳機能を提供するWordPressカスタムテンプレート(PHP)とそのフロントエンド(HTML/JavaScript/CSS)の実装を示しています。 HTMLとJavaScriptは、Vimeo動画を埋め込み、APIを介して再生を制御します。「動画を別ページで表示」リンクをクリックすると、動画を一時停止してから新しいタブで開きます。字幕のタイムスタンプなどを示すリンク(`a.imk-cue`)をクリックすると、動画が該当する時間にシークして再生を開始。動画の再生中は、現在の時刻に連動して字幕リストの該当部分がハイライトされ、自動的にスクロールされます。Vimeoプレーヤー、字幕リストのサイズ、ハイライトスタイルはCSSで調整されています。 PHPテンプレートは、URLの`movid`パラメータから動画IDを取得し、JSONファイルから対応する埋め込みコードを検索して出力します。このPHPは、埋め込みコードから特定の不要リンクを削除し、Google翻訳機能を統合します。さらに、字幕リストの高さやハイライトのスタイルを調整するCSSを動的に出力し、動画コンテンツのラッパーに適用することで、シームレスな視聴体験と学習体験を提供します。 マイライブラリ→基礎情報→vimeo→埋め込みコード ```
``` 対応条件: {"gggg":"18","eee":"3","ddd":"12"} vm5用php vimeo-custom-template3.php ``` 'n/a', 'mtime' => 'n/a', 'entries' => 0, 'json_ok' => false]; $raw = false; foreach ($path_candidates as $p) { if (is_readable($p)) { $raw = @file_get_contents($p); $debug_info['path'] = $p; break; } } if ($raw === false) { error_log('vm5: failed to read any json path'); return false; } $mtime = @filemtime($debug_info['path']); if ($mtime) $debug_info['mtime'] = date('Y-m-d H:i:s', $mtime); $data = json_decode($raw, true); if ($data === null && json_last_error() !== JSON_ERROR_NONE) { error_log('vm5: json decode error - ' . json_last_error_msg()); return false; } $debug_info['json_ok'] = true; $debug_info['entries'] = is_array($data) ? count($data) : 0; return is_array($data) ? $data : []; } // 厳密一致検索 function vm5_find_by_movid($data, $movid) { if (!is_array($data)) return null; $movid = trim((string)$movid); foreach ($data as $row) { $vid = isset($row['videoid']) ? trim((string)$row['videoid']) : ''; if ($vid === $movid) return $row; } return null; } // 不要リンク削除(「動画を別ページで表示(ここをクリック)」) function vm5_strip_unwanted_link($html) { $pattern = '/]*>\s*動画を別ページで表示\(ここをクリック\)\s*<\/a>/u'; return preg_replace($pattern, '', (string)$html); } // the_content 用フィルタ(※ remove_filter できるように “名前付き” で用意) function vm5_filter_the_content($content) { return vm5_strip_unwanted_link($content); } // ========== 表示開始 ========== get_header(); ?> '; echo 'path=' . esc_html($dbg['path']) . 'No data found for movid: ' . esc_html($movid) . '
'; } } else { echo 'No movid provided.
'; } // the_content にも同様の除去をかけたい場合(※ remove_filter が確実に効く) add_filter('the_content', 'vm5_filter_the_content', 9); if (have_posts()) : while (have_posts()) : the_post(); the_content(); endwhile; endif; remove_filter('the_content', 'vm5_filter_the_content', 9); get_footer(); ?> ```