142
- 收藏
- 点赞
- 分享
- 举报
求助,通过网络接收h264数据,解码后通过region画出来,出现错位撕裂 Hi3519DV500
通过ss_mpi_vdec_get_frame得到解码后的数据
while (vde->onoff) { int ret = ss_mpi_vdec_get_frame(chn, &frame, NULL, -1); // printf("ss_mpi_vdec_get_frame %X \n", ret); if (ret != TD_SUCCESS) { printf("ss_mpi_vdec_get_frame %X \n", ret); continue; } else { // memset(data,0,yuv_size); td_u8 *addr = ss_mpi_sys_mmap_cached(frame.video_frame.phys_addr[0], yuv_size); if (addr == TD_NULL) { printf("sys_mmap_cached for yuv failed\n"); return TD_NULL; } (td_void) ss_mpi_sys_flush_cache(frame.video_frame.phys_addr[0], addr, yuv_size); memcpy_s(data, yuv_size, frame.video_frame.virt_addr[0], yuv_size); ss_mpi_sys_munmap(addr, yuv_size); addr = ss_mpi_sys_mmap_cached(frame.video_frame.phys_addr[1], yuv_size / 2); memcpy_s(uv, yuv_size / 2, addr, yuv_size / 2); (td_void) ss_mpi_sys_flush_cache(frame.video_frame.phys_addr[1], addr, yuv_size / 2); ss_mpi_sys_munmap(addr, yuv_size / 2); vde->frameHandler(vde->chn, &frame, data, uv); //测试代码,如果把frame发给venc后,视频是正常的 ss_mpi_venc_send_frame(1,&frame, 0); } ss_mpi_vdec_release_frame(0, &frame); }
特别说明,解码是正常的,通过ss_mpi_venc_send_frame(1,&frame, 0);将frame发给venc后,存成文件能正常观看
这儿将yuv转换成rgb后,转成rgb1555,用region画出来;
static inline td_u32 GetYTileIndex(td_u32 x, td_u32 y, td_u32 stride)
{
const td_u32 tile_cols = stride / TILE_WIDTH; // 每行Tile数量
const td_u32 tile_x = x / TILE_WIDTH;
const td_u32 tile_y = y / TILE_HEIGHT;
const td_u32 in_tile_x = x - TILE_WIDTH * tile_x;
const td_u32 in_tile_y = y - TILE_HEIGHT * tile_y;
// printf("tile %d %d %d %d %d %d\n",x,y,tile_x,tile_y,in_tile_x,in_tile_y);
// 计算Tile起始地址 + Tile内偏移
return (tile_y * tile_cols + tile_x) * (TILE_WIDTH * TILE_HEIGHT) + in_tile_y * TILE_WIDTH + in_tile_x;
}
// UV分量Tile索引(32x8,色度下采样后)
static inline td_u32 GetUVTileIndex(td_u32 x, td_u32 y, td_u32 stride)
{
const td_u32 uv_tile_w = TILE_WIDTH / 2;
const td_u32 uv_tile_h = TILE_HEIGHT / 2;
const td_u32 tiles_per_row = (stride / 2) / uv_tile_w; // stride已下采样
const td_u32 tile_row = y / uv_tile_h;
const td_u32 tile_col = x / uv_tile_w;
const td_u32 in_tile_y = y % uv_tile_h;
const td_u32 in_tile_x = x % uv_tile_w;
return (tile_row * tiles_per_row + tile_col) * uv_tile_w * uv_tile_h + in_tile_y * uv_tile_w + in_tile_x;
}
static void frameHandler(int index, ot_video_frame_info *frame, td_u8 *ybuf, td_u8 *uv)
{
int w = frame->video_frame.width;
int h = frame->video_frame.height;
td_u8 *rgbBuf = members[index].regionBMP.data;
td_u32 stride = frame->video_frame.stride[0];
// FILE* fp = fopen("y_data.bin", "wb");
// fwrite(ybuf, 1, stride * h, fp);
// fclose(fp);
// for(int i=0;i<17;i++)
// memset(ybuf+stride*16*i, i*15, stride*16); // Y=255
// memset(uv, 0x80, stride*h/2); // U=V=128(中性色)
td_u8 r, g, b;
td_u8 *start = TD_NULL;
td_u16 *dst = TD_NULL;
td_u32 tile_idx;
for (int y = 0; y < h; y++)
{
for (int x = 0; x < w; x++)
{
tile_idx = GetYTileIndex(x, y, stride);
start = (td_u8 *)(ybuf + tile_idx);
dst = (td_u16 *)(rgbBuf + y * w * 2 + x * 2); /* 2 bytes */
tile_idx = UV_TILE_INDEX(x / 2, y / 2, stride);
const td_u8 *uv_ptr = uv + tile_idx * 2;
const td_u8 U = uv_ptr[1];
const td_u8 V = uv_ptr[0];
// YUV转RGB(BT.601标准)
r = *start;//CLAMP((298 * (*start - 16) + 409 * (V - 128) + 128) >> 8);
g = *start;//CLAMP((298 * (*start - 16) - 100 * (U - 128) - 208 * (V - 128) + 128) >> 8);
b =*start;// CLAMP((298 * (*start - 16) + 516 * (U - 128) + 128) >> 8);
*dst = RGB1555(r, g, b);
}
// break;
}
ss_mpi_rgn_set_bmp(index, &members[index].regionBMP);
}
下面是效果,视频是480*270的;第1张是只有亮度,第2张是y uv都有的
我来回答
回答4个
时间排序
认可量排序
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片
相关问答
-
2017-09-15 16:10:57
-
2013-03-16 15:45:23
-
2019-12-11 16:31:38
-
2016-12-27 11:19:32
-
2018-02-08 13:38:50
-
2024-01-08 21:11:18
-
2020-06-16 14:42:23
-
2017-05-04 17:31:57
-
2016-08-27 15:01:10
-
2016-08-18 17:41:33
-
2017-05-24 10:58:20
-
2014-09-04 12:43:59
-
2023-05-31 09:23:38
-
2016-09-20 15:47:30
-
2020-04-08 18:19:13
-
2024-10-31 09:53:14
-
2015-10-26 13:49:08
-
2016-01-17 00:22:36
-
2017-05-04 15:20:15
无更多相似问答 去提问

点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5hi3516dv500改了sensor驱动后使用pqtools出图出现彩色的竖条纹
-
10海思3559的VGS模块在VI上画线问题
-
53519dv500接lvds的sensor mn34120,图像出现很多竖线,sensor板接以前的3519v101没问题
-
103403外接hdmi口1024*600显示屏报错
-
5SS928点DC camera的6946,全屏紫色
-
5hi3519 的 网络传输的MTU值可以修改到比1500大嘛?
-
10WS73V100星闪扫描不到设备sle
-
5SS928/SD3403 录像失败 venc stream time out, exit thread; venc 2 stream buffer is full
-
10Hi3516DV500无法运行PQTool软件
-
10君正T23+1084带TF卡插卡(给该主板适配TF卡驱动,电机驱动,适配GPIO)
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认