summaryrefslogtreecommitdiffstats
path: root/kopete/protocols/msn/webcam/mimicwrapper.cpp
blob: 75eb52cfac4293c57531ce49738c0d7efc2114a4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/*
    Copyright (c) 2005 by Olivier Goffart        <ogoffart@ kde.org>

    *************************************************************************
    *                                                                       *
    * This program is free software; you can redistribute it and/or modify  *
    * it under the terms of the GNU General Public License as published by  *
    * the Free Software Foundation; either version 2 of the License, or     *
    * (at your option) any later version.                                   *
    *                                                                       *
    *************************************************************************
*/


#include "mimicwrapper.h"

#include "libmimic/mimic.h"

//#include <tqbytearray.h>
#include <kdebug.h>
#include <tqimage.h>

MimicWrapper::MimicWrapper()  : m_init(false)
{
	m_mimctx=mimic_open();
}

MimicWrapper::~MimicWrapper()
{
	mimic_close(m_mimctx);
}


TQPixmap MimicWrapper::decode(const TQByteArray& data)
{
	if(!m_init)
	{
		if(!mimic_decoder_init(m_mimctx, (guchar*)(data.data())))
		{
			kdWarning(14140) << k_funcinfo << "Impossible to init decoder" << endl;
			return TQPixmap();
		}
		if (!mimic_get_property( m_mimctx, "buffer_size", &m_bufferSize) )
		{
			kdWarning(14140) << k_funcinfo << "Impossible to get buffer size" << endl;
			return TQPixmap();
		}
		m_init=true;
	}
	
	TQByteArray buff(m_bufferSize);
	if(!mimic_decode_frame(m_mimctx, (guchar*)(data.data()) , (guchar*)(buff.data()) ) )
	{
		kdWarning(14140) << k_funcinfo << "Impossible to decode frame" << endl;
		return TQPixmap();
	}
	int width,height;
	mimic_get_property(m_mimctx, "width", &width);
	mimic_get_property(m_mimctx, "height", &height);
	
	
	TQByteArray buff2(m_bufferSize*4/3);
	uint b2=0;
	for(uint f=0;f<m_bufferSize;f+=3)
	{
		buff2[b2+0]=buff[f+2];
		buff2[b2+1]=buff[f+1];
		buff2[b2+2]=buff[f+0];
		buff2[b2+3]=0x00;
		b2+=4;
	}

	TQImage img( (uchar*)(buff2.data())   , width , height ,  32  , 0L , 0,  TQImage::BigEndian  );
	return TQPixmap(img);
}

TQByteArray MimicWrapper::encode(const TQByteArray& data)
{
	if(!m_init)
	{
		if(!mimic_encoder_init(m_mimctx, MIMIC_RES_HIGH))
		{
			kdWarning(14140) << k_funcinfo << "Impossible to init encoder" << endl;
			return TQByteArray();
		}
		if (!mimic_get_property( m_mimctx, "buffer_size", &m_bufferSize) )
		{
			kdWarning(14140) << k_funcinfo << "Impossible to get buffer size" << endl;
			return TQByteArray();
		}
		m_init=true;
		m_numFrames=0;
	}
	
	TQByteArray buff(m_bufferSize);
	int buff_new_size;
	if(!mimic_encode_frame(m_mimctx, (guchar*)(data.data()) , (guchar*)(buff.data()) , (gint*)(&buff_new_size) ,  m_numFrames%15==0  ) )
	{
		kdWarning(14140) << k_funcinfo << "Impossible to decode frame" << endl;
		return TQByteArray();
	}
	buff.resize(buff_new_size);
	++m_numFrames;
	return buff;
}