【OpenCV】cv2.arrowedLine関数の使い方【矢印を描画する】

【OpenCV】cv2.arrowedLine()の使い方【矢印を描画する】プログラミング
ゆうすけ
ゆうすけ

cv2.arrowedLine関数の使い方や引数が分からないです・・・

資格マフィア
資格マフィア

cv2.line関数は矢印線を描画する時に使う。
使い方や引数を解説しよう。

 

✔️ 本記事のテーマ

 cv2.arrowedLine関数の使い方

 

✔️ 読者さんへの前置きメッセージ

本記事は「OpenCV の arrowedLine関数」について書いています。

 

この記事を読むことで
「cv2.arrowedLineの使い方 や 画像中に矢印線を描画する方法」
について理解できます。

 

OpenCVを使うことで画像中に線を描画することができます。
参考:【OpenCV】cv2.line()の使い方【線を描画する】

 

OpenCVではただの直線だけではなく、
cv2.arrowedLine関数を使うことで矢印線を描画することもできます。

 

この記事ではcv2.arrowedLine関数の使い方や関数に与える引数まで徹底的に解説します。

 

それでは、解説していきましょう。

cv2.arrowedLine関数のサンプルコード

cv2.arrowedLine関数のサンプルコード

cv2.arrowedLineを使用したサンプルコードは以下のようなコードです。
この記事ではこのサンプルコードに沿って解説していきます。

import cv2

img = cv2.imread('./sample.png')

cv2.arrowedLine(img,
                pt1=(50, 150),
                pt2=(300, 300),
                color=(0, 255, 0),
                thickness=3,
                line_type=cv2.LINE_4,
                shift=0,
                tipLength=0.1)

cv2.imwrite('./sample_after.png', img)

 

このサンプルコードによって、生成される画像がこちらです。

画像_cv2_arrowedLineのサンプルコード

 

画像中に矢印線が描画されています。

 

cv2.arrowedLine関数の引数について

cv2.arrowedLine関数の引数について

サンプルコードの通り、cv2.arrowedLine関数は8個の引数を取ります。

cv2.arrowedLine(img,
                pt1=(50, 150),
                pt2=(300, 300),
                color=(0, 255, 0),
                thickness=3,
                line_type=cv2.LINE_4,
                shift=0,
                tipLength=0.1)

これらの引数がどのような意味を持つのかを順番に解説していきましょう。

cv2.arrowedLine関数の第1引数:img

cv2.arrowedLine関数の第1引数 img対象の画像データです。
Ndarray 型で指定します。

 

OpenCVで画像処理を行うためには、
まずcv2.imread関数によって画像データを読み込む必要があります。

img = cv2.imread('./sample.png')

 

サンプルコードではpythonファイルと同階層にある sample.png を読み込んでいます。

 

このようにして、読み込んだ画像データをcv2.arrowedLine関数に引数として渡すことで、その画像データに対して矢印線を描画します。

 

なお、OpenCVによる画像の読み込みについては
OpenCVで画像を読み込む方法【Python】
の記事で解説しています。

 

cv2.arrowedLine関数の第2引数:pt1

cv2.arrowedLineの第2引数 pt1 は描画する矢印線の始点の座標です。
(int型, int型)のtupleで指定します。

 

ちょうど以下の画像の丸で囲った点の座標です。

画像_cv2_arrowedLineの第2引数

座標は(x座標のピクセル, y座標のピクセル)の形式で指定する必要があります。

 

サンプルコードでは pt1=(50, 150) と指定しているので、
x座標: 50px, y座標: 150pxを始点とする直線を描画しています。

 

試しに pt1=(100, 150) と指定すると、
描画する直線の始点が右に移動します。

import cv2

img = cv2.imread('./sample.png')

cv2.arrowedLine(img,
                pt1=(100, 150),
                pt2=(300, 300),
                color=(0, 255, 0),
                thickness=3,
                line_type=cv2.LINE_4,
                shift=0,
                tipLength=0.1)

cv2.imwrite('./sample_after.png', img)

変更後画像_cv2_arrowedLine関数の第2引数

 

 

cv2.arrowedLine関数の第3引数:pt2

cv2.arrowedLineの第3引数 pt2 は描画する矢印線の終点の座標です。
(int型, int型)のtupleで指定します。

 

ちょうど以下の画像の丸で囲った点の座標です。

画像_cv2_arrowedLineの第3引数

 

座標は(x座標のピクセル, y座標のピクセル)で指定する必要があります。

 

サンプルコードでは pt1=(300, 300) と指定しているので、
x座標: 300px, y座標: 300pxを終点とする直線を描画しています。

 

試しに pt2=(350, 350) と指定すると、
描画する直線の終点が右下に移動します。

import cv2

img = cv2.imread('./sample.png')

cv2.arrowedLine(img,
                pt1=(50, 150),
                pt2=(350, 350),
                color=(0, 255, 0),
                thickness=3,
                line_type=cv2.LINE_4,
                shift=0,
                tipLength=0.1)

cv2.imwrite('./sample_after.png', img)

変更後画像_cv2_arrowedLineの第3引数

 

 

cv2.arrowedLine関数の第4引数:color

cv2.arrowedLineの第4引数 color は描画する線の色です。
(int型, int型, int型)のtupleで指定します。

 

colorは以下のBGR形式で指定する必要があります。

color = (青, 緑, 赤)

このような順番で3原色を数値で指定します。
各色の最大値は255です。

 

サンプルコードでは color=(0, 255, 0) としているので緑色を指定していることになります。

 

