基于视频压缩的实时监控系统-sprint3采集端传输子系统设计

由于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采集端传输子系统设计的更多相关文章
- 基于视频压缩的实时监控系统-sprint2采集端图像采集子系统设计
(1).初始化:a.初始化摄像头:b.注册事件到epoll (2).开始采集--->触发事件处理系统 (3).保存图像(方便测试) a.初始化摄像头 //初始化摄像头 1.获取驱动信息 2.设置 ...
- \阶段4-独挡一面\项目-基于视频压缩的实时监控系统\Sprint2-采集端图像采集子系统设计
1.在编写程序前有一个流程,思维导图: 初始化:包括初始化摄像头:注册事件到epoll 然后是开始启动采集:一旦开始采集我们的摄像头就会有数据了,它会触发事件处理函数:我们在这里的处理是保存这个图像: ...
- 项目-基于视频压缩的实时监控系统--tiny6410
项目-基于视频压缩的实时监控系统--tiny6410 @国嵌linux学习笔记. 1. 构造服务端结构体 server struct server { int epfd; //保存epoll指针 st ...
- 基于视频压缩的实时监控系统-sprint1基于epoll架构的采集端程序设计
part1:产品功能 part2:epoll机制 select与epoll区别 1.select与epoll没有太大的区别.除了select有文件描述符限制(1024个),select每次调用都需 ...
- 阶段4-独挡一面\项目-基于视频压缩的实时监控系统\Sprint1-基于Epoll架构的采集端程序框架设计\第2课-基于Epoll的采集端程序框架设计
回顾之前的整个程序架构 把epoll机制应用到这个架构上去 下面主要去分析我们的系统中有没有需要等待的事件,先看看采集子系统 在采集子系统当中,摄像头有数据,摄像头采集到图像数据可以作为一个等待事件. ...
- 嵌入式应用开发第四阶段-基于rk3399的视频监控系统
一.需求分析 伴随着嵌入式技术.图像处理技术和无线网络传输技术的发展,传统模拟视频监控系统和基于PC的远程视频监控系统由于自身的不足,已经无法满足现代社会应用中不断涌现出来的新需求,于是基于嵌入式技术 ...
- 转: 透过CAT,来看分布式实时监控系统的设计与实现
评注: 开源的分布式监控系统 转:http://www.infoq.com/cn/articles/distributed-real-time-monitoring-and-control-syste ...
- 透过CAT,来看分布式实时监控系统的设计与实现
2011年底,我加入大众点评网,出于很偶然的机会,决定开发CAT,为各个业务线打造分布式实时监控系统,CAT的核心概念源自eBay闭源系统CAL----eBay的几大法宝之一. 在当今互联网时代,业务 ...
- [经验交流] 试用基于 influxdb+kapacitor 的监控系统
2017年10月16日: 使用中发现kapacitor的ui过于简单,不能满足实际工作需要,现已切换到grafana --------- 两个月前试用了基于 elasticsearch + xpack ...
随机推荐
- Jenkins+tomcat自动发布的热部署/重启及遇到的坑解决办法
一.背景 公司的项目一直手动maven打包.上传服务器.关闭/开启tomcat,整个流程下来耗时耗力,虽然可以将所有流程通过shell脚本一次性解决,但如果可以通过idea的Jenkins插件一键自动 ...
- python 并发专题(一):并发基础相关概念,术语等
一.线程 1.概念 线程是程序执行流的最小执行单位,是行程中的实际运作单位. 进程是一个动态的过程,是一个活动的实体.简单来说,一个应用程序的运行就可以被看做是一个进程,而线程,是运行中的实际的任务执 ...
- 数据可视化之分析篇(十)Power BI应用:如何计算在职员工数量?
https://zhuanlan.zhihu.com/p/128652582 经常碰到的一类问题是,如何根据起止日期来计算某个时间点的数量,比如: 已知合同的生效日期和到期日期,特定日期的有效合同有 ...
- Python面试【315+道题】
第一部分 Python基础篇(80题) 为什么学习Python? 通过什么途径学习的Python? Python和Java.PHP.C.C#.C++等其他语言的对比? 简述解释型和编译型编程语言? P ...
- HotSpot的对象模型(5)
Java对象通过Oop来表示.Oop指的是 Ordinary Object Pointer(普通对象指针).在 Java 创建对象实例的时候创建,用于表示对象的实例信息.也就是说,在 Java 应用程 ...
- idea 项目启动console卡在Connected to the target VM, address: '127.0.0.1:51140', transport: 'socket'不动了
- db2数据库创建删除主键约束和创建删除唯一键约束
创建.删除唯一约束: db2 "alter table tabname add unique(colname)" db2 "alter table tabname dro ...
- web自动化测试实战之生成测试报告
同志们,老铁们,继上篇文章 web自动化测试实战之批量执行测试用例 之后我们接着继续往下走,有人说我们运行了所有测试用例,控制台输入的结果,如果很多测试用例那也不能够清晰快速的知道多少用例通过率以及错 ...
- OSCP Learning Notes - Buffer Overflows(1)
Introduction to Buffer Overflows Anatomy of Memory Anatomy of the Stack Fuzzing Tools: Vulnserver - ...
- vue : watch、computed、以及对象数组
watch和computed是vue框架中很重要的特性. 那么,他们是怎么作用于对象数组的? 今天我们就来探究一下. 上代码. <template> <div class=" ...