1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/dezhihuang-AVDataProcess

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
В этом репозитории не указан файл с открытой лицензией (LICENSE). При использовании обратитесь к конкретному описанию проекта и его зависимостям в коде.
Клонировать/Скачать
yuv420p_border.cpp 3 КБ
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
dezhihuang Отправлено 17.10.2017 12:49 a920f59
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef int BOOL;
#define TRUE 1
#define FALSE 0
//分离YUV420P像素数据中的Y、U、V分量
BOOL yuv420p_border(const char *file, int width, int height, int border)
{
if (file == NULL) {
return FALSE;
}
FILE *fp = fopen(file, "rb+");
FILE *fp0 = fopen("./out/output_420p_border.yuv", "wb+");
unsigned char *data = (unsigned char *)malloc(width*height*3/2);
memset(data, 0, width*height*3/2);
fread(data, 1, width*height*3/2, fp);
//给Y分量添加边框
for(int i=0; i<height; i++) {
for(int j=0; j<width; j++) {
//添加左右边框
if (j < border) {
data[i*width + j] = 255;
continue;
}
if (j >= width-border) {
data[i*width + j] = 255;
continue;
}
//添加上下边框
if (i < border) {
data[i*width + j] = 255;
continue;
}
if (i >= width-border) {
data[i*width + j] = 255;
continue;
}
}
}
int tmpBorder = border/2;
int tmpW = width/2;
int tmpH = height/2;
//给U分量添加边框
int uDataStart = width*height;
for(int i=0; i<tmpH; i++) {
for(int j=0; j<tmpW; j++) {
//添加左右边框
if (j < tmpBorder) {
data[uDataStart + i*tmpW + j] = 255;
continue;
}
if (j >= tmpW-tmpBorder) {
data[uDataStart + i*tmpW + j] = 255;
continue;
}
//添加上下边框
if (i < tmpBorder) {
data[uDataStart + i*tmpW + j] = 255;
continue;
}
if (i >= tmpW-tmpBorder) {
data[uDataStart + i*tmpW + j] = 255;
continue;
}
}
}
//给V分量添加边框
int vDataStart = width*height*5/4;
for(int i=0; i<tmpH; i++) {
for(int j=0; j<tmpW; j++) {
//添加左右边框
if (j < tmpBorder) {
data[vDataStart + i*tmpW + j] = 255;
continue;
}
if (j >= tmpW-tmpBorder) {
data[vDataStart + i*tmpW + j] = 255;
continue;
}
//添加上下边框
if (i < tmpBorder) {
data[vDataStart + i*tmpW + j] = 255;
continue;
}
if (i >= tmpW-tmpBorder) {
data[vDataStart + i*tmpW + j] = 255;
continue;
}
}
}
fwrite(data, 1, width*height*3/2, fp0);
free(data);
fclose(fp);
fclose(fp0);
return TRUE;
}
int main(int argc, char *argv[])
{
if (argc == 5) {
yuv420p_border(argv[1], atoi(argv[2]), atoi(argv[3]), atoi(argv[4]));
}
return 0;
}

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://api.gitlife.ru/oschina-mirror/dezhihuang-AVDataProcess.git
git@api.gitlife.ru:oschina-mirror/dezhihuang-AVDataProcess.git
oschina-mirror
dezhihuang-AVDataProcess
dezhihuang-AVDataProcess
master