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 |