由于jpg本来就是编码压缩后的格式,所有无需重复编码

传输子系统步骤:(1)初始化:a.socket(初始化tcp连接);b.将事件添加到epoll中

         (2)事件处理:接收到网络包、发送完网络包

struct tcp_srv* net_sys_init()
{
struct tcp_srv* s;
struct sockaddr_in addr;
struct sockaddr_in sin;
struct tcp_cli* c;
int len; s = calloc(, sizeof(struct tcp_srv));
c = calloc(, sizeof(struct tcp_cli)); //1. 初始化传输子系统(socket初始化)
//1.1 创建socket
s->sock = socket(AF_INET, SOCK_STREAM, ); //1.2 初始化地址
addr.sin_addr.s_addr = INADDR_ANY;
addr.sin_family = AF_INET;
addr.sin_port = htons(DEF_TCP_SRV_PORT); //1.3 bind地址
bind(s->sock, (struct sockaddr*)&addr, sizeof(struct sockaddr)); //1.4 listen
listen(s->sock, ); //1.5 accept
c->sock = accept(s->sock, (struct sockaddr*)&sin, &len);
memcpy(&(c->addr), &sin, len); //2. 将传输子系统中的事件加入epoll池
c->ev_rx = epoll_event_create(c->sock, EPOLLIN, rx_app_handler, c);
c->ev_tx = epoll_event_create(c->sock, EPOLLOUT, tx_app_handler, c); epoll_add_event(srv_main->epfd, c->ev_rx); return s;
}
void tx_app_handler(int sock, void* arg)
{ //发送事件
struct tcp_cli* c = arg;
send(sock, c->buf, c->len, ); epoll_del_event(srv_main->epfd, c->ev_tx);
epoll_add_event(srv_main->epfd, c->ev_rx);
} void rx_app_handler(int sock, void* arg)
{ //接收事件
unsigned char* pbuf;//保存读取的数据
struct tcp_cli* c = arg; pbuf = &(c->req[]);
read(c->sock, pbuf, FRAME_HDR_SZ);
process_incoming(c);//数据处理子函数
}
int process_incoming(struct tcp_cli* c)
{
//针对不同的命令做处理
__u8 id;
__u8 data[FRAME_DAT_MAX];//数据最大长度
struct cam* v = srv_main->cam;
__u8* req = c->req;
__u8* rsp = c->rsp;
__u8 status = ERR_SUCCESS;
__u32 pos, len, size; id = req[CMD1_POS];//请求的ID switch (id)
{
case REQUEST_ID(VID_GET_FMT)://VID_GET_FMT
//1. 获取图像格式
cam_get_fmt(v, data); //2. 构造返回数据
build_ack(rsp, (TYPE_SREQ << TYPE_BIT_POS) | SUBS_VID, id, , data); //3. 发送返回数据
net_send(c, rsp, FRAME_HDR_SZ + ); break;
case REQUEST_ID(VID_REQ_FRAME)://VID_REQ_FRAME
//1. 获取一帧图像
pos = FRAME_HDR_SZ + ;
size = cam_get_trans_frame(v, &rsp[pos]);//获取到图像的长度; //2. 构造返回数据,按照要求的格式数发送
build_ack(rsp, (TYPE_SREQ << TYPE_BIT_POS) | SUBS_VID, id, , (__u8*)&size); //3. 发送返回数据
net_send(c, rsp, FRAME_HDR_SZ + + size);
break;
default:
break;
}
return status;
}
int build_ack(unsigned char* rsp, unsigned char type, unsigned char id, unsigned char len, unsigned char* data)
{ //cam.c构造返回数据
rsp[LEN_POS] = len;
rsp[CMD0_POS] = type;
rsp[CMD1_POS] = id;
memcpy(&rsp[DAT_POS], data, len); return len + FRAME_HDR_SZ;
}
void net_send(struct tcp_cli* tc, void* buf, int len)
{ // 发送返回数据
struct tcp_cli* c = (struct tcp_cli*)tc;
struct tcp_srv* s = c->srv; epoll_del_event(s->epfd, c->ev_rx);
c->buf = buf;
c->len = len;
epoll_add_event(srv_main->epfd, c->ev_tx);
}

