我有一个带有几个PivotItem的Pivot,其中一个包含一个画布,将其项目放在动态位置(取决于数据)。我得到了数据,我可以在用户可以选择此项之前将项目放在它们的位置(这不是第一个支点)。但是,只有当我选择PivotItem时,画布才会呈现自己,所以你可以在它显示之前看到它闪烁。
有没有办法强制画布在显示之前渲染,所以一切都是在用户看到之前准备的?
我的代码看起来像这样:
在page.xaml.cs中:
private async void GameCenterView_OnDataContextChanged(object sender, EventArgs e)
{
// Load data...
// Handle other pivots
// This is the problem pivot
if (ViewModel.CurrentGame.SportTypeId == 1)
{
_hasLineups = ViewModel.CurrentGame.HasLineups.GetValueOrDefault();
HasFieldPositions = ViewModel.CurrentGame.HasFieldPositions.GetValueOrDefault();
// I only add the pivot when I need it, otherwise, it won't be shown
if (_hasLineups)
{
if (MainPivot.Items != null) MainPivot.Items.Add(LineupPivotItem);
}
if (HasFieldPositions)
{
// Here I place all the items in their proper place on the canvas
ArrangeLineup(ViewModel.TeamOneLineup, TeamOneCanvas);
ArrangeLineup(ViewModel.TeamTwoLineup, TeamTwoCanvas);
}
}
// Handle other pivots
}
private void ArrangeLineup(ObservableCollection<PlayerInLineupViewModel> teamLineup, RationalCanvas canvas)
{
if (teamLineup == null)
return;
foreach (var player in teamLineup)
{
var control = new ContentControl
{
Content = player,
ContentTemplate = LinupPlayerInFieldDataTemplate
};
control.SetValue(RationalCanvas.RationalTopProperty, player.Player.FieldPositionLine);
control.SetValue(RationalCanvas.RationalLeftProperty, player.Player.FieldPositionSide);
canvas.Children.Add(control);
}
}
画布不是库存画布。我创建了一个新的画布,根据它们的相对位置显示项目(我得到的位置是0-99)。
逻辑发生在OverrideArrange方法中:
protected override Size ArrangeOverride(Size finalSize)
{
if (finalSize.Height == 0 || finalSize.Width == 0)
{
return base.ArrangeOverride(finalSize);
}
var yRatio = finalSize.Height/100.0;
var xRatio = finalSize.Width/100.0;
foreach (var child in Children)
{
var top = (double) child.GetValue(TopProperty);
var left = (double) child.GetValue(LeftProperty);
if (top > 0 || left > 0)
continue;
var rationalTop = (int) child.GetValue(RationalTopProperty);
var rationalLeft = (int) child.GetValue(RationalLeftProperty);
if (InvertY)
rationalTop = 100 - rationalTop;
if (InvertX)
rationalLeft = 100 - rationalLeft;
child.SetValue(TopProperty, rationalTop*yRatio);
child.SetValue(LeftProperty, rationalLeft*xRatio);
}
return base.ArrangeOverride(finalSize);
}
感谢。
答案 0 :(得分:4)
你可以尝试一些技巧。例如:
ArrangeOverride
中,如果自上次执行以来尺寸没有发生变化(且数据相同),您可以将逻辑短路。Pivot
上告诉您准备好演示的活动 - 例如PivotItemLoading
Pivot
的一部分,而是在父容器中(例如Grid
)并使其Opacity
为零。然后在目标PivotItem
进入视图时将其设置为100。