Попробуйте это:
CharSequence[] charArray = {"a","b","c"};
for (int i = 0; i < charArray.length; i++){
String str = charArray.toString().join("", charArray[i]);
System.out.print(str);
}
Хорошо, я нашел решение, которое работает в моем случае, но может не сработать для всех, кто хочет что-то подобное. Это беспорядочно, но работает.
Я не собираюсь принимать свой ответ в течение нескольких дней, на всякий случай, если у кого-то есть лучший способ сделать это.
Итак, во-первых, XAML:
<Window x:Class="WpfApplication1.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Window1"
Height="500"
Width="600">
<DockPanel LastChildFill="True">
<RichTextBox x:Name="rtb"
FontFamily="Courier New"
FontSize="14"
PreviewKeyDown="rtb_PreviewKeyDown">
<FlowDocument>
<Paragraph>
<InlineUIContainer Unloaded="InlineUIContainer_Unloaded">
<TextBlock FontFamily="Courier New" FontSize="14">This line of text is not editable.</TextBlock>
</InlineUIContainer>
<Run Foreground="Blue">But this is editable.</Run>
</Paragraph>
</FlowDocument>
</RichTextBox>
</DockPanel>
</Window>
И код, стоящий за:
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
namespace WpfApplication1
{
public partial class Window1 : Window
{
public Window1()
{
InitializeComponent();
}
private void InlineUIContainer_Unloaded(object sender, RoutedEventArgs e)
{
(sender as InlineUIContainer).Unloaded -= new RoutedEventHandler(InlineUIContainer_Unloaded);
TextBlock tb = new TextBlock();
tb.FontFamily = new FontFamily("Courier New");
tb.FontSize = 14;
tb.Text = "This line of text is not editable.";
TextPointer tp = rtb.CaretPosition.GetInsertionPosition(LogicalDirection.Forward);
InlineUIContainer iuic = new InlineUIContainer(tb, tp);
iuic.Unloaded += new RoutedEventHandler(InlineUIContainer_Unloaded);
}
private void rtb_PreviewKeyDown(object sender, KeyEventArgs e)
{
if (e.Key == Key.Enter)
{
var newPointer = rtb.Selection.Start.InsertLineBreak();
rtb.Selection.Select(newPointer, newPointer);
e.Handled = true;
}
}
}
}
Мое решение основано на том факте, что при удалении InlineUIContainer
из пользовательского интерфейса вызывается метод Unloaded ()
. В этот момент я просто повторно вставляю удаленный InlineUIContainer
в текущую позицию курсора.
Как и в любом другом взломе, здесь есть ряд недостатков. Я обнаружил следующие недостатки:
InlineUIContainer
. Это небольшое ограничение для этого решения. InlineUIContainer.Unloaded ()
продолжает срабатывать каждый раз при нажатии клавиши Enter. Не весело, но в моем случае это работает. Это не лучшее решение, но я думаю, что оно сработает для меня. Как я уже сказал, я пока не собираюсь отмечать это как ответ на свой вопрос - надеюсь, кто-то другой сможет сделать это лучше.
но в моем случае это работает.Это не лучшее решение, но я думаю, что оно сработает для меня. Как я уже сказал, я пока не собираюсь отмечать это как ответ на свой вопрос - надеюсь, кто-то другой сможет сделать это лучше.
но в моем случае это работает.Это не лучшее решение, но я думаю, что оно сработает для меня. Как я уже сказал, я пока не собираюсь отмечать это как ответ на свой вопрос - надеюсь, кто-то другой сможет сделать это лучше.