基于视频压缩的实时监控系统-sprint3采集端传输子系统设计的更多相关文章

  1. 基于视频压缩的实时监控系统-sprint2采集端图像采集子系统设计

    (1).初始化:a.初始化摄像头:b.注册事件到epoll (2).开始采集--->触发事件处理系统 (3).保存图像(方便测试) a.初始化摄像头 //初始化摄像头 1.获取驱动信息 2.设置 ...

  2. \阶段4-独挡一面\项目-基于视频压缩的实时监控系统\Sprint2-采集端图像采集子系统设计

    1.在编写程序前有一个流程,思维导图: 初始化:包括初始化摄像头:注册事件到epoll 然后是开始启动采集:一旦开始采集我们的摄像头就会有数据了,它会触发事件处理函数:我们在这里的处理是保存这个图像: ...

  3. 项目-基于视频压缩的实时监控系统--tiny6410

    项目-基于视频压缩的实时监控系统--tiny6410 @国嵌linux学习笔记. 1. 构造服务端结构体 server struct server { int epfd; //保存epoll指针 st ...

  4. 基于视频压缩的实时监控系统-sprint1基于epoll架构的采集端程序设计

    part1:产品功能 part2:epoll机制   select与epoll区别 1.select与epoll没有太大的区别.除了select有文件描述符限制(1024个),select每次调用都需 ...

  5. 阶段4-独挡一面\项目-基于视频压缩的实时监控系统\Sprint1-基于Epoll架构的采集端程序框架设计\第2课-基于Epoll的采集端程序框架设计

    回顾之前的整个程序架构 把epoll机制应用到这个架构上去 下面主要去分析我们的系统中有没有需要等待的事件,先看看采集子系统 在采集子系统当中,摄像头有数据,摄像头采集到图像数据可以作为一个等待事件. ...

  6. 嵌入式应用开发第四阶段-基于rk3399的视频监控系统

    一.需求分析 伴随着嵌入式技术.图像处理技术和无线网络传输技术的发展,传统模拟视频监控系统和基于PC的远程视频监控系统由于自身的不足,已经无法满足现代社会应用中不断涌现出来的新需求,于是基于嵌入式技术 ...

  7. 转: 透过CAT,来看分布式实时监控系统的设计与实现

    评注: 开源的分布式监控系统 转:http://www.infoq.com/cn/articles/distributed-real-time-monitoring-and-control-syste ...

  8. 透过CAT,来看分布式实时监控系统的设计与实现

    2011年底,我加入大众点评网,出于很偶然的机会,决定开发CAT,为各个业务线打造分布式实时监控系统,CAT的核心概念源自eBay闭源系统CAL----eBay的几大法宝之一. 在当今互联网时代,业务 ...

  9. [经验交流] 试用基于 influxdb+kapacitor 的监控系统

    2017年10月16日: 使用中发现kapacitor的ui过于简单,不能满足实际工作需要,现已切换到grafana --------- 两个月前试用了基于 elasticsearch + xpack ...

随机推荐

  1. 赋值,逻辑,运算符, 控制流程之if 判断

    赋值运算 (1). 增量运算 age += 1 # age = age + 1 print(age) age -= 10 # age = age - 10 (2).交叉赋值 x = 111 y = 2 ...

  2. Python面向对象01 /面向对象初识、面向对象结构、类、self、实例化对象

    Python面向对象01 /面向对象初识.面向对象结构.类.self.实例化对象 目录 Python面向对象01 /面向对象初识.面向对象结构.类.self.实例化对象 1. 面向对象初识 2. 面向 ...

  3. L1和L2正则化。L1为什么能产生稀疏值,L2更平滑

    参考博客:https://zhuanlan.zhihu.com/p/35356992 https://zhuanlan.zhihu.com/p/25707761 https://www.zhihu.c ...

  4. Oracle数据泵详解

    一.EXPDP和IMPDP使用说明 Oracle Database 10g引入了最新的数据泵(Data Dump)技术,数据泵导出导入(EXPDP和IMPDP)的作用 1)实现逻辑备份和逻辑恢复. 2 ...

  5. 云原生时代高性能Java框架—Quarkus(一)

    --- Quarkus&GraalVM介绍.创建并启动第一个项目 Quarkus系列博文 Quarkus&GraalVM介绍.创建并启动第一个项目 构建Quarkus本地镜像.容器化部 ...

  6. Mock分页

    前后端分离开发时,一般会使用mock. 因为mock是用node运行的,行为与调用后台一致. 这样,不需要等后台写好,只要有接口文档,前端可以自己调接口,这样联调时遇到的问题会少很多,可以加快整体开发 ...

  7. Android 性能优化---布局优化

    Android 性能优化---布局优化 Android 布局绘制原理 布局加载过程 setContentView() --> inflate() -- > getLayout()(I/O操 ...

  8. Redis Desktop Manager安装

    Windows安装: 1.下载安装包 官网下载地址:https://redisdesktop.com/pricing 官网下载需要付费使用 再此附上一个免费的破解版本,绿色安全可用 链接:https: ...

  9. LeetCode 85 | 如何从矩阵当中找到数字围成的最大矩形的面积?

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode专题53篇文章,我们一起来看看LeetCode中的85题,Maximal Rectangle(最大面积矩形). 今天的 ...

  10. 2020最新全栈必备 Redis,你还不了解么

    什么是Redis Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如字符串, 散列, 列表, 集合, 有序集合与范围查 ...