試しに color=(255, 0, 0)とすると、以下の画像のように青色の直線が描画されます。

import cv2

img = cv2.imread('./sample.png')

cv2.arrowedLine(img,
                pt1=(50, 150),
                pt2=(300, 300),
                color=(255, 0, 0),
                thickness=3,
                line_type=cv2.LINE_4,
                shift=0,
                tipLength=0.1)

cv2.imwrite('./sample_after.png', img)

変更後画像_cv2_lineの第4引数

 

 

cv2.arrowedLine関数の第5引数:thickness

cv2.arrowedLineの第5引数 thickness は描画する線の太さです。
int型で指定します。

 

以下の形式で描画する線の太さを指定することができます。

thickness = 数値(ピクセル)

 

サンプルコードでは thickness=3 としているので太さ3pxの線を描画しています。

 

なお、引数thicknessに負の数を渡すと、cv2.errorが発生します。

cv2.error: OpenCV(4.4.0) /private/var/folders/nz/vv4_9tw56nv9k3tkvyszvwg80000gn/T/pip-req-build-gi6lxw0x/opencv/modules/imgproc/src/drawing.cpp:1801: error: (-215:Assertion failed) 0 < thickness && thickness <= MAX_THICKNESS in function 'line'

thickness は0以上の整数で指定しましょう。

 

ちなみに、thicknessはデフォルト引数なので
引数を渡さなくともcv2.arrowedLine関数は動きます。
引数で値を渡さなかった場合は thickness=1の挙動になります。

 

なお、デフォルト引数については
pythonのデフォルト引数についての解説
の記事で解説しています。

 

cv2.arrowedLine関数の第6引数:lineType

cv2.arrowedLineの第6引数 lineType は線を描画するアルゴリズムの種類です。
OpenCVの独自コードで指定します。

 

引数lineTypeでは以下のアルゴリズムを選択することができます。

  • 4連結: cv2.LINE_4
  • 8連結: cv2.LINE_8(デフォルト)
  • アンチエイリアス: cv2.LINE_AA

 

lineTypeはデフォルト引数なので、引数を渡さなくともcv2.line関数は動きます。
引数で値を渡さなかった場合は lineType=cv2.LINE_8 の挙動になります。

 

アンチエイリアスとはピクセルの境目に出るギザギザを滑らかに表現する手法です。
ただ、長方形の描画では上記3つとも目でみてわかる違いはないです。
文字の描画などにすると違いが多少分かります。

 

なお、OpenCVによる文字の描画については
【OpenCV】cv2.putText関数の使い方【文字を描画する】
の記事で解説しています。

 

cv2.arrowedLine関数の第7引数:shift

cv2.arrowedLineの第7引数 shift は各座標において小数点以下の桁を表すビット数です。
int型で指定します。

 

これは正直あまり違いが分からないので、特に気にしなくても良いです。

 

shiftもデフォルト引数なので、特に値を渡さなければ shift=0として扱われます。

 

一応解説すると、shiftを指定した場合、座標(x, y)は以下の式で計算されます。

(x*2^(-shift), y*2^(-shift))


より正確な値で座標を指定することができるので、
理論上はより滑らかな描画を可能にしますが、目に見える違いはほとんどないです。

 

cv2.arrowedLineの第8引数:tipLength

cv2.arrowedLineの第8引数 tipLength矢の先の部分の長さです。
float型で指定します。

 

tipLength「全体の矢印線の長さに対する比率」で指定します。

 

サンプルコードでは tipLength=0.1 としているので
「全体の長さ」の10%が「矢の先の長さ」になっています。

 

試しに tipLength=0.3 とすると、矢の先の長さが長くなります。

import cv2

img = cv2.imread('./sample.png')

cv2.arrowedLine(img,
                pt1=(50, 150),
                pt2=(300, 300),
                color=(0, 255, 0),
                thickness=3,
                line_type=cv2.LINE_4,
                shift=0,
                tipLength=0.3)

cv2.imwrite('./sample_after.png', img)

変更後画像_cv2_lineの第8引数

 

 

画像処理プログラミングを独学で勉強するなら

画像処理プログラミングを独学で勉強するなら

OpenCVのarrowedLine関数の使い方と引数について解説しました。

 

OpenCVは画像処理には欠かすことのできないライブラリです。

 

もし、OpenCVについて独学でスキルをつけるなら、以下の書籍がオススメです。

 

この書籍はOpenCVの基礎から応用までを
丁寧にかつ詳細に解説しています。

 

OpenCVのほぼ全てを網羅しているとも言えるほどの徹底ぶりなので、
関数のリファレンスとしても使用することができます。
本記事で解説したcv2.arrowedLine関数も掲載されています。

エンジニアとしての自身の価値をチェックする(完全無料)

エンジニアとして、

自分の価値がどれくらいのものかご存知でしょうか?

 

エンジニアとしてIT業界に身を置いていると

今の会社でずっと働くのか、フリーランスとして独立するのか …

と様々な選択肢があります。

 

どの選択肢が正解なのかを見極めるためにも、選択肢を広げるためにも

自身の価値を知っておくことはとても重要です。

 

TechClips ME では、

職務経歴書をアップロードするだけで企業からのスカウトを受けることができます。

▼▼▼▼▼

▲▲▲▲▲

しかもTechClips MEでは想定年収を企業から提示してくれるので、

自身の価値を数字で分かりやすくたしかめることができます。

 

登録はもちろん完全無料なので、一度登録してみると良いかもしれません。

 

コメント

タイトルとURLをコピーしました