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

OSCHINA-MIRROR/dezhihuang-AVDataProcess

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
В этом репозитории не указан файл с открытой лицензией (LICENSE). При использовании обратитесь к конкретному описанию проекта и его зависимостям в коде.
Клонировать/Скачать
yuv420p_half_y.cpp 935
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
dezhihuang Отправлено 18.10.2017 05:13 a571e3a
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef int BOOL;
#define TRUE 1
#define FALSE 0
//分离YUV420P像素数据中的亮度分量Y的数值减半,降低图像的亮度
BOOL yuv420p_half_y(const char *file, int width, int height)
{
if (file == NULL) {
return FALSE;
}
FILE *fp = fopen(file, "rb+");
FILE *fp0 = fopen("./out/output_420p_half_y.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);
for(int i=0; i<width*height; i++) {
data[i] = data[i] / 2; //Y分量减半
}
fwrite(data, 1, width*height*3/2, fp0);
free(data);
fclose(fp);
fclose(fp0);
return TRUE;
}
int main(int argc, char *argv[])
{
if (argc == 4) {
yuv420p_half_y(argv[1], atoi(argv[2]), atoi(argv[3]));
}
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