IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> Linux下基于TCP的视频传输(c++ ) -> 正文阅读

[网络协议]Linux下基于TCP的视频传输(c++ )

  1. 分段传输

代码说明:

首先,图像的大小为640*480,但是图像是三通道的彩色图像,每一列都有3个小列,所以每一行的像素个数为640*3;
其次,图像的高为480,也就是有480行,这里为了避免数组过大,所以传送时每一次传送15行,一共传送480/32=15次;
然后,传送时先用ptr指针找到每一行的首地址,在对每一行的像素进行遍历,依次把每行的640*3个像素点赋值给buf数组;
.h头文件中定义BUFFER_SIZE为640*480*3/32,每一行像素为640*3,每一轮传送15行,buf的大小为640*3/15
  • 发送方:
int transmit(cv::Mat image)
{
    if (image.empty())
    {
        printf("empty image\n\n");
        return -1;
    }
    for (int k = 0; k < 32; k++)
    {
        int num1 = IMG_HEIGHT / 32 * k;
        for (int i = 0; i < IMG_HEIGHT / 32; i++)
        {
            int num2 = i * IMG_WIDTH * 3;
            uchar* ucdata = image.ptr<uchar>(i + num1);
            for (int j = 0; j < IMG_WIDTH * 3; j++)
            {
                data.buf[num2 + j] = ucdata[j];
            }
        }

        if (k == 31)
            data.flag = 2;
        else
            data.flag = 1;

        if (send(sockClient, (char *)(&data), sizeof(data), 0) < 0)
        {
            printf("send msg error: %s(errno: %d)\n", strerror(errno), errno);
            return -1;
        }
    }
}
  • 接收方:
int receive(cv::Mat& image)
{
    cv::Mat img(IMG_HEIGHT, IMG_WIDTH, CV_8UC3, cv::Scalar(0));

    int needRecv = sizeof(recvbuf);  //28804
    int count = 0;
    extern int errno;

    while (1)
    {
        for (int i = 0; i < 32; i++)
        {
            int pos = 0;
            int len0 = 0;

            while (pos < needRecv)
            {
                len0 = recv(sockConn, (char*)(&data) + pos, needRecv - pos, 0);
                if (len0 < 0)
                {
                    printf("Server Recieve Data Failed!\n");
                    return -1;
                }
                pos += len0;
            }

            count = count + data.flag;

            int num1 = IMG_HEIGHT / 32 * i;
            for (int j = 0; j < IMG_HEIGHT / 32; j++)
            {
                int num2 = j * IMG_WIDTH * 3;
                uchar* ucdata = img.ptr<uchar>(j + num1);
                for (int k = 0; k < IMG_WIDTH * 3; k++)
                {
                    ucdata[k] = data.buf[num2 + k];
                }
            }

            if (data.flag == 2)
            {
                if (count == 33)
                {
                    image = img;
                    return 1;
                    count = 0;
                }
                else
                {
                    count = 0;
                    i = 0;
                }
            }
        }
    }
}
  1. 解码传输
  • 发送方:
	Mat image;
    VideoCapture capture(0);
    vector<uchar> data_encode;

    while (1)
    {
        if (!capture.read(image)) 
            break;
        imencode(".jpg", image, data_encode);
        int len_encode = data_encode.size();
        string len = to_string(len_encode);
        int length = len.length();
        for (int i = 0; i < 16 - length; i++)
        {
            len = len + " ";
        }
        //发送数据
        send(sockClient, len.c_str(), strlen(len.c_str()), 0);
        char send_char[1];
        for (int i = 0; i < len_encode; i++)
        {
            send_char[0] = data_encode[i];
            send(sockClient, send_char, 1, 0);
        }
        //接收返回信息
        char recvBuf[32];
        if(recv(sockClient, recvBuf, 32, 0))
            printf("%s\n", recvBuf);
    }
  • 接收方:
	while (1)
    {
        if (recv(conn, recvBuf, 16, 0))
        {
            for (int i = 0; i < 16; i++)
            {
                if (recvBuf[i]<'0' || recvBuf[i]>'9') recvBuf[i] = ' ';
            }
            data.resize(atoi(recvBuf));
            for (int i = 0; i < atoi(recvBuf); i++)
            {
                recv(conn, recvBuf_1, 1, 0);
                data[i] = recvBuf_1[0];
            }
            printf("Image recieved successfully!\n");
            send(conn, "Server has recieved messages!", 29, 0);
            img_decode = imdecode(data, CV_LOAD_IMAGE_COLOR);
            imshow("server", img_decode);
            if (waitKey(30) == 27) break;
        }
    }

参考链接:
1.摄像头监控视频传输实现(C++)
2.网络编程:基于TCP的socket网络传输视频(C++, python)

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-04-09 18:53:50  更:2022-04-09 18:56:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 3:39:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码