Memo

WordPressでURLから作成したスクショをメディアライブラリに登録&サムネイル生成する方法

先日「WordPressでURLからスクリーンショットを撮って記事に貼り、自分のサーバーにも保存する方法」という記事を書きました。
その中で「メディアライブラリに登録するにはプラグインを使わないといけない」と書いていましたが、プラグインを使わないでメディアライブラリに登録する方法が分かりました。ついでにサムネイルなどの生成もできます!

1年以上も前の記事です。情報が古くなっている可能性があります。

URLからスクリーンショットを作成&メディアライブラリに保存&サムネイルを生成する

これで、[Screenshot url=""]とするだけで、URLのスクリーンショットがメディアライブラリに保存され、且つ、メディア設定で指定したサイズの画像が生成されます。

メディアライブラリ登録の解説

メディアライブラリの登録はwp_insert_attachment( $attachment, $filename, $parent_post_id )を使います。

mime_typeや画像のタイトルなどを含む配列($attachment)、ファイル名($filename)、画像を使用する記事のID($parent_post_id)を指定します。
今回は記事内でショートコードが指定された際に動くので、記述している記事のIDを指定していますが、使用する記事のIDが不明の場合(新規登録の場合など)は$parent_post_id = "0"でOKだそうです。

参考:wp_insert_attachment() で新規 insert | DEVLAB

サムネイルなどのリサイズ画像生成

wordpressでは画像をアップロードすると、アップロードしたファイルとは別に、サムネイルサイズや中サイズなどのリサイズ画像も生成されます。
リサイズ画像の生成はwp_generate_attachment_metadata( $attachment_id, $file )を使用します。生成されるサイズはメディア設定で指定したサイズになります。

$attachment_idは、アップロードした画像に付与されるIDです。こちらはwp_insert_attachment()の返り値で取得できます。
$fileはサーバー上の絶対パスから始まる画像のファイル名です。

また、wp_generate_attachment_metadata()の返り値はデータを更新するwp_update_attachment_metadata( $attachment_id, $attachment_metadata )で必要な$attachment_metadata(アップロードした画像の詳細データ)を返します。

参考:Function Reference/wp generate attachment metadata « WordPress Codex

そんなわけで

WordPressでURLからスクリーンショットを撮り、メディアライブラリに登録し、サムネイルなどのリサイズ画像を作る、ということができるようになりました!使用用途としてはかなり限定されますが、参考になれば幸いです。

実はひっそりちょっとしたサイトギャラリーを作ってまして。それで色々しらべておりました。ギャラリーはコンテンツが充実してきたらまたブログでご紹介しますね。

COMMENT

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください