コグノスケ


2013年3月10日

誕生日

30歳になったけど、実感ないなー。

相変わらず甘いものは好きだし、ゲームも好きだし。年齢で好みが変わることはあっても、あえて変える必要はない、って、そりゃ当たり前か。

編集者:すずき(2013/03/12 02:42)

コメント一覧

  • hdkさん(2013/03/12 08:35)
    誕生日おめでとう!
  • すずきさん(2013/03/12 19:26)
    ありがとう!!
open/close この記事にコメントする



2013年3月13日

ffmpegビルドふたたび

以前(2009年5月22日の日記参照)ビルドしたffmpegがいい加減古くなってきたので、再びビルドしました。

もう4年も経っているので、少なからずconfigureのオプションが変わっていたり、以前は使えたライブラリが使えなくなっていたりしていたので、使用するライブラリを変えました。

以下、今回ビルドしたソフトおよびライブラリです。前回からの変化点には★をつけています。

★yasm
アセンブラ:コーデックではないです。ffmpegをビルドする際にDebianのStableパッケージより新しいyasmが必要となります。ffmpegのアセンブラコードを無効化する(./configure --disable-asmでできるが、速度が犠牲になる)か、yasmの新しいパッケージを持ってくるか、いっそyasmを独自にビルドしまっても良いです。
libogg
Ogg:コンテナ、つまり動画、音声を入れる箱のことです。フリーのフォーマットです。
libx264
MPEG-4 Advanced Video Codec/H.264:動画、いわゆるAVCとかH.264と呼ばれます。ワンセグやBlu-rayに用いられます。
libxvidcore
Xvid:動画、MPEG-4ベースのフリーのコーデックです。H.264が出るまではDivXと争っていた気がします。対応しているプレーヤは見かけません。
★libvpx
VP8, VP9:動画、On2 Technologies開発でしたが、Googleに買収されWebM規格(コンテナMatroska, 動画VP8, 音声Vorbis)としてフリーで提供されているコーデックです。サービスではYouTubeが採用し、ブラウザはGoogle Chromeが対応しているなど、Googleの仲間達がよく使っています。
libtheora
Theora:動画、MPEG-4ベースのOn2 VP3をベースとしたフリーのコーデックです。VP3の後継コーデックVP6はFlash Videoのコーデックとして有名ですが、Theoraはあまり有名とは言えないかな…。
libvorbis
Vorbis:音声、フリーなコーデックです。音質、圧縮率ともにMP3より優れていると評判でしたが、他の音声コーデックがぞろぞろ出てきて、存在感が薄くなりました。
★libopencore-amrnb
3G AMR-Narrowband:音声、狭帯域向けのコーデックです。iモーションの音声に使われます。以前対応していたamr-nb, amr-wbライブラリのサポートが無くなり、こちらのライブラリになりました。何でだろ?
★libopencore-amrwb
3G AMR-Wideband:音声、AMR-Narrowbandの広帯域版です。何に使われているか知りません。
libmp3lame
MPEG-1 Audio Layer 3:音声、いわゆるMP3です。各所で使われています。
★libfaac
MPEG-2 Advanced Audio Codec:音声、いわゆるAACです。DVDの音声、iTunesの音声として有名です。ffmpegがAACのデコードに対応したせいか、libfaadのサポートがなくなりました。
★libaacplus
MPEG-4 High Efficiency Advanced Audio Codec:音声、いわゆるHE-AACです。iTunesで使っています。着うたでも使ってたっけ?低域部分をAACで、高域部分をSpectral Band Replicationでコードします。v2ではParametric Stereoも使います。

ビルド手順は下記の通りです。ソースコードアーカイブへのURLは日記を書いた時点のものであり、いつ変わるかわかりませんので、ビルドの際はURLをご自分で今一度ご確認下さい。

ffmpegのビルド(Debian 6.0.7 Squeezeにて)
export PATH=/home/katsuhiro/usr/bin:$PATH


git clone https://github.com/yasm/yasm.git yasm
cd yasm
automake --add-missing
autoreconf
./configure --prefix=/home/katsuhiro/usr
make
make install


git clone git://git.videolan.org/x264.git x264
cd x264
./configure --prefix=/home/katsuhiro/usr \
 --enable-shared \
 --enable-pic
make
make install


wget http://downloads.xvid.org/downloads/xvidcore-1.3.2.tar.gz
tar xzvf xvidcore-1.3.2.tar.gz
mv xvidcore xvidcore-1.3.2
cd xvidcore-1.3.2/build/generic/
./configure --prefix=/home/katsuhiro/usr
make
make install


git clone  http://git.chromium.org/webm/libvpx.git libvpx
cd libvpx
./configure --prefix=/home/katsuhiro/usr \
 --enable-shared
make
make install


wget http://downloads.xiph.org/releases/ogg/libogg-1.3.0.tar.gz
tar xzvf libogg-1.3.0.tar.gz
cd libogg-1.3.0
./configure --prefix=/home/katsuhiro/usr \
 --enable-shared
make
make install


wget http://downloads.xiph.org/releases/vorbis/libvorbis-1.3.3.tar.gz
tar xzvf libvorbis-1.3.3.tar.gz
cd libvorbis-1.3.3
./configure --prefix=/home/katsuhiro/usr \
 --enable-shared \
 --with-ogg=/home/katsuhiro/usr \
 --with-vorbis=/home/katsuhiro/usr
make
make install


wget http://downloads.xiph.org/releases/theora/libtheora-1.1.1.tar.bz2
tar xjvf libtheora-1.1.1.tar.bz2
cd libtheora-1.1.1
./configure --prefix=/home/katsuhiro/usr \
 --with-ogg=/home/katsuhiro/usr \
 --enable-shared
make
make install


wget http://downloads.sourceforge.net/project/opencore-amr/opencore-amr/opencore-amr-0.1.3.tar.gz
tar xzvf opencore-amr-0.1.3.tar.gz
cd opencore-amr-0.1.3
./configure --prefix=/home/katsuhiro/usr \
 --enable-shared
make
make install


wget http://downloads.sourceforge.net/project/lame/lame/3.99/lame-3.99.5.tar.gz
tar xzvf lame-3.99.5.tar.gz
cd lame-3.99.5
./configure --prefix=/home/katsuhiro/usr
make install


wget http://downloads.sourceforge.net/project/faac/faac-src/faac-1.28/faac-1.28.tar.gz
tar xzvf faac-1.28.tar.gz
cd faac-1.28
./configure --prefix=/home/katsuhiro/usr \
 --enable-shared
sed '126d' ./common/mp4v2/mpeg4ip.h > ./common/mp4v2/mpeg4ip.h_new
mv ./common/mp4v2/mpeg4ip.h_new ./common/mp4v2/mpeg4ip.h
make
make install


wget http://217.20.164.161/~tipok/aacplus/libaacplus-2.0.2.tar.gz
tar xzvf libaacplus-2.0.2.tar.gz
cd libaacplus-2.0.2
./autogen.sh
./configure --prefix=/home/katsuhiro/usr
make
make install


git clone git://source.ffmpeg.org/ffmpeg.git ffmpeg
cd ffmpeg
./configure --prefix=/home/katsuhiro/usr \
 --enable-nonfree --enable-gpl \
 --enable-version3 \
 --enable-pthreads --enable-shared \
 --extra-cflags="-I/home/katsuhiro/usr/include" \
 --extra-libs="-L/home/katsuhiro/usr/lib" \
 --enable-libx264 --enable-libxvid \
 --enable-libvpx \
 --enable-libopencore-amrnb --enable-libopencore-amrwb \
 --enable-libtheora --enable-libvorbis \
 --enable-libmp3lame \
 --enable-libfaac --enable-libaacplus

============================================================

$ ffmpeg -version
ffmpeg version N-50843-gacbd14b
built on Mar 13 2013 21:38:21 with gcc 4.4.5 (Debian 4.4.5-8)
configuration: --prefix=/home/katsuhiro/usr --enable-nonfree --enable-gpl --enable-version3 --enable-pthreads --enable-shared --extra-cflags=-I/home/katsuhiro/usr/include --extra-libs=-L/home/katsuhiro/usr/lib --enable-libx264 --enable-libxvid --enable-libvpx --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libtheora --enable-libvorbis --enable-libmp3lame --enable-libfaac --enable-libaacplus
libavutil      52. 19.100 / 52. 19.100
libavcodec     55.  0.100 / 55.  0.100
libavformat    55.  0.100 / 55.  0.100
libavdevice    54.  4.100 / 54.  4.100
libavfilter     3. 45.101 /  3. 45.101
libswscale      2.  2.100 /  2.  2.100
libswresample   0. 17.102 /  0. 17.102
libpostproc    52.  2.100 / 52.  2.100
編集者:すずき(2013/03/13 22:27)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2013年3月16日

ノートPCの内蔵サウンドからUSB DACへ

目次: PC

ノートPCの内蔵サウンドカード → ヘッドフォン出力、で音楽を聴いていると、音を出力開始する際に「バシッ」というノイズが載るのと、無音部分の「サー」というホワイトノイズが載るのがかなり気になります。

Windowsのサウンドカードのプロパティでいじれるところをいじってみましたが、サンプリングレートをいくつにしても、音の明瞭化を無効にしても何も変化がありませんでした…。

USB Audio

じゃあサウンドカードごと変えてしまおうと思い立って、最近流行のUSB DACを買ってみました。

USB DACは値段も数千円のものから、やたら高い(10万円超)ものまであって、みな、高音質であることを主張しています。が…、正直言って違いが良くわかりません。

大きさと値段で選んで、ONKYOのSE-U33GXV2にしました。追加ドライバを必要としないことと、24bit/96kHzという仕様から、USB Audio Class 1.0対応と思われます。

聴いてみた

内蔵サウンドカードで問題になっていた点(バシっというノイズ、サーというホワイトノイズ)は全く聞こえません。この辺りはさすがです。

ですがしばらく使っていると、音が切れたり、音程が一瞬低くなったり、バリっとノイズが載ったりして、どうにも動きがおかしいです。

プレイヤーがいかんのか?と思って、foobar2000 v1.2.3とWASAPIプラグイン3.2.3に替えてみましたが、eventモードでもpushモードでも症状は同じです。

なぜか24bit出力がグダグダ

いろいろ設定を変えていたら原因に行き当たりました。出力のビット数(※)です。

出力フォーマットのビット数が24ビットだと先ほどのような問題が起き、16ビットに変更すると安定して動作するようです。

せっかく筐体に金色の文字で「24bit/96kHz」と書いてあるのに、24ビット出力は使いものにならないとは、また斬新な製品ですねえ。

(※)foobar2000のPreferences - Playback - OutputのOutput Data Formatです。ビット数は8, 16, 24, 32ビットの4択ですが、8と32はサポートしていないとエラーが出るので、実質16, 24ビットの2択です。

再現環境

環境は下記の通り。

  • PC: Lenovo Thikpad Edge E420(カスタムオーダ)
  • OS: Windows 8 Professional
  • プレイヤ: foobar2000 v1.2.3
  • 出力: WASAPIプラグイン(event)
  • ストリーム: MP3 44.1kHz 192kbps

なおかつfoobar2000の設定を以下のようにします。とにかくバッファらしきものは全部排除です。

  • Preferences - Playback - DSP Manager - Active DSPsを全削除
  • Preferences - Playback - ReplayGain - Processingをdisabled
  • Preferences - Playback - Output - Buffer lengthを1000ms
  • Preferences - Playback - Output - Output data formatを24-bit

