我有一个按钮,我想要在其中添加一些文本,但某些文本可能太长,无法很好地放入按钮中。我想让文本在一行中水平滚动,就像 HTML 中的选取框一样。我可以让它滚动一行,但是,测试文本在按钮边缘被切断,并且那里的文本实际上会移出按钮,而不是在按钮边缘消失。
我已经用谷歌搜索了我的问题的答案,几个小时后,我认为是时候问我的问题了。
<Grid HeightRequest="400" Grid.Column="0" Grid.Row="0" >
<Grid.RowDefinitions>
<RowDefinition Height="*"/>
<RowDefinition Height="*"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<Button BackgroundColor="#006633" Opacity="0.7" Grid.RowSpan="3" Grid.ColumnSpan="1">
</Button>
<Label x:Name="Label1" StyleClass="button" Grid.Row="1" Grid.Column="0" >
</Label>
</Grid>
public void Marque1()
{
Label1.Text = "This is to simulate a really long sentence for testing purposes";
Label1.HorizontalOptions = LayoutOptions.Start;
Label1.VerticalTextAlignment = TextAlignment.Center;
Label1.LineBreakMode = LineBreakMode.NoWrap;
Label1.TranslateTo(-50, 0, 8000, Easing.Linear);
}
我希望整个文本从右向左移动并重复,并且不离开按钮的边界。
你可以检查一下,是不是你需要的效果:
public partial class MaqueText : ContentPage
{
private bool Execute { get; set; }
public MaqueText ()
{
InitializeComponent ();
Label1.Text = "This is to simulate a really long sentence for testing purposes";
Label1.HorizontalOptions = LayoutOptions.Start;
Label1.VerticalTextAlignment = TextAlignment.Center;
Label1.LineBreakMode = LineBreakMode.NoWrap;
}
protected override void OnAppearing()
{
base.OnAppearing();
Execute = true;
Device.StartTimer(TimeSpan.FromMilliseconds(50), () =>
{
Label1.TranslationX -= 5f;
if (Math.Abs(Label1.TranslationX) > Width)
{
Label1.TranslationX = Label1.Width;
}
return Execute;
});
}
protected override void OnDisappearing()
{
base.OnDisappearing();
Execute = false;
}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)