Python 实现RGB和YUV互转

RGB和YUV互转

python 复制代码
class Color:
    # BT601 数字Full range
    def __init__(self):
        pass

    def YUV2RGB(self, Y, U, V):
        # R,G,B (0~255)
        R= Y + ((360 * (V - 128))>>8)
        G= Y - (( ( 88 * (U - 128)  + 184 * (V - 128)) )>>8) 
        B= Y +((455 * (U - 128))>>8) 
        return R,G,B
    
    def RGB2YUV(self, R, G, B):
        # Y(0~255),  U,V(-128~128)          
        Y = (77*R + 150*G + 29*B)>>8
        U = ((-44*R  - 87*G  + 131*B)>>8) + 128
        V = ((131*R - 110*G - 21*B)>>8) + 128
        return Y,U,V
    
    def YUV2RGBF(self, Y, U, V):
        # R,G,B (0.0~255.0)
        R = Y+1.4075*(V-128)
        G = Y-0.3455*(U-128)-0.7169*(V-128)
        B = Y+1.779*(U-128)
        return R,G,B
    
    def RGB2YUVF(self, R, G, B):
        # Y(0.0~255.0),  U,V(-128.0~128.0)
        Y = 0.299*R + 0.587*G + 0.114*B
        U = -0.169*R - 0.331*G + 0.5*B + 128
        V = 0.5*R - 0.419*G - 0.081*B + 128
        return Y,U,V


# 测试代码:    
color = Color()

y,u,v = color.RGB2YUV(255, 255, 255)
print("Y:{:.02f}, U:{:.02f}, V:{:.02f}".format(y, u, v))

r,g,b = color.YUV2RGB(y,u,v)
print("R:{:.02f}, G:{:.02f}, B:{:.02f}".format(r, g, b))
相关推荐
Rabbit_QL2 小时前
【水印添加工具】从零设计一个工程级 Python 图片水印工具:WaterMask 架构与实现
开发语言·python
天“码”行空3 小时前
简化Lambda——方法引用
java·开发语言
z20348315203 小时前
C++对象布局
开发语言·c++
Beginner x_u3 小时前
如何解释JavaScript 中 this 的值?
开发语言·前端·javascript·this 指针
java1234_小锋3 小时前
Java线程之间是如何通信的?
java·开发语言
张张努力变强3 小时前
C++ Date日期类的设计与实现全解析
java·开发语言·c++·算法
曲幽4 小时前
FastAPI多进程部署:定时任务重复执行?手把手教你用锁搞定
redis·python·fastapi·web·lock·works
feifeigo1234 小时前
基于EM算法的混合Copula MATLAB实现
开发语言·算法·matlab
LYS_06184 小时前
RM赛事C型板九轴IMU解算(4)(卡尔曼滤波)
c语言·开发语言·前端·卡尔曼滤波
森屿~~4 小时前
AI 手势识别系统:踩坑与实现全记录 (PyTorch + MediaPipe)
人工智能·pytorch·python