この設定だと1〜2分に1回は、音が歪んだり、音程が下がったり、音が切れます。Output data formatを16-bitにすると10分以上聴いていても何も起きません。

これが何かのヒントになれば幸いです。

編集者:すずき(2024/10/25 01:22)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2013年3月20日

車が故障した(バッテリー上がり)

目次:

今朝、同期の人たちと梅見に行くため車で出発しようとしたのですが、キーをSTARTまで捻ってもセルがピクリともしません。レガシィさん、なんというタイミングで壊れてくれるのだね…。

室内灯もカーナビも元気なのでバッテリ上がりではなく、ボンネットを開けてみても特に何かが漏れたり、外れているという様子もないのです。そもそもメカ系のトラブルなら何かしら動こうと頑張るはずですが、一切動かないのは何故だろう?

改めてキーをSTARTにしてメーターを見ていたら、走行距離計に「Er HC」の文字が出ていました。ネットで調べると「Er HC = 高速CAN通信エラー」とのこと。どうもECUか、ECU近辺の電装系が死んだようです。うーん、どうしようもないな…。

車はもう全く一切動かないので、ディーラーまでレッカーで運ばなければなりません。10年近く車に乗ってますが、レッカーのお世話になるのは初めてかも??

残念ながら近所のディーラーは定休日でしたので、修理はまた今度。

編集者:すずき(2023/09/30 14:58)

コメント一覧

  • hdkさん(2013/03/21 00:55)
    レッカーじゃなくて、キャリアカーというかローダーというか、アレで運んでもらったことがあります。その時は、点火系のコードがねずみにかじられたみたいになっていて、エンジンが 2 秒間しか回らない (ECU が異常判定して燃料を止めてしまう) 状態でした。
  • すずきさん(2013/03/21 01:11)
    >hdk さん
    なるほどそういうのもあるのですね。売り物の新車や中古車を運んでいるイメージしかなかった。

    ちなみにキャリアカーにはどうやって入れたのでしょう??
  • hdkさん(2013/03/21 01:51)
    >売り物の新車や中古車を運んでいるイメージしかなかった。
    それはデカいキャリアカーですかね。故障車を運ぶ積載車は、車 1 台だけ積めるトラックみたいなやつです。

    > ちなみにキャリアカーにはどうやって入れたのでしょう??
    一応ウインチがついてたと思うんだけど、2 秒だけでもエンジン回ると、MT だし少しくらいは動かせたのでそれで積んでたかも。
  • すずきさん(2013/03/22 20:38)
    >hdk さん
    1台だけ載せるキャリアカーもあるんですね、なるほど…。
    ディーラーには来週にでも連絡してみたいと思います。
open/close この記事にコメントする



2013年3月25日

免許の更新と車の修理

目次:

前回の免許更新は免許センターまで行ったのですが、遠いわ、混んでいるわ、で辟易したので、今回は近所の警察署で更新しました。警察の方々の事務作業は手慣れたもので、まさに「流れ作業」という言葉がぴったりでした。

講習では道路交通法の5年前との変更点を習いました。結構変わっているもんだなあ。一番意味がわからなかったのは「右折可能信号でUターンして良くなった」ことです。

今までは青信号と、左折、直進、右折可信号の全点灯の違い(※)は、知る人ぞ知るって感じの豆知識でした。でも右折可信号でUターンOKとなると…いよいよ青信号との違いがわからなくなりますね。

(※)従来の青信号と、左折、直進、右折可信号の全点灯の違いは「Uターンしては行けない」でした。

車のレッカー

エンジンが全くかからなくなった車(2013年3月20日の日記参照)をディーラーに持っていくため、JAFさんに来てもらいました。電話した後に、家の前の狭い丁字路(普通車がギリギリ)を思い出し「ここレッカー通れるか??」と不安を感じてたのですが…。

