関数・クラス解説
imagecropauto
version:PHP 5 >= 5.5.0, PHP 7 (公式)利用可能なモードを指定して、画像を自動的にクロップする
公式リファレンス
書式
imagecropauto ( resource $image [, int $mode = IMG_CROP_DEFAULT [, float $threshold = .5 [, int $color = -1 ]]] ) : resource|false
説明
指定した mode にしたがって、画像を自動的にクロップします。
警告この関数は、現在のところ詳細な情報はありません。引数のリストのみが記述されています。
パラメータ
- image
- imagecreatetruecolor()のような画像作成関数が返す画像リソース。
- mode
- 以下の定数のいずれか。
- IMG_CROP_DEFAULT
- IMG_CROP_TRANSPARENT と同じです。 PHP 7.4.0 より前のバージョンでは、 PHP にバンドルされた libgd は、 画像に透過色がない場合に IMG_CROP_SIDES にフォールバックしていました。
- IMG_CROP_TRANSPARENT
- 透過色の背景をクロップします。
- IMG_CROP_BLACK
- 黒の背景をクロップします。
- IMG_CROP_WHITE
- 白の背景をクロップします。
- IMG_CROP_SIDES
- 画像の四隅から、クロップする背景色を検出します。
- IMG_CROP_THRESHOLD
- threshold と color を用いてクロップします。
- threshold
- 画像の色とクロップする色を比較する際に用いる許容誤差を、パーセントで指定します。 色の違いを判断する際には、RGBキューブ内での距離を用います。 IMG_CROP_THRESHOLD モードのときにだけ利用します。
注意: PHP 7.4.0 より前のバージョンでは、 PHP にバンドルされていた libgd はやや異なるアルゴリズムを用いていました。 なので、同じ threshold を渡しても システムの libgd と PHP にバンドルされた libgd とは異なる結果が生成されていました。
- color
- RGB値あるいはパレットインデックスを指定します。 IMG_CROP_THRESHOLD モードのときにだけ利用します。
返値
成功した場合にクロップ後の画像リソースを返します。失敗した場合に FALSE を返します。 すべてクロップされてしまった場合は、 imagecrop() は FALSE を返します。
注意
警告この関数は、現在のところ詳細な情報はありません。引数のリストのみが記述されています。
更新履歴
バージョン | 説明 |
---|---|
7.4.0 | PHP にバンドルされた imagecropauto() の振る舞いは、 システムにインストールされる libgd のそれと同じになりました。 つまり、IMG_CROP_DEFAULT が IMG_CROP_SIDES にフォールバックすることはななくなり、 しきい値によるクロップは、 システムにインストールされる libgd のアルゴリズムと同じものを使うようになりました。 |
7.4.0 | mode パラメータのデフォルト値が IMG_CROP_AUTO に変更されました。 これより前のバージョンでは、デフォルト値は -1 で、IMG_CROP_DEFAULT に対応しています。 しかし、-1 を渡すのは非推奨になりました。 |
サンプル
例1 自動クロップの適切な処理
返り値のところで説明したとおり、全部クロップしてしまったときに imagecropauto() が返す値は FALSE となります。 この例では、クロップする部分がある場合にだけ画像リソース $im を自動クロップします。 それ以外の場合は、元の画像をそのまま使います。
$cropped = imagecropauto($im, IMG_CROP_DEFAULT);
if ($cropped !== false) { // 新しい画像リソースが戻された場合にだけ
imagedestroy($im); // 元の画像を破棄して
$im = $cropped; // クロップ後の画像を $im に代入します
}
参考
ワード検索
※入力キーワードが、関数名・説明文・タグに含まれるものを検索関数名アルファベット別
最終更新一覧
●stristr
大文字小文字を区別せず文字列を検索し、ヒット箇所以降(あるいは以前)の文字列を返却
●stripslashes
バックスラッシュでエスケープされた文字列から、バックスラッシュを取り除く
●stripos
大文字小文字を区別せずに文字列が最初に現れる位置を取得する
●stripcslashes
addcslashes() でクォートされた文字列をアンクォートする
●strip_tags
文字列から HTML と PHP のタグを除去して返却
●strcspn
指定した文字が最初に現れる位置を調べる
●strcoll
ロケールに基づいて2つの文字列を比較し同じか(あるいは大小)を判定する
●strcmp
2つの文字列を比較し同じか(あるいは大小)を判定する
●strchr
strstr() のエイリアス
●strcasecmp
2つの文字列を比較(大文字小文字を区別せず同じとみなす)
カテゴリー一覧
PHP の振る舞いの変更
音声フォーマットの操作
認証サービス
コマンドライン関連
圧縮およびアーカイブ
暗号
データベース関連
日付および時刻関連
ファイルシステム
自然言語および文字エンコーディング
画像処理および作成
メール関連
数学
テキスト以外の MIME 型
プロセス制御
その他の基本モジュール
その他のサービス
検索エンジン用の拡張モジュール
サーバー固有のモジュール
セッション関連
テキスト処理
変数・データ型関連
ウェブサービス
Windows 用のモジュール
XML 操作
GUI用の拡張モジュール