本文整理匯總了C#中Microsoft.Xna.Framework.Content.Pipeline.Graphics.NodeContent類的典型用法代碼示例。如果您正苦於以下問題:C# NodeContent類的具體用法?C# NodeContent怎麽用?C# NodeContent使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
NodeContent類屬於Microsoft.Xna.Framework.Content.Pipeline.Graphics命名空間,在下文中一共展示了NodeContent類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: StoreEffectTechniqueInMeshName
/// <summary>
/// Stores the current selected technique and if the texture uses alpha
/// into the mesh name for each mesh part.
/// </summary>
private void StoreEffectTechniqueInMeshName(
NodeContent input, ContentProcessorContext context)
{
MeshContent mesh = input as MeshContent;
if (mesh != null)
{
foreach (GeometryContent geom in mesh.Geometry)
{
EffectMaterialContent effectMaterial = geom.Material as EffectMaterialContent;
if (effectMaterial != null)
{
if (effectMaterial.OpaqueData.ContainsKey("technique"))
{
// Store technique here! (OpaqueData["technique"] is an int32)
input.Name = input.Name + effectMaterial.OpaqueData["technique"];
} // if
} // if
} // foreach
} // if
// Go through all childs
foreach (NodeContent child in input.Children)
{
StoreEffectTechniqueInMeshName(child, context);
} // foreach
}
示例2: Process
public override ModelContent Process(NodeContent input, ContentProcessorContext context)
{
if (input == null)
{
throw new ArgumentNullException("input");
}
//we always want to generate tangent frames, as we use tangent space normal mapping
GenerateTangentFrames = true;
//merge transforms
MeshHelper.TransformScene(input, input.Transform);
input.Transform = Matrix.Identity;
if (!_isSkinned)
MergeTransforms(input);
ModelContent model = base.Process(input, context);
//gather some information that will be useful in run time
MeshMetadata metadata = new MeshMetadata();
BoundingBox aabb = new BoundingBox();
metadata.BoundingBox = ComputeBoundingBox(input, ref aabb, metadata);
//assign it to our Tag
model.Tag = metadata;
return model;
}
示例3: Process
public override ModelContent Process(NodeContent input, ContentProcessorContext context)
{
model = base.Process(input, context);
AnimationClips clips = ProcessAnimations(model, input, context);
model.Tag = clips;
return model;
}
示例4: Process
/// <summary>
/// The main Process method converts an intermediate format content pipeline
/// NodeContent tree to a ModelContent object with embedded animation data.
/// </summary>
public override ModelContent Process(NodeContent input, ContentProcessorContext context)
{
SkinningData skinningData = SkinningHelpers.GetSkinningData(input, context, SkinnedEffect.MaxBones);
ModelContent model = base.Process(input, context);
model.Tag = skinningData;
return model;
}
示例5: Import
public override TImport Import(string filename, ContentImporterContext context)
{
_context = context;
// _animfiles will contain list of new temp anim files.
_animfiles = new List<string>();
// Decouple header and animation data.
ExtractAnimations(filename);
// Process master file (this will also process the first animation)
_master = base.Import(filename, context);
// Process the remaining animations.
foreach (string file in _animfiles) {
TImport anim = base.Import(file, context);
// Append animation to master NodeContent.
AppendAnimation(_master, anim);
}
// Delete the temporary animation files.
DeleteTempFiles();
return _master;
}
示例6: Process
public override ModelContent Process(NodeContent input, ContentProcessorContext context)
{
ModelContent model = base.Process(input, context);
//results will be stored in this collection
List<Vector3> points = new List<Vector3>();
//loop throught each mesh at the center of each of its bounding spheres
foreach (ModelMeshContent mesh in model.Meshes)
{
//we will need to transform the center by the meshes parent bone atrix
//if we don't they will all be at the same position
Matrix transform;
if (mesh.ParentBone.Transform != null)
transform = mesh.ParentBone.Transform;
var p = Vector3.Transform(mesh.BoundingSphere.Center, mesh.ParentBone.Transform);
//using the property above we can make decisions
if (PreservePointHeight)
points.Add(p);
else
points.Add(new Vector3(p.X,0,p.Z));
}
//we always store the additional data in the Tag property of the object
model.Tag = points;
return model;
}
示例7: Process
/// <summary>
/// The main method in charge of processing the content.
/// </summary>
public override ModelContent Process(NodeContent input,
ContentProcessorContext context)
{
// Chain to the base ModelProcessor class.
ModelContent model = base.Process(input, context);
// Look up the input vertex positions.
FindVertices(input);
// You can store any type of object in the model Tag property. This
// sample only uses built-in types such as string, Vector3, BoundingSphere,
// dictionaries, and arrays, which the content pipeline knows how to
// serialize by default. We could also attach custom data types here, but
// then we would have to provide a ContentTypeWriter and ContentTypeReader
// implementation to tell the pipeline how to serialize our custom type.
//
// We are setting our model Tag to a dictionary that maps strings to
// objects, and then storing two different kinds of custom data into that
// dictionary. This is a useful pattern because it allows processors to
// combine many different kinds of information inside the single Tag value.
Dictionary<string, object> tagData = new Dictionary<string, object>();
model.Tag = tagData;
// Store vertex information in the tag data, as an array of Vector3.
tagData.Add("Vertices", vertices.ToArray());
// Also store a custom bounding sphere.
tagData.Add("BoundingSphere", BoundingSphere.CreateFromPoints(vertices));
return model;
}
示例8: CalculateBoundingBox
public void CalculateBoundingBox(NodeContent node)
{
MeshContent mesh = node as MeshContent;
if (mesh != null)
{
// calculating max and min points coordinates
foreach (Vector3 vertex in mesh.Positions)
{
if (vertex.X < minPoint.X) minPoint.X = vertex.X;
if (vertex.Y < minPoint.Y) minPoint.Y = vertex.Y;
if (vertex.Z < minPoint.Z) minPoint.Z = vertex.Z;
if (vertex.X > maxPoint.X) maxPoint.X = vertex.X;
if (vertex.Y > maxPoint.Y) maxPoint.Y = vertex.Y;
if (vertex.Z > maxPoint.Z) maxPoint.Z = vertex.Z;
}
}
else
{
// calling the function recursively for all the children nodes
foreach (NodeContent childNode in node.Children)
{
this.CalculateBoundingBox(childNode);
}
}
}
示例9: Process
public override ModelContent Process(NodeContent input, ContentProcessorContext context)
{
ValidateMesh(input, context, null);
BoneContent skeleton = MeshHelper.FindSkeleton(input);
if (skeleton == null)
throw new InvalidContentException("Input skeleton not found.");
//Bakes everything
FlattenTransforms(input, skeleton);
//Read bind pse and skeleton hierarchy data.
IList<BoneContent> bones = MeshHelper.FlattenSkeleton(skeleton);
if (bones.Count > SkinnedEffect.MaxBones)
{
throw new InvalidContentException(string.Format("Skeleton has {0} bones, but the max is {1}.", bones.Count, SkinnedEffect.MaxBones));
}
List<Matrix> bindPose = new List<Matrix>();
List<Matrix> inverseBindPose = new List<Matrix>();
List<int> skeletonHierarchy = new List<int>();
Dictionary<string, int> boneIndices = new Dictionary<string, int>();
foreach (BoneContent bone in bones)
{
bindPose.Add(bone.Transform);
inverseBindPose.Add(Matrix.Invert(bone.AbsoluteTransform));
skeletonHierarchy.Add(bones.IndexOf(bone.Parent as BoneContent));
boneIndices.Add(bone.Name, boneIndices.Count);
}
ModelContent model = base.Process(input, context);
model.Tag = new SkinningDataStorage(bindPose, inverseBindPose, skeletonHierarchy, boneIndices);
return model;
}
示例10: Process
public override ModelContent Process(NodeContent input,
ContentProcessorContext context)
{
// Break up the mesh to separate triangles.
NodeContent processedNode = ProcessMesh(input);
return base.Process(processedNode, context);
}
示例11: Process
/// <summary>
/// The main Process method converts an intermediate format content pipeline
/// NodeContent tree to a ModelConte nt object with embedded animation data.
/// </summary>
public override ModelContent Process(NodeContent input, ContentProcessorContext context)
{
ValidateMesh(input, context, null);
List<int> boneHierarchy = new List<int>();
// Chain to the base ModelProcessor class so it can convert the model data.
ModelContent model = base.Process(input, context);
// Add each of the bones
foreach (ModelBoneContent bone in model.Bones)
{
boneHierarchy.Add(model.Bones.IndexOf(bone.Parent as ModelBoneContent));
}
// Animation clips inside the object (mesh)
Dictionary<string, ModelAnimationClip> animationClips = new Dictionary<string, ModelAnimationClip>();
// Animation clips at the root of the object
Dictionary<string, ModelAnimationClip> rootClips = new Dictionary<string, ModelAnimationClip>();
// Process the animations
ProcessAnimations(input, model, animationClips, rootClips);
// Store the data for the model
model.Tag = new ModelData(animationClips, rootClips, null, null, boneHierarchy);
return model;
}
示例12: FindVertices
/// <summary>
/// Helper for extracting a list of all the vertex positions in a model.
/// </summary>
void FindVertices(NodeContent node)
{
// Is this node a mesh?
MeshContent mesh = node as MeshContent;
if (mesh != null)
{
// Look up the absolute transform of the mesh.
//Matrix absoluteTransform = mesh.AbsoluteTransform;
// Loop over all the pieces of geometry in the mesh.
foreach (GeometryContent geometry in mesh.Geometry)
{
// Loop over all the indices in this piece of geometry.
// Every group of three indices represents one triangle.
foreach (int index in geometry.Indices)
{
// Look up the position of this vertex.
Vector3 vertex = geometry.Vertices.Positions[index];
// Transform from local into world space.
//vertex = Vector3.Transform(vertex, absoluteTransform);
// Store this vertex.
vertices.Add(vertex);
}
}
}
// Recursively scan over the children of this node.
foreach (NodeContent child in node.Children)
{
FindVertices(child);
}
}
示例13: AddVerticesToList
private List<Triangle> AddVerticesToList(NodeContent node, List<Triangle> triangleList)
{
MeshContent mesh = node as MeshContent;
if (mesh != null)
{
Matrix abstransform = mesh.AbsoluteTransform;
foreach (GeometryContent geo in mesh.Geometry)
{
int triangles = geo.Indices.Count / 3;
for (int currentTriangle = 0; currentTriangle < triangles; ++currentTriangle)
{
int index0 = geo.Indices[currentTriangle * 3 + 0];
int index1 = geo.Indices[currentTriangle * 3 + 1];
int index2 = geo.Indices[currentTriangle * 3 + 2];
Vector3 v0 = geo.Vertices.Positions[index0];
Vector3 v1 = geo.Vertices.Positions[index1];
Vector3 v2 = geo.Vertices.Positions[index2];
Vector3 transv0 = Vector3.Transform(v0, abstransform);
Vector3 transv1 = Vector3.Transform(v1, abstransform);
Vector3 transv2 = Vector3.Transform(v2, abstransform);
Triangle newTriangle = new Triangle(transv0, transv1, transv2);
triangleList.Add(newTriangle);
}
}
}
foreach (NodeContent child in node.Children)
triangleList = AddVerticesToList(child, triangleList);
return triangleList;
}
示例14: Process
/// <summary>
/// The main Process method converts an intermediate format content pipeline
/// NodeContent tree to a ModelContent object with embedded animation data.
/// </summary>
public override ModelContent Process(NodeContent input, ContentProcessorContext context)
{
contentPath = Environment.CurrentDirectory;
using (XmlReader reader = XmlReader.Create(MaterialDataFilePath))
{
incomingMaterials = IntermediateSerializer.Deserialize<List<MaterialData>>(reader, null);
}
context.AddDependency(Path.Combine(Environment.CurrentDirectory, MaterialDataFilePath));
// Chain to the base ModelProcessor class so it can convert the model data.
ModelContent model = base.Process(input, context);
// Put the material's flags into the ModelMeshPartContent's Tag property.
foreach (ModelMeshContent mmc in model.Meshes)
{
foreach (ModelMeshPartContent mmpc in mmc.MeshParts)
{
MaterialData mat = incomingMaterials.Single(m => m.Name == mmpc.Material.Name);
MaterialInfo extraInfo = new MaterialInfo();
extraInfo.HandlingFlags = mat.HandlingFlags;
extraInfo.RenderState = mat.RenderState;
mmpc.Tag = extraInfo;
}
}
return model;
}
示例15: Process
/// <summary>
/// The main Process method converts an intermediate format content pipeline
/// NodeContent tree to a ModelContent object with embedded animation data.
/// </summary>
public override ModelContent Process(NodeContent input,
ContentProcessorContext context)
{
ValidateMesh(input, context, null);
// Find the skeleton.
BoneContent skeleton = MeshHelper.FindSkeleton(input);
if (skeleton == null)
throw new InvalidContentException("Input skeleton not found.");
// We don't want to have to worry about different parts of the model being
// in different local coordinate systems, so let's just bake everything.
FlattenTransforms(input, skeleton);
// Read the bind pose and skeleton hierarchy data.
IList<BoneContent> bones = MeshHelper.FlattenSkeleton(skeleton);
if (bones.Count > SkinnedEffect.MaxBones)
{
throw new InvalidContentException(string.Format(
"Skeleton has {0} bones, but the maximum supported is {1}.",
bones.Count, SkinnedEffect.MaxBones));
}
List<Matrix> bindPose = new List<Matrix>();
List<Matrix> inverseBindPose = new List<Matrix>();
List<int> skeletonHierarchy = new List<int>();
#region BaamStudios XnaMixamoImporter Change
List<string> boneNames = new List<string>();
#endregion
foreach (BoneContent bone in bones)
{
bindPose.Add(bone.Transform);
inverseBindPose.Add(Matrix.Invert(bone.AbsoluteTransform));
skeletonHierarchy.Add(bones.IndexOf(bone.Parent as BoneContent));
#region BaamStudios XnaMixamoImporter Change
boneNames.Add(bone.Name);
#endregion
}
// Convert animation data to our runtime format.
Dictionary<string, AnimationClip> animationClips;
animationClips = ProcessAnimations(skeleton.Animations, bones);
// Chain to the base ModelProcessor class so it can convert the model data.
ModelContent model = base.Process(input, context);
// Store our custom animation data in the Tag property of the model.
model.Tag = new SkinningData(animationClips, bindPose,
inverseBindPose, skeletonHierarchy
#region BaamStudios XnaMixamoImporter Change
, boneNames
#endregion
);
return model;
}