Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Memilih Sempadan Atas dan Bawah HSV yang Betul untuk Pengesanan Warna Tepat dalam OpenCV?

Bagaimana untuk Memilih Sempadan Atas dan Bawah HSV yang Betul untuk Pengesanan Warna Tepat dalam OpenCV?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-02 01:36:10890semak imbas

How to Choose the Correct HSV Upper and Lower Boundaries for Accurate Color Detection in OpenCV?

Memilih Sempadan HSV Atas dan Bawah yang Betul untuk Pengesanan Warna dengan cv::inRange (OpenCV)

Apabila mengesan warna dalam imej menggunakan fungsi cv::inRange dalam OpenCV, adalah penting untuk memilih sempadan atas dan bawah yang sesuai untuk Ruang warna HSV (Hue, Saturation, Value). Ini memastikan pengesanan warna yang tepat dan membolehkan pembahagian yang cekap.

Masalah:

Pertimbangkan imej yang mengandungi penutup oren pada tin kopi. Nilai HSV di tengah tudung, yang diperoleh menggunakan utiliti gcolor2, ialah (22, 59, 100). Menggunakan sempadan awal yang ditakrifkan sebagai min = (18, 40, 90) dan maks = (27, 255, 255) menghasilkan hasil pengesanan yang tidak dijangka.

Penyelesaian:

Masalah 1: Julat HSV Variasi

Aplikasi yang berbeza selalunya menggunakan skala yang berbeza untuk nilai HSV. GIMP, contohnya, menggunakan skala H: 0-360, S: 0-100, V: 0-100, manakala OpenCV menggunakan H: 0-179, S: 0-255, V: 0-255. Dalam kes ini, nilai warna 22 dalam GIMP hendaklah ditukar kepada 11 dalam OpenCV dengan mengambil separuh daripada nilainya. Oleh itu, sempadan yang disemak menjadi (5, 50, 50) - (15, 255, 255).

Masalah 2: Keserasian Ruang Warna

OpenCV menggunakan BGR Format warna (Biru-Hijau-Merah), bukan RGB. Untuk memastikan keserasian, kod yang menukar RGB kepada HSV hendaklah diubah suai kepada:

cv.CvtColor(frame, frameHSV, cv.CV_BGR2HSV)

Kod Kemas Kini:

import cv

in_image = 'kaffee.png'
out_image = 'kaffee_out.png'
out_image_thr = 'kaffee_thr.png'

ORANGE_MIN = cv.Scalar(5, 50, 50)
ORANGE_MAX = cv.Scalar(15, 255, 255)
COLOR_MIN = ORANGE_MIN
COLOR_MAX = ORANGE_MAX

def test1():
    frame = cv.LoadImage(in_image)
    frameHSV = cv.CreateImage(cv.GetSize(frame), 8, 3)
    cv.CvtColor(frame, frameHSV, cv.CV_BGR2HSV)
    frame_threshed = cv.CreateImage(cv.GetSize(frameHSV), 8, 1)
    cv.InRangeS(frameHSV, COLOR_MIN, COLOR_MAX, frame_threshed)
    cv.SaveImage(out_image_thr, frame_threshed)

if __name__ == '__main__':
    test1()

Hasil:

Menjalankan kod yang dikemas kini menghasilkan pembahagian oren yang lebih tepat penutup.

Nota:

Mungkin terdapat beberapa pengesanan palsu kecil disebabkan rona yang serupa di latar belakang. Untuk menangani perkara ini, pemprosesan lanjut seperti analisis kontur boleh digunakan untuk mengasingkan kontur terbesar yang sepadan dengan tudung.

Atas ialah kandungan terperinci Bagaimana untuk Memilih Sempadan Atas dan Bawah HSV yang Betul untuk Pengesanan Warna Tepat dalam OpenCV?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn