Commit 4a6c42f736a3c546db976d433cbcea9fe778001a
1 parent
fc440c2c
Exists in
master
and in
2 other branches
[UPDATE] Analisar PCR do vídeo quando for TS.
Showing
7 changed files
with
66 additions
and
54 deletions
Show diff stats
Makefile
| @@ -171,4 +171,4 @@ svn: | @@ -171,4 +171,4 @@ svn: | ||
| 171 | @find -iname "*.swp" -exec rm {} \; | 171 | @find -iname "*.swp" -exec rm {} \; |
| 172 | @find -iname "*.tmp" -exec rm {} \; | 172 | @find -iname "*.tmp" -exec rm {} \; |
| 173 | @find -iname "*.svn-base" -exec rm -r {} \; | 173 | @find -iname "*.svn-base" -exec rm -r {} \; |
| 174 | - @find -iname "*.svn" -exec rm -r {} \; | ||
| 175 | \ No newline at end of file | 174 | \ No newline at end of file |
| 175 | + @find -iname "*.svn" -exec rm -r {} ;\ | ||
| 176 | \ No newline at end of file | 176 | \ No newline at end of file |
extratorSRT/src/extratorSRT.cpp
| @@ -76,11 +76,11 @@ void ExtratorSRT::Run(){ | @@ -76,11 +76,11 @@ void ExtratorSRT::Run(){ | ||
| 76 | 76 | ||
| 77 | 77 | ||
| 78 | void ExtratorSRT::notifyPCRBase(uint64_t pcrbase){ | 78 | void ExtratorSRT::notifyPCRBase(uint64_t pcrbase){ |
| 79 | - DDPRINTF("PCRBase = %ld\n", pcrbase); | 79 | + //DDPRINTF("PCRBase = %ld\n", pcrbase); |
| 80 | this->pcr_base = pcrbase; | 80 | this->pcr_base = pcrbase; |
| 81 | this->hasPCRBase = true; | 81 | this->hasPCRBase = true; |
| 82 | } | 82 | } |
| 83 | 83 | ||
| 84 | uint64_t ExtratorSRT::calcula_pts(double msec) { | 84 | uint64_t ExtratorSRT::calcula_pts(double msec) { |
| 85 | return (uint64_t)(pcr_base + ((msec/1000) * 100000.0)); | 85 | return (uint64_t)(pcr_base + ((msec/1000) * 100000.0)); |
| 86 | -} | ||
| 87 | \ No newline at end of file | 86 | \ No newline at end of file |
| 87 | +} |
input/src/include/inputFile.h
| @@ -9,6 +9,7 @@ | @@ -9,6 +9,7 @@ | ||
| 9 | #define INPUTFILE_H | 9 | #define INPUTFILE_H |
| 10 | 10 | ||
| 11 | #include <fstream> | 11 | #include <fstream> |
| 12 | +#include <string.h> | ||
| 12 | #include "logger.h" | 13 | #include "logger.h" |
| 13 | #include "ouvinteInput.h" | 14 | #include "ouvinteInput.h" |
| 14 | #include "inputException.h" | 15 | #include "inputException.h" |
input/src/inputFile.cpp
| @@ -20,26 +20,26 @@ InputFile::~InputFile(){ | @@ -20,26 +20,26 @@ InputFile::~InputFile(){ | ||
| 20 | 20 | ||
| 21 | void InputFile::initialize(){ | 21 | void InputFile::initialize(){ |
| 22 | ifstream filein(path, ifstream::binary); | 22 | ifstream filein(path, ifstream::binary); |
| 23 | - | ||
| 24 | - if (filein.is_open()) { | ||
| 25 | - | ||
| 26 | - char buffer [MAX_SIZE_PACKET]; | ||
| 27 | - DPRINTF("[AGUARDE] Lendo arquivo...\n") | ||
| 28 | - while (!filein.eof()) { | ||
| 29 | - filein.read(buffer, MAX_SIZE_PACKET); | ||
| 30 | - unsigned char* packet = (unsigned char*) buffer; | ||
| 31 | - notificaOuvintes(packet); | 23 | + |
| 24 | + if (strstr(path, ".ts") != NULL) { | ||
| 25 | + if (filein.is_open()) { | ||
| 26 | + char buffer [MAX_SIZE_PACKET]; | ||
| 27 | + DPRINTF("[AGUARDE] Lendo arquivo...\n") | ||
| 28 | + while (!filein.eof()) { | ||
| 29 | + filein.read(buffer, MAX_SIZE_PACKET); | ||
| 30 | + unsigned char* packet = (unsigned char*) buffer; | ||
| 31 | + notificaOuvintes(packet); | ||
| 32 | + } | ||
| 33 | + printf("\n"); | ||
| 34 | + filein.close(); | ||
| 35 | + //finished = true; | ||
| 36 | + } else { | ||
| 37 | + finished = true; | ||
| 38 | + Util::Logger::Instance()->writeLog((char*) "[ERRO: inputFile.cpp] Arquivo de vídeo não encontrado."); | ||
| 39 | + throw InputException("Falha ao abrir o arquivo de vídeo! Verifique se o mesmo existe."); | ||
| 32 | } | 40 | } |
| 33 | - | ||
| 34 | - printf("\n"); | ||
| 35 | - filein.close(); | ||
| 36 | - finished = true; | ||
| 37 | - | ||
| 38 | - } else { | ||
| 39 | - finished = true; | ||
| 40 | - Util::Logger::Instance()->writeLog((char*) "[ERRO: inputFile.cpp] Arquivo de vídeo não encontrado."); | ||
| 41 | - throw InputException("Falha ao abrir o arquivo de vídeo! Verifique se o mesmo existe."); | ||
| 42 | } | 41 | } |
| 42 | + finished = true; | ||
| 43 | 43 | ||
| 44 | } | 44 | } |
| 45 | 45 |
monitorPCR/src/include/monitor_pcr.h
| @@ -30,6 +30,13 @@ class MonitorPCR: public OuvinteInput { | @@ -30,6 +30,13 @@ class MonitorPCR: public OuvinteInput { | ||
| 30 | void notifyListenersWithPCRBase(uint64_t pcrbase); | 30 | void notifyListenersWithPCRBase(uint64_t pcrbase); |
| 31 | uint64_t getPCRBase(); | 31 | uint64_t getPCRBase(); |
| 32 | void chegouInput(unsigned char* packet); | 32 | void chegouInput(unsigned char* packet); |
| 33 | + | ||
| 34 | + /** | ||
| 35 | + * Informa para o monitor o formato do vídeo que está sendo manipulado. | ||
| 36 | + * Caso seja qualquer outro diferente de Transport Stream (TS), os componentes | ||
| 37 | + * observadores devem receber a notificação de um valor de PCR padrão. | ||
| 38 | + */ | ||
| 39 | + void setFormatVideo(char* format); | ||
| 33 | 40 | ||
| 34 | private: | 41 | private: |
| 35 | 42 |
monitorPCR/src/monitor_pcr.cpp
| 1 | #include <stdio.h> | 1 | #include <stdio.h> |
| 2 | #include <string.h> | 2 | #include <string.h> |
| 3 | +#include <locale> | ||
| 3 | #include "monitor_pcr.h" | 4 | #include "monitor_pcr.h" |
| 4 | #define PCRBASE_PADRAO 1000000 | 5 | #define PCRBASE_PADRAO 1000000 |
| 5 | using namespace std; | 6 | using namespace std; |
| @@ -17,52 +18,45 @@ MonitorPCR::~MonitorPCR(){ | @@ -17,52 +18,45 @@ MonitorPCR::~MonitorPCR(){ | ||
| 17 | DDDPRINTF("Monitor PCR finalized!\n"); | 18 | DDDPRINTF("Monitor PCR finalized!\n"); |
| 18 | } | 19 | } |
| 19 | 20 | ||
| 21 | + | ||
| 20 | uint64_t MonitorPCR::getPCRBase(){ | 22 | uint64_t MonitorPCR::getPCRBase(){ |
| 21 | return pcr_base; | 23 | return pcr_base; |
| 22 | } | 24 | } |
| 23 | 25 | ||
| 24 | -void MonitorPCR::chegouInput(unsigned char* packet) { | ||
| 25 | - | ||
| 26 | - //printf("\n\n\n\n\n\nEXTENSAOOO---2: %s\n\n\n\n\n\n", extvideo); | ||
| 27 | 26 | ||
| 28 | - if (!find) { // verifica se o PCRBase já foi encontrado | ||
| 29 | - //printf("\n>>> 2\n"); | 27 | +void MonitorPCR::setFormatVideo(char* format) { |
| 28 | + extvideo = format; | ||
| 29 | +} | ||
| 30 | 30 | ||
| 31 | - if (strcmp(extvideo, (char*) "ts") == 0) { // se for TS procura nos pacotes | ||
| 32 | - readPCRBase(packet); | ||
| 33 | - //printf("\n>>> 3\n"); | ||
| 34 | 31 | ||
| 32 | +void MonitorPCR::chegouInput(unsigned char* packet) { | ||
| 35 | 33 | ||
| 36 | - } | ||
| 37 | - else // outros formatos de vídeo, define o PCR padrão = 1000000 | 34 | + if (!find) { // verifica se o PCRBase já foi encontrado |
| 35 | + *extvideo = tolower(*extvideo); | ||
| 36 | + if (strcmp(extvideo, (char*) "ts") == 0) { // se for TS procura nos pacotes | ||
| 37 | + readPCRBase(packet); | ||
| 38 | + } else { // outros formatos de vídeo, define o PCR padrão = 1000000 | ||
| 38 | notifyListenersWithPCRBase((uint64_t) PCRBASE_PADRAO); | 39 | notifyListenersWithPCRBase((uint64_t) PCRBASE_PADRAO); |
| 39 | - } | 40 | + find = true; |
| 41 | + } | ||
| 42 | + } | ||
| 43 | + | ||
| 40 | } | 44 | } |
| 41 | 45 | ||
| 46 | + | ||
| 42 | void MonitorPCR::readPCRBase(unsigned char* packet){ | 47 | void MonitorPCR::readPCRBase(unsigned char* packet){ |
| 43 | 48 | ||
| 44 | - // printf("\n>>> 0\n"); | ||
| 45 | - | ||
| 46 | if (packet[0] == 0x47 && !find){ | 49 | if (packet[0] == 0x47 && !find){ |
| 47 | - //printf("\n>>> 1\n"); | ||
| 48 | - if((((packet[1] & 0x1F) << 8) | packet[2]) != 0xFF){ | ||
| 49 | - | ||
| 50 | - int adaptation_field_control = ((packet[3] & 0x30) >> 4); | ||
| 51 | - | ||
| 52 | - if (adaptation_field_control == 2 || adaptation_field_control == 3) { | ||
| 53 | - | ||
| 54 | - int adaptation_field_length = packet[4]; | ||
| 55 | - | ||
| 56 | - if (adaptation_field_length > 0) { | ||
| 57 | - | ||
| 58 | - if (((packet[5] & 0x10) >> 4) == 1) { | ||
| 59 | - | 50 | + if((((packet[1] & 0x1F) << 8) | packet[2]) != 0xFF) { |
| 51 | + int adaptation_field_control = ((packet[3] & 0x30) >> 4); | ||
| 52 | + if (adaptation_field_control == 2 || adaptation_field_control == 3) { | ||
| 53 | + int adaptation_field_length = packet[4]; | ||
| 54 | + if (adaptation_field_length > 0) { | ||
| 55 | + if (((packet[5] & 0x10) >> 4) == 1) { | ||
| 60 | uint64_t program_clock_reference_base = (uint64_t) packet[6] << 25 | packet[7] << 17 | packet[8] << 9 | 56 | uint64_t program_clock_reference_base = (uint64_t) packet[6] << 25 | packet[7] << 17 | packet[8] << 9 |
| 61 | - | packet[9] << 1 | (packet[10] & 0x80) >> 7; | ||
| 62 | - | 57 | + | packet[9] << 1 | (packet[10] & 0x80) >> 7; |
| 63 | notifyListenersWithPCRBase(program_clock_reference_base); | 58 | notifyListenersWithPCRBase(program_clock_reference_base); |
| 64 | - find = true; | ||
| 65 | - | 59 | + find = true; |
| 66 | } | 60 | } |
| 67 | } | 61 | } |
| 68 | } | 62 | } |
| @@ -79,4 +73,4 @@ void MonitorPCR::notifyListenersWithPCRBase(uint64_t pcrbase){ | @@ -79,4 +73,4 @@ void MonitorPCR::notifyListenersWithPCRBase(uint64_t pcrbase){ | ||
| 79 | for(list<ListenerMonitorPCRBase*>::iterator it = this->listeners->begin(); it != this->listeners->end(); it++){ | 73 | for(list<ListenerMonitorPCRBase*>::iterator it = this->listeners->begin(); it != this->listeners->end(); it++){ |
| 80 | (*it)->notifyPCRBase(pcrbase); | 74 | (*it)->notifyPCRBase(pcrbase); |
| 81 | } | 75 | } |
| 82 | -} | ||
| 83 | \ No newline at end of file | 76 | \ No newline at end of file |
| 77 | +} |
servico/src/serviceWindowGenerationFromSRT.cpp
| @@ -100,8 +100,18 @@ void ServiceWindowGenerationFromSRT::initialize() { | @@ -100,8 +100,18 @@ void ServiceWindowGenerationFromSRT::initialize() { | ||
| 100 | */ | 100 | */ |
| 101 | 101 | ||
| 102 | inputfile = new InputFile(this->path_input); | 102 | inputfile = new InputFile(this->path_input); |
| 103 | - extratorSRT = new ExtratorSRT(); | ||
| 104 | - monitor_pcr_base = new MonitorPCR(); | 103 | + extratorSRT = new ExtratorSRT(); |
| 104 | + | ||
| 105 | + monitor_pcr_base = new MonitorPCR(); | ||
| 106 | + | ||
| 107 | + /* [Temporário]: como o monitor do PCR não estava encontrando a extensão do | ||
| 108 | + vídeo, este está sendo analisado e infomado no trecho de código a seguir. | ||
| 109 | + */ | ||
| 110 | + if (strstr(path_input, "ts") != NULL) { | ||
| 111 | + char* format_video = new char[3]; | ||
| 112 | + strcpy(format_video, "ts"); | ||
| 113 | + monitor_pcr_base->setFormatVideo(format_video); | ||
| 114 | + } | ||
| 105 | 115 | ||
| 106 | monitor_pcr_base->addListenerPCRBase(extratorSRT); | 116 | monitor_pcr_base->addListenerPCRBase(extratorSRT); |
| 107 | 117 |