Opencv-adding-borders
提供:Dev Guides
OpenCV-ボーダーの追加
この章では、画像にヒキガエルの境界線を付ける方法を説明します。
copyMakeBorder()メソッド
このメソッドの構文は次のパッケージ* org.opencv.core。に属するCoreという名前のクラスのメソッド copyMakeBorder()*を使用して、画像にさまざまな境界線を追加できます。
copyMakeBorder(src, dst, top, bottom, left, right, borderType)
このメソッドは、次のパラメータを受け入れます-
- src -ソース(入力)画像を表すクラス Mat のオブジェクト。
- dst -宛先(出力)イメージを表すクラス Mat のオブジェクト。
- top -画像の上部の境界線の長さを表す整数型の整数の変数。
- bottom -画像の下部の境界線の長さを表す整数型の整数の変数。
- 左-整数の変数は、画像の左側の境界線の長さを表す整数型です。
- right -画像の右側の境界線の長さを表す整数型の変数。
- borderType -使用される境界線のタイプを表す整数型の変数。
例
次のプログラムは、特定の画像に境界線を追加する方法を示す例です。
import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
public class AddingBorder {
public static void main( String[] args ) {
//Loading the OpenCV core library
System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
//Reading the Image from the file and storing it in to a Matrix object
String file ="E:/OpenCV/chap15/input.jpg";
Mat src = Imgcodecs.imread(file);
//Creating an empty matrix to store the result
Mat dst = new Mat();
Core.copyMakeBorder(src, dst, 20, 20, 20, 20, Core.BORDER_CONSTANT);
Imgcodecs.imwrite("E:/OpenCV/chap15/border_constant.jpg", dst);
System.out.println("Image Processed");
}
}
上記のプログラムで指定された入力画像 thresh_input.jpg が次のものであると仮定します。
出力
プログラムを実行すると、次の出力が得られます-
Image Processed
指定したパスを開くと、次のように出力画像を観察できます-
他の種類のボーダー
境界タイプに加えて、前の例で示した BORDER_CONSTANT は、OpenCVがさまざまな他のタイプの境界に対応しています。 これらのタイプはすべて、Coreクラスの事前定義された静的フィールド(固定値)によって表されます。
それぞれの事前定義値を* copyMakeBorder()メソッドの *borderType という名前のパラメーターに渡すことで、必要なしきい値操作のタイプを選択できます。
Core.copyMakeBorder(src, dst, 20, 20, 20, 20, Core.BORDER_CONSTANT);
以下は、さまざまなタイプの境界操作とそれぞれの出力を表す値です。
Operation and Description | Output |
---|---|
BORDER_CONSTANT | BORDER_CONSTANT |
BORDER_ISOLATED | BORDER_ISOLATED |
BORDER_DEFAULT | BORDER_DEFAULT |
BORDER_REFLECT | BORDER_REFLECT |
BORDER_REFLECT_101 | BORDER_REFLECT_101 |
BORDER_REFLECT101 | BORDER_REFLECT101 |
BORDER_REPLICATE | BORDER_REPLICATE |
BORDER_WRAP | BORDER_WRAP |