blob: 198bb9e293569a08152a3eb31eadc4d0a2ce4f29 (
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
106
107
108
109
110
111
|
/*
*
* $Id: k3bstringutils.cpp 619556 2007-01-03 17:38:12Z trueg $
* Copyright (C) 2003 Sebastian Trueg <trueg@k3b.org>
*
* This file is part of the K3b project.
* Copyright (C) 1998-2007 Sebastian Trueg <trueg@k3b.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.
* See the file "COPYING" for the exact licensing terms.
*/
#include "k3bstringutils.h"
#include <qfontmetrics.h>
#include <kdebug.h>
QString K3b::cutToWidth( const QFontMetrics& fm, const QString& fullText, int cutWidth )
{
QString squeezedText = "...";
int squeezedWidth = fm.width(squeezedText);
int textWidth = fm.width(fullText);
if( textWidth <= cutWidth ) {
return fullText;
}
if( fm.width(fullText.right(1) + "..." ) > cutWidth ) {
kdDebug() << "(K3b::cutToWidth) not able to cut text to " << cutWidth << "!" << endl;
return fullText.right(1) + "...";
}
// estimate how many letters we can add to the dots
int letters = fullText.length() * (cutWidth - squeezedWidth) / textWidth;
squeezedText = fullText.left(letters) + "...";
squeezedWidth = fm.width(squeezedText);
if (squeezedWidth < cutWidth) {
// we estimated too short
// add letters while text < label
do {
letters++;
squeezedText = fullText.left(letters) + "...";
squeezedWidth = fm.width(squeezedText);
} while (squeezedWidth < cutWidth);
letters--;
squeezedText = fullText.left(letters) + "...";
} else if (squeezedWidth > cutWidth) {
// we estimated too long
// remove letters while text > label
do {
letters--;
squeezedText = fullText.left(letters) + "...";
squeezedWidth = fm.width(squeezedText);
} while (squeezedWidth > cutWidth);
}
return squeezedText;
}
// from KSqueezedTextLabel
QString K3b::squeezeTextToWidth( const QFontMetrics& fm, const QString& fullText, int cutWidth )
{
int textWidth = fm.width(fullText);
if (textWidth > cutWidth) {
// start with the dots only
QString squeezedText = "...";
int squeezedWidth = fm.width(squeezedText);
// estimate how many letters we can add to the dots on both sides
int letters = fullText.length() * (cutWidth - squeezedWidth) / textWidth / 2;
if (cutWidth < squeezedWidth) letters=1;
squeezedText = fullText.left(letters) + "..." + fullText.right(letters);
squeezedWidth = fm.width(squeezedText);
if (squeezedWidth < cutWidth) {
// we estimated too short
// add letters while text < label
do {
letters++;
squeezedText = fullText.left(letters) + "..." + fullText.right(letters);
squeezedWidth = fm.width(squeezedText);
} while (squeezedWidth < cutWidth);
letters--;
squeezedText = fullText.left(letters) + "..." + fullText.right(letters);
}
else if (squeezedWidth > cutWidth) {
// we estimated too long
// remove letters while text > label
do {
letters--;
squeezedText = fullText.left(letters) + "..." + fullText.right(letters);
squeezedWidth = fm.width(squeezedText);
} while (letters > 2 && squeezedWidth > cutWidth);
}
if (letters == 2)
kdDebug() << "(K3b::squeezeTextToWidth) WARNING: unable to squeeze text to width "
<< cutWidth << endl;
return squeezedText;
}
else
return fullText;
}
|