Main Content

このページの内容は最新ではありません。最新版の英語を参照するには、ここをクリックします。

imrect

(非推奨) ドラッグ可能な四角形の作成

関数 imrect は推奨されません。代わりに、新しい Rectangle ROI オブジェクトを使用してください。新しい ROI 簡易関数 drawrectangle を使用することもできます。詳細については、互換性の考慮事項を参照してください。

説明

imrect オブジェクトはイメージ上に対話型で四角形をカプセル化します。

マウスを使用して、四角形のサイズと位置を調整できます。四角形には、その外観や動作などを制御するコンテキスト メニューもあります。詳細については、使用方法を参照してください。

作成

説明

h = imrect は、現在の座標軸で四角形の対話型の配置を開始し、imrect オブジェクトを返します。

h = imrect(hparent) は、hparent で指定されるオブジェクトに四角形の対話型の配置を開始します。

h = imrect(hparent,position) は、hparent で指定されたオブジェクト上の位置 position にドラッグ可能な四角形を作成します。

また、h = imrect(___,"PositionConstraintFcn",fcn) は、位置制約関数 fcn を使用して四角形をドラッグできる場所を指定します。

入力引数

すべて展開する

親オブジェクトのハンドル。ハンドルとして指定します。親は通常 axes オブジェクトですが、hggroup オブジェクトの親である他の任意のオブジェクトにもなります。

四角形の位置。[xmin ymin width height] 形式の 4 要素ベクトルとして指定します。四角形の初期サイズは width x height で、四角形の左上隅は (x,y) 座標 (xmin,ymin) です。

位置制約関数。関数ハンドルとして指定します。fcn はマウスをドラッグできるときはいつでも呼び出せます。この関数を使用して、楕円をドラッグできる場所を制御します。有効な関数ハンドルの詳細については、関数 setPositionConstraintFcn のヘルプを参照してください。

プロパティ

すべて展開する

ROI が削除可能。true または false を指定します。

データ型: logical

使用法

対話型構文で imrect を呼び出すと、ポインターはイメージ上で十字形 に変わります。四角形を作成してから、マウスを使用してサイズと位置を調整できます。四角形では、その外観や動作などを制御するコンテキスト メニューもサポートされています。このコンテキスト メニューを表示するには、四角形を右クリックします。

表に imrect がサポートしている対話型動作を示します。

対話型動作説明
四角形の移動四角形内のポインターを移動します。ポインターが花形 に変わります。マウスをクリック アンド ドラッグして、四角形を移動します。
四角形のサイズ変更 ポインターを四角形の任意の辺または角に動かすと、形が両方向の矢印 に変わります。マウスを使用して辺または角をクリック アンド ドラッグします。
四角形の色の変更四角形内のポインターを移動します。右クリックで表示されるコンテキスト メニューから [色の設定] を選択します。
現在の位置の座標の取得多角形内のポインターを移動します。右クリックして、コンテキストメニューから [位置のコピー] を選択します。imrect は、4 要素の位置ベクトルをクリップボードにコピーします。
対話型でサイズ変更の実行時に四角形の現在の縦横比を維持します。 四角形内のポインターを移動します。右クリックして、コンテキスト メニューから [縦横比を固定] を選択します。
四角形の削除ポインターを四角形内または四角形の辺に移動します。右クリックして、コンテキスト メニューから [削除] を選択します。コンテキスト メニューからこのオプションを削除するには、Deletable プロパティを false に設定します。h = imrect(); h.Deletable = false;

setResizeable を使用して四角形のサイズ変更を不可にすると、[縦横比を固定] コンテキスト メニュー項目は表示されません。

オブジェクト関数

imrect オブジェクトは、多数の関数をサポートしています。詳細なリストを参照するには、methods imrect を入力してください。

addNewPositionCallbackROI オブジェクトに新しい位置のコールバックを追加する
createMask(非推奨) イメージ内にマスクを作成する
deleteハンドル オブジェクトの削除
getColorROI オブジェクトの描画に使用する色を取得する
getPositionROI オブジェクトの現在の位置を返す
getPositionConstraintFcn現在の位置制約関数への関数ハンドルを返す
removeNewPositionCallbackROI オブジェクトから新しい位置のコールバックを削除する
resume(非推奨) MATLAB コマンド ラインの実行の再開
setColor(非推奨) ROI オブジェクトの描画に使用する色の設定
setConstrainedPositionROI オブジェクトに新しい位置を設定する
setFixedAspectRatioModeROI オブジェクトをサイズ変更したときに縦横比を維持する
setPosition(非推奨) ROI オブジェクトを新しい位置に移動
setPositionConstraintFcnROI オブジェクトの位置制約関数の設定
setResizableROI オブジェクトのサイズ変更動作の設定
wait(非推奨) ROI の作成が完了するまで MATLAB コマンド ラインをブロックする

すべて折りたたむ

イメージ上に四角形の ROI を表示します。タイトルに四角形の位置を表示します。四角形移動時にタイトルを更新します。四角形の 1 辺をドラッグしてイメージの境界外への移動を試みます。

imshow("cameraman.tif")
h = imrect(gca,[10 10 100 100]);
addNewPositionCallback(h,@(p) title(mat2str(p,3)));

元のイメージの XLimYLim の範囲内に四角形を保持するために、makeConstrainToRectFcn を使用して位置制約関数を指定します。

fcn = makeConstrainToRectFcn("imrect",get(gca,"XLim"),get(gca,"YLim"));
setPositionConstraintFcn(h,fcn);

次に、マウスを使用して四角形をドラッグします。四角形がイメージの境界を越えられなくなっていることを確認します。

クリック アンド ドラッグにより四角形を対話形式で配置します。wait を使用して MATLAB® コマンド ラインをブロックします。MATLAB コマンド ラインの実行を再開するには、四角形をダブルクリックします。

imshow("pout.tif");
h = imrect;
position = wait(h);

ヒント

image オブジェクトを含んでいる axes で imrect を使用し、位置制約関数を指定しない場合、イメージの範囲外に四角形をドラッグできます。関数 plot で作成した座標軸で使用すると、座標軸の範囲は四角形の動きに合わせて自動的に拡張されます。

バージョン履歴

R2006a より前に導入

すべて折りたたむ

R2018b: 関数 imrect は非推奨

R2018b 以降、既存の ROI オブジェクトのセットが新しい ROI オブジェクトのセットに置き換えられています。新しいオブジェクトは、面の色の透明度など、さらに便利な機能を提供します。新しいクラスでは、移動やクリックなどの ROI の変化に応答するために使用できるイベントもサポートされています。現時点では、以前の ROI オブジェクトを削除する予定はありませんが、追加された機能や柔軟性を活用するために、新しい ROI に切り替えてください。新しい ROI 関数を使用した ROI の作成方法の詳細については、ROI の形状の作成を参照してください。

imrect ROI オブジェクトを使用する代わりに、新しい Rectangle ROI オブジェクトを使用してください。ROI 作成簡易関数 drawrectangle を使用することもできます。

ROI 作成コードの更新

imrect のすべてのインスタンスを更新してください。

非推奨の使用方法推奨される代替案

この例では四角形 ROI を作成します。

imshow("cameraman.tif");
h = imrect(gca,[10 10 100 150]);

次のコードは等価なコードで、古い ROI オブジェクトが新しい ROI オブジェクトに置き換えられています。この例では、ROI 作成簡易関数を使用しています。サイズと位置の情報を名前と値の引数として指定しなければならないことに注意してください。

imshow("cameraman.tif");
h = drawrectangle(gca,"Position",[10 10 100 150]);
その他の ROI コードの更新

imrect ROI オブジェクトのいずれかのオブジェクト関数を使用するコードを更新してください。多くの場合、単純に Rectangle ROI オブジェクト プロパティの値にアクセスするかその値を設定することによって、オブジェクト関数 imrect の呼び出しを置き換えることができます。たとえば、getColor または setColor の呼び出しの代わりに Color プロパティを使用します。場合によっては、オブジェクト関数 imrect を新しい Rectangle ROI のオブジェクト関数に置き換えなければなりません。個々の ROI オブジェクト関数 imrect には、新しい Rectangle ROI オブジェクトへの移行に関する情報が含まれています。移行の概要については、ROI の移行を参照してください。