Переполнение текста в WPF - PullRequest
       43

Переполнение текста в WPF

1 голос
/ 04 сентября 2010

В настоящее время я пытаюсь сделать так, чтобы, когда я беру строку, она заполняла первый текстовый блок до тех пор, пока он не переполнился, а затем он должен начаться в текстовом блоке 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);

Ответы [ 2 ]

3 голосов
/ 04 сентября 2010

Обратите внимание на свойство TextWrapping , связанное с TextBlock, чтобы, возможно, сделать ваш код проще.

<StackPanel>
  <TextBlock Text="One line of text"/>
  <TextBlock Width="50" TextWrapping="WrapWithOverflow" Text="One line of text"/>
  <TextBlock Width="50" TextWrapping="Wrap" Text="One line of text"/>
</StackPanel>
1 голос
/ 04 сентября 2010

Один из способов - создать пользовательский элемент управления, в котором вы выполняете рендеринг по DrawingContext .При этом вы можете точно рассчитать размер, который будет использовать текст, и, следовательно, вычислить позицию обрезки.

С таким элементом управления вы можете определить свойство переполнения, которое возвращает для каждого элемента управления текст, который не являетсяпоказать и установить его в качестве источника контроля родного брата.

Конечно, это не простая работа, но это возможный способ.Вы также можете извлечь из TextBlock, а затем вычислить текст в логике обработки по умолчанию и добавить DP для предоставления текста переполнения.

Следующие ссылки могут быть полезны для решения вышеупомянутого:

Форматированный текст

Форматированный текст. Высота

...