やはりというか何というか、JAFの作業員の方が、開口一番「ここの路地、かなり狭いですねー。牽引だと通れそうにないんですわ…。」と困っていました。やはりそうか…。しばし悩んだ後に、2つのプランで行くことになりました。

まずはプランA「車が自走すれば一番良いよね。」作戦です。ま、要は車を直そうと頑張るってことですね。しかしブースターを使っても全くエンジンは動かず、同じエラーを表示し続けるだけ…。切ない。
次にプランB「狭い路地をクリアするまでロープで曳き、その先で牽引!」作戦です。これは1人ではできないので、牽引側(トラック)をJAFの方、曳かれる側(レガシィ)を私が運転しました。

しかしこのエンジン掛かってないパワステのハンドルってやつは、重いのなんのって…。しかも途中でバッテリーまで死んで、メーターすら光らなくなり、車がいよいよダメになりました。

でもそんなこんなでなんとか広い路地に出ることができ、トラックで牽引してもらい無事、ディーラーへたどり着きました。や、良かった良かった。

狭い、面倒

家の前の路地といい、牽引の準備(※2)といい、まるでJAFへの嫌がらせみたいな状況でした…。別にわざとやったわけじゃないし、誰が悪いわけでもないのだけども…申し訳ない気分になるのはなぜかしら?

まあ、それはともかく。ありがとうJAFさん、感謝です。

(※2)レガシィは四駆なので、四輪全部浮かせないと牽引できません。そのため牽引準備の作業量が1.5倍くらいになってしまいます。

窓口

JAFへは、アパートの駐車場から電話したのですが、窓口のおねえさんが最後に「暖かい部屋の中でお待ちください。」と言って、会話を終えたのが印象的でした。

相手が外に居ることを察して、相手を気遣う何気ない一言を掛ける、ってのは、余所余所しいお礼よりもずっと心に響くんだなあ…。

編集者:すずき(2023/09/30 15:00)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2013年3月27日

車の修理が終わった

先日レガシィを運び込んだ(2013年3月25日の日記参照)ディーラーから電話があり「バッテリーが完全に死んだのが原因」とのこと。説明を聞いていたのですが、どうも向こうの言う原因と今回の現象が繋がりません。

エラーが初めて出た日(水曜日)にはバッテリーは生きていたよ?
牽引前にJAFの方がブースター繋いだけどかからなかったよ?
バッテリーが完全に死んだのは牽引の直前だよ?
前にバッテリー上がったときは出なかったよ?
Er HCの意味は?なぜバッテリーが原因なの?
というようなことを聞き返したら「折り返し電話する」とのこと。なんだそりゃ…?

しばらくして2回目の電話。観念して(?)整備マニュアルを見つつ説明してくれたようで、やたら詳しかったです。ひとまず結論だけ一言でいえば「統合ユニットの誤報」でした。

と言われてもわかんないですね。覚えている限りですが、説明の要点は次の通り。

  • 電圧降下のエラーが統合ユニット(エンジン制御のコンピュータ)に記録が残っていた。
    もともとバッテリーがかなり弱っていたと考えられる。
  • バッテリーがかなり弱っていると、ブースターを繋いでもかからないことがある。
    →聞き流しちゃったけど、これ本当なのかな?
  • バッテリーを交換したところ、エンジンがかかった。
    機械類に故障はないと考えられる。
  • Er HCは高速CAN通信エラー、つまりエンジン周りのセンサーなどとの通信エラー。
    センサーに異常があれば、バッテリー交換後もEr HCエラーが出る。
    だが、バッテリー交換後センサーのエラーは出ていないし、統合ユニットにも記録が残っていない。
    センサー類に故障はないと考えられる。

