本文整理汇总了C#中Dynamo.Nodes.List.Cast方法的典型用法代码示例。如果您正苦于以下问题:C# List.Cast方法的具体用法?C# List.Cast怎么用?C# List.Cast使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Dynamo.Nodes.List
的用法示例。
在下文中一共展示了List.Cast方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: AggregateUpstreamRenderPackages
/// <summary>
/// Aggregates all upstream geometry for the given node then sends
/// a message that a visualization is ready
/// </summary>
/// <param name="node">The node whose upstream geometry you need.</param>
/// <returns>A render description containing all upstream geometry.</returns>
public void AggregateUpstreamRenderPackages(RenderTag tag)
{
var packages = new List<IRenderPackage>();
//send back just what the node needs
var watch = new Stopwatch();
watch.Start();
if (tag.Node == null)
{
//send back everything
List<NodeModel> copyOfNodesList = controller.DynamoModel.Nodes;
foreach (var modelNode in copyOfNodesList)
{
lock (modelNode.RenderPackagesMutex)
{
packages.AddRange(modelNode.RenderPackages);
}
}
watch.Stop();
Debug.WriteLine(String.Format("RENDER: {0} ellapsed for aggregating geometry for background preview.", watch.Elapsed));
if (packages.Any())
{
// if there are packages, send any that aren't empty
OnResultsReadyToVisualize(this,
new VisualizationEventArgs(
packages.Where(x => ((RenderPackage)x).IsNotEmpty()).Cast<RenderPackage>(), string.Empty, tag.TaskId));
}
else
{
// if there are no packages, still trigger an update
// so the view gets redrawn
OnResultsReadyToVisualize(this,
new VisualizationEventArgs(packages.Cast<RenderPackage>(), string.Empty, tag.TaskId));
}
}
else
{
watch.Stop();
Debug.WriteLine(String.Format("RENDER: {0} ellapsed for aggregating geometry for branch {1}.", watch.Elapsed, tag.Node.GUID));
//send back renderables for the branch
packages = GetUpstreamPackages(tag.Node.Inputs, 0).ToList();
if (packages.Any())
OnResultsReadyToVisualize(this, new VisualizationEventArgs(packages.Where(x => ((RenderPackage)x).IsNotEmpty()).Cast<RenderPackage>(), tag.Node.GUID.ToString(),tag.TaskId));
}
//LogVisualizationUpdateData(rd, watch.Elapsed.ToString());
}