本文整理汇总了C#中ScriptCoreLib.SelectMany方法的典型用法代码示例。如果您正苦于以下问题:C# ScriptCoreLib.SelectMany方法的具体用法?C# ScriptCoreLib.SelectMany怎么用?C# ScriptCoreLib.SelectMany使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ScriptCoreLib
的用法示例。
在下文中一共展示了ScriptCoreLib.SelectMany方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: InvokeTest
public static void InvokeTest(Action<string> WriteLine)
{
var Enumerable_Range_1_2 = new[] { 1, 2 }.AsEnumerable();
var Enumerable_Range_3_2 = new[] { 3, 4 }.AsEnumerable();
foreach (var item in
Enumerable_Range_1_2
.SelectMany(
x =>
{
WriteLine("SelectMany " + new { x });
return Enumerable_Range_3_2.Select(
y =>
{
WriteLine("Select " + new { x, y });
return new { x, y };
}
);
}
)
// jsc should call it automatically to allow arrays
.AsEnumerable()
)
{
WriteLine(item.ToString());
}
}
示例2: Application
//.........这里部分代码省略.........
x.style.height = "96px";
}
),
Message = "Face Value by mshariful"
}
);
add(
new NotificationLayout
{
// keep attributes around?
// like we do with XElement sync?
Icon = new HTML.Images.FromAssets._371_28122014_2045510F2F7974319A9F7E9F4B39DF07().With(
x =>
{
x.style.width = "96px";
x.style.height = "96px";
}
),
Message = "Mind Wall. by Sumit Goski"
}
);
#region lines
{
var geometry = new THREE.Geometry
{
// how can we keep streaming verticies data points to gpu?
vertices =
others.SelectMany(
lineTo =>
new[]
{
new THREE.Vector3(200, 0, 0),
lineTo.sprite.position
}
).ToArray()
// https://github.com/mrdoob/three.js/wiki/Updates
// http://stackoverflow.com/questions/17842521/adding-geometry-to-a-three-js-mesh-after-render
//verticesNeedUpdate = true
};
Native.window.onframe += delegate { geometry.verticesNeedUpdate = true; };
var o = new THREE.Line(geometry, new THREE.LineDashedMaterial(
new { color = 0x00aaff, dashSize = 1, gapSize = 0.5, linewidth = 1 }
), THREE.LineStrip);
//objects.Add(o);
scene.add(o);
}
#endregion
// // DK2
// hResolution: 1920,
//vResolution: 1080,
var renderer = new THREE.WebGLRenderer();
renderer.setSize(1920, 1080);
示例3: hilbert3D
// var points = hilbert3D( new THREE.Vector3( 0,0,0 ), 25.0, recursion, 0, 1, 2, 3, 4, 5, 6, 7 );
static THREE.Vector3[] hilbert3D(
THREE.Vector3 center,
double size = 25.0,
int iterations = 1,
int v0 = 0,
int v1 = 1,
int v2 = 2,
int v3 = 3,
int v4 = 4,
int v5 = 5,
int v6 = 6,
int v7 = 7)
{
// 0:71ms {{ i = 0, x = -18.75, y = 18.75, z = -18.75 }}
// Default Vars
var half = size / 2;
var vec_s = new[] {
new THREE.Vector3(center.x - half, center.y + half, center.z - half),
new THREE.Vector3(center.x - half, center.y + half, center.z + half),
new THREE.Vector3(center.x - half, center.y - half, center.z + half),
new THREE.Vector3(center.x - half, center.y - half, center.z - half),
new THREE.Vector3(center.x + half, center.y - half, center.z - half),
new THREE.Vector3(center.x + half, center.y - half, center.z + half),
new THREE.Vector3(center.x + half, center.y + half, center.z + half),
new THREE.Vector3(center.x + half, center.y + half, center.z - half)
};
var vec = new[] {
vec_s[v0],
vec_s[v1],
vec_s[v2],
vec_s[v3],
vec_s[v4],
vec_s[v5],
vec_s[v6],
vec_s[v7]
};
// Recurse iterations
//if (--iterations >= 0)
if (iterations > 0)
{
iterations--;
var tmp = new[] {
hilbert3D(vec[0], half, iterations, v0, v3, v4, v7, v6, v5, v2, v1),
hilbert3D(vec[1], half, iterations, v0, v7, v6, v1, v2, v5, v4, v3),
hilbert3D(vec[2], half, iterations, v0, v7, v6, v1, v2, v5, v4, v3),
hilbert3D(vec[3], half, iterations, v2, v3, v0, v1, v6, v7, v4, v5),
hilbert3D(vec[4], half, iterations, v2, v3, v0, v1, v6, v7, v4, v5),
hilbert3D(vec[5], half, iterations, v4, v3, v2, v5, v6, v1, v0, v7),
hilbert3D(vec[6], half, iterations, v4, v3, v2, v5, v6, v1, v0, v7),
hilbert3D(vec[7], half, iterations, v6, v5, v2, v1, v0, v3, v4, v7)
};
// Return recursive call
return tmp.SelectMany(x => x).ToArray();
}
// Return complete Hilbert Curve.
return vec;
}