以上から所見としては「バッテリーの電圧が一時的に下がったか何かで、統合ユニットのメモリにエラーが生じ、Er HCエラーが出た。しかしバッテリー交換によりエラーが消えたところを見るに、エンジンや統合ユニットに異常はないと考えられる。」とのことらしいです。

修理代的な観点だとエンジン周りは壊れていないから、交換不要。バッテリーは死んでいたから、交換した。ってことです。

悪意はないのだろう

もう!最初からそうやって説明してくれれば良いのに!!って思った。でも後で良く考えたら、車に興味のない人に統合ユニットだ、CANだ説明したところで「はぁ?何それ?で、修理代いくらなの?」って言われるのが関の山だろうなあ。

一生懸命説明しても虚しいから、いつも端折って説明してきたのに、今回だけは(私が)やたら食いついてきたもんだから、観念して整備マニュアル引っ張ってきた、ってところでしょうか。単なる推測に過ぎませんが…。

編集者:すずき(2013/03/30 03:04)

コメント一覧

  • hdkさん(2013/03/28 23:49)
    バッテリーが本当にダメだとかからないことがあるのは、電子制御の燃料噴射装置やスロットルだとありそうな話だけど、一応電装品が動くくらいはあったわけだから、バッテリーが完全に干上がったことでコンピューターのエラー状態か何かがリセットされたのがミソなんですかねぇ。結果的には自分でバッテリー交換すれば牽引の必要もなかったということに...?
  • すずきさん(2013/03/29 00:50)
    >hdk さん
    確かに、説明を聞いていたら「バッテリー端子外すだけで(一時的にでも)治ったのでは?」とは思いましたが…。
    調べるまでは原因がわからなかったし、結果論ってやつですねー。
open/close この記事にコメントする



2013年3月28日

Javaのリフレクションとコンストラクタ

Javaのリフレクションを使ったコンストラクタの取得で躓いています。正解が分からない…。

あるクラスTestがあり、パラメータにクラスAしか取らないコンストラクタがあるとします。

クラスTestのコンストラクタに対し、クラスAと全く関係ないクラスCのインスタンスを渡せばコンパイルエラーになります。クラスAの派生クラスBのインスタンスであれば渡せます。これはオブジェクト指向言語なら当たり前です。

しかしリフレクションを使ってコンストラクタを得ようとすると、派生クラスを渡せるコンストラクタをどうやって取得すれば良いかわからないのです。


public class Test {
    public Test(A a) {
    }
}

public class A {
    public A() {
    }
}

public class B extends A {
    public B() {
    }
}

public class Main {
    public static void main() {
        Test obj1 = new Test(new A()); //OK
        Test obj2 = new Test(new B()); //OK

        Constructor<Test> cons1 = Test.class.getConstructor(A.class); //OK
        Constructor<Test> cons2 = Test.class.getConstructor(B.class); //NG

        Test obj3 = cons1.newInstance(new A()); //OK
        Test obj4 = cons1.newInstance(new B()); //OK

        //Test obj5 = cons2.newInstance(new B());
    }
}

上記のようなコードがあったとします(try〜catchは省いています)。

クラスTestには、クラスAをパラメータにとるコンストラクタしかありません。従って、派生クラスBをパラメータに取るコンストラクタをくれ(=Test.class.getConstructor(B.class))と頼むと「そんなコンストラクタは無い」と例外がスローされます。

どうしてTest.class.getConstructor(B.class) としたとき、「ありません」なんだろうか?基底クラスを取るコンストラクタ(Test(A a))があるのだから、そちらを教えてくれれば良いのに…。

鶏と卵

クラスTestには、クラスBを取るコンストラクタはないから、この動きは正しい。
とか、
基底クラスAを取るコンストラクタ(cons1)を得て、派生クラスBのインスタンスを渡せば良いだけだ。(つまりobj4を生成しているように書く)
という反論はわかるのですが、それだとせっかくのリフレクションなのに本末転倒になってしまいませんか?

