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
|
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qmultimediautils_p.h"
#include "qvideoframe.h"
#include <QtCore/qdir.h>
QT_BEGIN_NAMESPACE
Fraction qRealToFraction(qreal value)
{
int integral = int(floor(value));
value -= qreal(integral);
if (value == 0.)
return {integral, 1};
const int dMax = 1000;
int n1 = 0, d1 = 1, n2 = 1, d2 = 1;
qreal mid = 0.;
while (d1 <= dMax && d2 <= dMax) {
mid = qreal(n1 + n2) / (d1 + d2);
if (qAbs(value - mid) < 0.000001) {
break;
} else if (value > mid) {
n1 = n1 + n2;
d1 = d1 + d2;
} else {
n2 = n1 + n2;
d2 = d1 + d2;
}
}
if (d1 + d2 <= dMax)
return {n1 + n2 + integral * (d1 + d2), d1 + d2};
else if (d2 < d1)
return { n2 + integral * d2, d2 };
else
return { n1 + integral * d1, d1 };
}
QSize qCalculateFrameSize(QSize resolution, Fraction par)
{
if (par.numerator == par.denominator || par.numerator < 1 || par.denominator < 1)
return resolution;
if (par.numerator > par.denominator)
return { resolution.width() * par.numerator / par.denominator, resolution.height() };
return { resolution.width(), resolution.height() * par.denominator / par.numerator };
}
QSize qRotatedFrameSize(QSize size, int rotation)
{
Q_ASSERT(rotation % 90 == 0);
return rotation % 180 ? size.transposed() : size;
}
QSize qRotatedFrameSize(const QVideoFrame &frame)
{
return qRotatedFrameSize(frame.size(), frame.rotationAngle());
}
QUrl qMediaFromUserInput(QUrl url)
{
return QUrl::fromUserInput(url.toString(), QDir::currentPath(), QUrl::AssumeLocalFile);
}
QT_END_NAMESPACE
|