В настоящее время я пытаюсь сделать так, чтобы, когда я беру строку, она заполняла первый текстовый блок до тех пор, пока он не переполнился, а затем он должен начаться в текстовом блоке 2. В настоящее время у меня это там, где строка разрезается на две части. кусочки в последнем конце последнего слова, прежде чем оно достигнет того, что, я думаю, будет максимальным количеством символов, которые могут поместиться в один из текстовых блоков, а вторая половина - в 2, но проблема, с которой я сталкиваюсь, заключается в том, что на самом деле никогда не удается понять где обрезать текст, так как при его переносе оставшиеся пробелы занимают разные размеры. Таким образом, у меня остался текстовый блок 1, в конце которого есть какой-то обрезанный текст, и создается впечатление, что между ними отсутствуют некоторые слова. Есть ли способ программно найти переполнение для текстового блока?
ps - текстовые блоки создаются во время выполнения в C # вместо разметки wpf.
Это то, что я делаю. Я беру myDescription и пытаюсь вписать его в myDesc [0], а затем [2] в зависимости от приблизительных размеров. Проблема в том, что если я предполагаю, что порог размера слишком велик, он оставляет myDesc [0] со словом ... или обрезанным словом, а если я приближаю его к слишком маленькому значению, у него возникают огромные неловкие пробелы. Там нет ни одного номера, который я бы обрезал, которого бы тоже не было.
TextBlock[] myDesc = new TextBlock[2];
string myDescription = infoLoader.games[gameID].description[currentLanguage];
string[] myWords = myDescription.Split(' ');
string firstPart = "";
string secondPart = "";
int currentWord = 0;
// New and improved way
int currentLine = 0;
int charsInLine = 0;
while (currentWord < myWords.Length)
{
// Determine the size of the word based on the number of characters and size of certain characters in it.
int myWLength = myWords[currentWord].Length;
int iCount = 0;
for (int i = 0; i < myWords[currentWord].Length; i++)
{
if (myWords[currentWord][i] == 'm' || myWords[currentWord][i] == 'M')
{
Console.Write("M or m. ");
myWLength++;
}
else if (myWords[currentWord][i] == 'i' || myWords[currentWord][i] == 'l' || myWords[currentWord][i] == 'I' || myWords[currentWord][i] == 'j' || myWords[currentWord][i] == 'í' || myWords[currentWord][i] == 't')
{
iCount++;
}
}
iCount = (iCount / 2);
myWLength -= iCount;
if (myWords[currentWord] == "SKIP")
{
firstPart += "\n";
currentLine++;
currentWord++;
}
else if (currentLine < 4)
{
// firstPart.
if (charsInLine + myWLength < 20)
{
// Add It.
firstPart += myWords[currentWord];
firstPart += " ";
charsInLine += myWLength;
charsInLine += 1;
currentWord++;
}
else
{
// New Line.
//firstPart += " " + currentLine + " ";
firstPart += "\n";
charsInLine = 0;
currentLine++;
}
} else if (currentLine < 6)
{
if (charsInLine + myWLength < 21)
{
// Add It.
firstPart += myWords[currentWord];
firstPart += " ";
charsInLine += myWLength;
charsInLine += 1;
currentWord++;
}
else
{
// New Line.
//firstPart += "\n";
charsInLine = 0;
currentLine++;
}
}
else
{
// secondPart.
secondPart += myWords[currentWord];
secondPart += " ";
currentWord++;
}
}
myDesc[0] = new TextBlock();
myDesc[0].Text = firstPart;
myDesc[0].TextWrapping = TextWrapping.Wrap;
myDesc[0].TextTrimming = TextTrimming.CharacterEllipsis;
myDesc[0].Background = descBGBrush;
myDesc[0].FontFamily = new FontFamily("Arial");
myDesc[0].FontSize = 12.0;
myDesc[0].Width = 118;
myDesc[0].Height = 83;
Canvas.SetLeft(myDesc[0], 132);
Canvas.SetTop(myDesc[0], 31);
myDesc[1] = new TextBlock();
myDesc[1].Text = secondPart;
myDesc[1].TextWrapping = TextWrapping.Wrap;
myDesc[1].Background = descBGBrush;
myDesc[1].FontSize = 12.0;
myDesc[1].FontFamily = new FontFamily("Arial");
myDesc[1].Width = 236;
myDesc[1].Height = 43;
Canvas.SetLeft(myDesc[1], 16);
Canvas.SetTop(myDesc[1], 115);