###実現したいこと・前提条件
- 画像データを販売するサイトを作成している
- phpで画像に透かし(ウォータマーク)を入れたサンプルデータを表示したい
- 商品ページ毎に合成する画像を記事別に動的に変えたい
- 最終的にそのサンプルデータをインラインイメージとして任意の場所に出力したい
2枚の画像を合成してウォーターマーク有のデータを作成することはできたのですが、
これをどうやって任意の場所に出力すればいいのかがわかりません。
###画面該当箇所のコード
php
1<?php 2$stamp = imagecreatefrompng( 'watermark.png' ); 3$im = imagecreatefromjpeg( 'hanbai_data.jpg' ); 4 5 6// スタンプの余白を設定し、スタンプ画像の幅と高さを取得します 7$marge_right = 10; 8$marge_bottom = 10; 9$sx = imagesx( $stamp ); 10$sy = imagesy( $stamp ); 11 12// スタンプ画像を写真の上にコピーします。余白の値と 13// 写真の幅を元にスタンプの位置を決定します 14imagecopy( $im, $stamp, imagesx( $im ) - $sx - $marge_right, imagesy( $im ) - $sy - $marge_bottom, 0, 0, imagesx( $stamp ), imagesy( $stamp ) ); 15 16// 出力し、メモリを開放します 17header( 'Content-type: image/png' ); 18imagepng( $im ); 19imagedestroy( $im ); 20?>
↓出力結果のコード
php
1<html> 2<head> 3<meta name="viewport" content="width=device-width, minimum-scale=0.1"> 4<title>watermark.php (640×480)</title> 5</head> 6<body style="margin: 0px; background: #0e0e0e;"> 7<img style="-webkit-user-select: none;margin: auto;" src="https://【ドメイン】/test01/wp-content/themes/storefront-child/コードを記載したphpファイル名.php" width="640" height="480"> 8</body> 9</html> 10
↑そもそもなぜimgタグ内の画像パスが.php形式になるのかよくわからないです。
画像だけを任意の個所に出力したのに、ファイル全体が「合成後の画像データ」みたいな感じになってしまいます。
###試したこと
例えば、サーバー上にすでに存在する画像をbase64エンコードして出力するだけであれば下記の方法でできました。
php
1<?php 2$img = base64_encode(file_get_contents('画像ファイルのパス')); 3?> 4<img src="data:image/png;base64,<?php echo $img; ?>">
これと組み合わせて透かし有のデータを好きな場所に出力すればできるのではないかと考えているのですが、
どうすればいいのかわかりません。
知恵を貸していただけないでしょうか。
###参考にしたサイト
透かしを入れるための画像合成
→https://www.php.net/manual/ja/image.examples-watermark.php
base64エンコード
→https://kaworu.jpn.org/kaworu/2008-04-06-1.php
###追記1
表示したいページのbodyタグ内に「画面該当箇所のコード」を貼り付けると、もともと書かれていたhtmlはすべて無視されて下記のようになります。
(右上のウィンドウはキャプチャソフトの画面なので無視してください)
###追記2
chromeのディベロッパーモードでどんなhtmlが吐き出されているのか確認しました。
出力結果のコード
html
1<body style="margin: 0px; background: #0e0e0e;"> 2<img style="-webkit-user-select: none;margin: auto;" src="https://ドメイン/test01/product/1068/"> 3</body>
bodyタグ内でいうとこれだけしか表示されません。
エラーらしきものはこの中からは見つけられませんでした。
回答1件
あなたの回答
tips
プレビュー