Main Content

impoint

(非推奨) ドラッグ可能な点の作成

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

説明

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

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

作成

説明

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

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

h = impoint(hparent,position) はドラッグ可能な点を position で定義される座標に作成します。

h = impoint(hparent,x,y) はドラッグ可能な点を x および y で定義される (x, y) 座標に作成します。

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

入力引数

すべて展開する

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

点の位置。[x y] 形式の 2 要素ベクトルとして指定します。

点の x 座標。数値スカラーとして指定します。

点の y 座標。数値スカラーとして指定します。

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

プロパティ

すべて展開する

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

データ型: logical

使用法

対話型構文で impoint を呼び出すと、ポインターはイメージ上で十字形 に変わります。マウスをクリック アンド ドラッグして、点の位置を指定します。点では、その外観や動作などを制御するコンテキスト メニューがサポートされています。

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

対話型動作説明
点の移動。マウス ポインターを点上に移動します。マウス ポインターが花形 に変わります。マウスをクリック アンド ドラッグして、点を移動します。
点の表示に使用する色の変更。 マウス ポインターを点上に移動します。右クリックで表示されるコンテキスト メニューから [色の設定] を選択し、使用する色を指定します。
点の座標の取得。マウス ポインターを点上に移動します。右クリックで表示されるコンテキスト メニューから [位置のコピー] を選択し、点の座標 [X Y] を指定する 1 行 2 列の配列をクリップボードにコピーします。
点の削除。ポインターを点の上に移動します。右クリックして、コンテキスト メニューから [削除] を選択します。コンテキスト メニューからこのオプションを削除するには、Deletable プロパティを false に設定します。h = impoint(); h.Deletable = false;

オブジェクト関数

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

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

すべて折りたたむ

関数 impoint を使用してカスタム色の設定、ラベルの設定、境界の強制的な制約、点の移動に伴うタイトル内の位置の更新を行います。

imshow("rice.png")
h = impoint(gca,100,200);

addNewPositionCallback を使用して、新しい位置でタイトルを更新します。

addNewPositionCallback(h,@(h) title(sprintf('(%1.0f,%1.0f)',h(1),h(2))));

makeConstrainToRectFcn を使用して境界制約関数を作成します。

fcn = makeConstrainToRectFcn("impoint",get(gca,"XLim"),get(gca,"YLim"));

setPositionConstraintFcn を使用して境界制約関数を実行します。

setPositionConstraintFcn(h,fcn);
setColor(h,"r");
setString(h,"Point label");

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

imshow("pout.tif")
h = impoint(gca,[]);
position = wait(h);

ヒント

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

バージョン履歴

R2006a より前に導入

すべて展開する