Rumah >pembangunan bahagian belakang >C++ >Bagaimana untuk Menukar RGB kepada HSV dan HSV kepada Nilai RGB dalam Julat 0-255?

Bagaimana untuk Menukar RGB kepada HSV dan HSV kepada Nilai RGB dalam Julat 0-255?

Linda Hamilton
Linda Hamiltonasal
2024-12-10 10:20:15987semak imbas

How to Convert RGB to HSV and HSV to RGB Values within a 0-255 Range?

Algoritma untuk Penukaran RGB ke HSV dan HSV ke RGB dalam Julat 0-255

Algoritma penukaran ruang warna dibentangkan untuk menukar warna RGB nilai kepada HSV dan sebaliknya, mengekalkan julat 0 hingga 255 dalam kedua-dua ruang warna. Begini cara ia beroperasi:

Penukaran RGB ke HSV (rgb2hsv)

Untuk menukar nilai RGB (r, g, b) kepada HSV (h, s, v):

  1. Tentukan nilai minimum dan maksimum antara r, g dan b.
  2. Kira komponen nilai (v) sebagai nilai maksimum.
  3. Kira komponen tepu (s) sebagai perkadaran (v - nilai minimum) kepada v.
  4. Tentukan komponen rona (h):

    • Jika r adalah maksimum, h dikira sebagai (g - b) / (v - nilai minimum).
    • Jika g adalah maksimum, h ialah 2.0 (b - r) / (v - nilai minimum).
    • Jika b ialah maksimum, h ialah 4.0 (r - g) / (v - nilai minimum).
  5. Tukarkan sudut h kepada darjah.
  6. Jika h negatif, tambah 360 darjah.

Penukaran HSV kepada RGB (hsv2rgb)

Untuk menukar nilai HSV (h, s, v) kepada RGB (r, g, b):

  1. Jika s ialah sifar, tetapkan r, g, dan b hingga v.
  2. Jika tidak, hitung pecahan sudut rona (hh) dan lantai (i) bagi hh.
  3. Kira nilai p=v⋅(1−s), q =v⋅(1−s⋅(1−hh)), dan t=v⋅(1−s⋅hh).
  4. Berdasarkan i, tetapkan nilai kepada r, g dan b:

    • Kes 0: r=v , g=t, b=p
    • Kes 1: r=q, g=v, b=p
    • Kes 2: r=p, g=v, b=t
    • Kes 3: r=p, g=q, b=v
    • Kes 4: r=t, g=p, b=v
    • Kes 5: r=v, g=p, b=q

Fungsi ini membolehkan penukaran yang cekap dan tepat antara ruang warna RGB dan HSV, yang penting untuk aplikasi yang melibatkan manipulasi warna dan pemprosesan imej.

Atas ialah kandungan terperinci Bagaimana untuk Menukar RGB kepada HSV dan HSV kepada Nilai RGB dalam Julat 0-255?. 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