クラスTestの利用者側の立場からすれば、クラスTestに、クラスAを取るコンストラクタがあるか?クラスBを取るコンストラクタがあるか?なんて知らないわけです。自分が呼び出したいコンストラクタが既にあるとわかっているなら、リフレクションなど使わずに直接呼べば良いのです…。

クラスTestのコンストラクタを全部取得して、クラスBの基底クラスを取るコンストラクタがないかどうか、全て探すしかないのでしょうか…。うーん、それはさすがに格好悪いような…。

編集者:すずき(2013/03/30 03:04)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2013年3月30日

ニコニコ動画ダウンロードスクリプト改良

以前、ニコニコ動画:Qの動画ダウンロードスクリプト(2012年10月25日の日記参照)を載せましたが、奥さんに「Google Chromeで動かない」と突っ込まれました。

試したら確かに動かない。ChromeだとXMLHttpRequestでニコニコ動画のgetflv APIを呼ぶとstatus 0が返ってきます。SeaMonkeyだとstatus 200が返ってきて、動画のURLが取得できているのですが…?

何故Chromeだけ動かないのかわからなくて、しばらくウンウンうなってたのですが、わかってみれば何てことはなかった。単にgetflv APIのURLが間違っていただけでした。

誤「http://www.nicovideo.jp/api/getflv/(movie ID)」
正「http://flapi.nicovideo.jp/api/getflv/(movie ID)」

というわけで、修正。SeaMonkeyとChromeで動作確認しました。


javascript:

function received() {
    if (request.readyState == 4 && request.status == 200) {
        /* received */
        var strurl = decodeURI(request.responseText);
        strurl = new String(strurl.match(/url=[^&]+/));
        strurl = strurl.replace('url=', '');
        strurl = decodeURIComponent(strurl);
        
        var btn_container = document.getElementById('videoHeaderDetail');
        var btn = document.createElement('a');
        
        btn.href = strurl;
        btn.style.fontSize = '2em';
        btn.textContent = '[download]';
        btn_container.appendChild(btn);
    }
}

var docurl = document.URL;
var doccookie = document.cookie;
var flvurl = docurl;
flvurl = flvurl.replace('www.nicovideo.jp/', 'flapi.nicovideo.jp/');
flvurl = flvurl.replace('/watch/', '/api/getflv/');

var request = new XMLHttpRequest();
request.open('GET', flvurl, true);
request.withCredentials = true;
request.setRequestHeader('Cookie', doccookie);
request.onreadystatechange = received;
request.send('');

注意点を一つ書いておきます。SeaMonkeyだと [download] リンクをクリックすると保存するかい?と聞かれます。しかしながらChromeは [download] リンクをクリックすると再生(※)してしまいますので、リンクを右クリックして「リンク先を保存」で保存してください。

最後に一つ心残りがあるとすれば、SeaMonkeyはなんで間違ったURLで正常に動いていたんだろう?ってことですかね。まあ、ご機嫌で動いているから、もうどうでもいいんだけどね。

(※)ChromeはContent-typeがvideo/mp4だと「ダウンロード」じゃなくて「ブラウザ内蔵プレイヤーで再生」してしまうようです。気が利いているというか、余計なお世話というか…。

編集者:すずき(2013/03/31 00:15)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



こんてんつ

open/close wiki
open/close Linux JM
open/close Java API

過去の日記

open/close 2002年
open/close 2003年
open/close 2004年
open/close 2005年
open/close 2006年
open/close 2007年
open/close 2008年
open/close 2009年
open/close 2010年
open/close 2011年
open/close 2012年
open/close 2013年
open/close 2014年
open/close 2015年
open/close 2016年
open/close 2017年
open/close 2018年
open/close 2019年
open/close 2020年
open/close 2021年
open/close 2022年
open/close 2023年
open/close 2024年
open/close 過去日記について

その他の情報

open/close アクセス統計
open/close サーバ一覧
open/close サイトの情報