由于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. SQL批量插入数据【万级】

    1.每4000条插入一次 for (int i = 0; i < dt.Rows.Count; i++) { IsTBProductForStockInfo model = new IsTBPr ...

  2. java 基础(三) 搭建Java编译环境(树莓派)

    安装需求1.JDK的安装2.PI4J的安装 JDK的安装1.首先到JDK的官网:https://www.oracle.com/technetwork/java/javase/downloads/ind ...

  3. 机器学习实战基础(二十一):sklearn中的降维算法PCA和SVD(二) PCA与SVD 之 降维究竟是怎样实现

    简述 在降维过程中,我们会减少特征的数量,这意味着删除数据,数据量变少则表示模型可以获取的信息会变少,模型的表现可能会因此受影响.同时,在高维数据中,必然有一些特征是不带有有效的信息的(比如噪音),或 ...

  4. 手把手整合SSM框架

    前言 如果看过前几篇文章,对 Spring 和 MyBatis 有了一定了解,一定想上手试试.这篇文章从 0 到 1,手把手整合 SSM (Spring.Spring MVC.MyBatis). 本篇 ...

  5. 邂逅Vue.js

    1.简单认识一下Vue.js Vue (读音 /vjuː/,类似于 view),不要读错. Vue是一个渐进式的框架,什么是渐进式的呢? p渐进式意味着你可以将Vue作为你应用的一部分嵌入其中,带来更 ...

  6. Nginx/Httpd反代tomcat配置

    在上一篇博客中,我们了解了tomcat的server.xml中各组件的用法和作用:其中对于tomcat连接器来说,它分三类,一类是http连接器,一类是https连接器,一类是ajp连接器:通常tom ...

  7. Vue全家桶之一Vue(基础知识篇)

    全家桶:Vue本身.状态管理.路由.   异步组件:     

  8. python监控服务器应用日志,推送钉钉机器人,实时关注日志异常

    生产环境多台服务器上部署了多个应用,日志出现报错时,无法及时反馈到开发人员.部署一个大型的运维监控应用,不但耗资源,而且配置也不简单. 简简单单写个python脚本来监控服务器日志就简单多了,废话不多 ...

  9. LESS实战::not与:hover混合使用

    举个例子,有个HTML是这样的. <div class="item light">A</div> <div class="item" ...

  10. PowerJob 技术综述,能领悟多少就看你下多少功夫了~

    本文适合有 Java 基础知识的人群 作者:HelloGitHub-Salieri HelloGitHub 推出的<讲解开源项目>系列.从本章开始,就正式进入 PowerJob 框架的技术 ...