Linux--V4L2应用程序开发(二)改变亮度

一、思路流程

创建一个新线程用来控制亮度,线程通过读取用户输入来增加或减少亮度值,并使用 ioctl 函数将新亮度值设置到视频设备。

二、代码

复制代码
/*创建线程来控制亮度*/
pthread_t thread;
pthread_create(&thread, NULL, thread_brightness_contrl,(void*)fd);



static void*thread_brightness_contrl(void* args)
{
    int fd = (int)args;
    unsigned char c;
    int brightness;
    int delta;

    struct v4l2_queryctrl qctrl;
    memset(&qctrl,0,sizeof(qctrl));
    qctrl.id = V4L2_CID_BRIGHTNESS;
    if(0 != ioctl(fd,VIDIOC_QUERYCTRL,&qctrl))
    {
        printf("can not query brightness\n");
        return NULL;
    }
    printf("brightness min = %d,max = %d\n",qctrl.minimum,qctrl.maximum);

    struct v4l2_control ctl;
    ctl.id = V4L2_CID_BRIGHTNESS;
    ioctl(fd, VIDIOC_G_CTRL,&ctl);

    while(1)
    {
        c= getchar();
        if (c=='u'||c=='U')
        {
            ctl.value += delta;
        }
        else if(c =='D'||c=='d')
        {
            ctl.value -=delta;
        }
        if(ctl.value >= qctrl.maximum) ctl.value = qctrl.maximum;
        if(ctl.value <= qctrl.minimum) ctl.value = qctrl.minimum;

        ioctl(fd,VIDIOC_S_CTRL,&ctl);
    }


    return NULL;
};

三、知识点补充

while循环关键点

  1. 阻塞等待 :当执行 c = getchar(); 时,如果没有输入,程序会在这里阻塞。这意味着线程会在此暂停,直到用户输入一个字符。

  2. 循环继续 :一旦用户输入一个字符,getchar() 返回字符并继续执行循环的剩余部分。循环并未终止,它只是被阻塞等待输入。

  3. 线程挂起 :由于 getchar() 阻塞等待输入,线程会被挂起,等待输入字符。挂起状态并不意味着 while 循环终止,而是线程暂停在 getchar() 这行代码。

相关推荐
qwy71522925816333 分钟前
1-Docker Engine 安装前置环境配置
运维·docker·容器
菜菜艾2 小时前
基于llama.cpp部署私有大模型
linux·运维·服务器·人工智能·ai·云计算·ai编程
重生的黑客2 小时前
Linux开发工具:条件编译、动静态库与 make/makefile 入门
linux·运维·服务器
minji...2 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
.柒宇.2 小时前
nginx入门教程
运维·nginx
w6100104663 小时前
cka-2026-ConfigMap
java·linux·cka·configmap
cc_yy_zh3 小时前
Win10 家庭版找不到Device Guard; 无法处理 VMware Workstation与Device Guard不兼容问题
linux·vmware
航Hang*3 小时前
VMware vSphere 云平台运维与管理基础——第2章(扩展):VMware ESXi 5.5 安装、配置与运维
运维·服务器·github·系统安全·虚拟化
嵌入式吴彦祖3 小时前
Luckfox Pico Ultra W WIFI
linux·嵌入式硬件
SPC的存折3 小时前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql