C # 3D wpf visual studio 2010
У меня есть сцена, состоящая из круга, построенного из числовых треугольников, в которые я добавил сетки как сзади, так и спереди.
Появляется треугольникна мой взгляд, но стороны черные, как внутри, так и снаружи.Я добавляю материал таким образом
Material material = new DiffuseMaterial(new SolidColorBrush(Colors.Blue));
, но если я изменю материал на
Material material = new EmissiveMaterial(new SolidColorBrush(Colors.Red));
Стороны начинают светиться этим цветом.
У меня есть триисточники света
< AmbientLight Color="White" / >
< DirectionalLight x:Name="myDirectLight1" Color="White"/ >
< PointLight x:Name="myPointLight1" Color="White" Position="0,0,0"/>
Где я тоже делаю
myCamera.LookDirection = -(Vector3D)myCamera.Position; //always look to (0,0,0)
myDirectLight1.Direction = myCamera.LookDirection; //light comes from the camera
Но стороны все еще черные (если я не изменю материал на EmissiveMaterial) ???
Делайте огниесть какой-то диапазон по умолчанию, не установленный в бесконечность?
Круг большой, около 2000 единиц в диаметре,
С уважением
Добавлено
private Model3DGroup CreateTriangleModel(Point3D p0, Point3D p1, Point3D p2, Material material, Material material2)
{
MeshGeometry3D mesh = null;
GeometryModel3D model = null;
Model3DGroup group = new Model3DGroup();
//
// Front side of jagged part
//
mesh = new MeshGeometry3D();
mesh.Positions.Add(p0);
mesh.Positions.Add(p1);
mesh.Positions.Add(p2);
mesh.TriangleIndices.Add(0);
mesh.TriangleIndices.Add(1);
mesh.TriangleIndices.Add(2);
Vector3D normal = CalculateNormal(p0, p1, p2);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
//
// Front side of the surface below the jagged edge
//
Point3D p3 = new Point3D(p1.X, p1.Y, bh);
Point3D p4 = new Point3D(p2.X, p2.Y, bh);
mesh.Positions.Add(p3);
mesh.Positions.Add(p4);
mesh.TriangleIndices.Add(1);
mesh.TriangleIndices.Add(3);
mesh.TriangleIndices.Add(4);
normal = CalculateNormal(p1, p3, p4);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.TriangleIndices.Add(1);
mesh.TriangleIndices.Add(4);
mesh.TriangleIndices.Add(2);
normal = CalculateNormal(p1, p4, p2);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
model = new GeometryModel3D(mesh, material);
group.Children.Add(model);
//
// Back side of jagged part
//
mesh = new MeshGeometry3D();
mesh.Positions.Add(p0);
mesh.Positions.Add(p1);
mesh.Positions.Add(p2);
mesh.TriangleIndices.Add(0);
mesh.TriangleIndices.Add(2);
mesh.TriangleIndices.Add(1);
normal = CalculateNormal(p0, p1, p2);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
//
// Back side of the surface below the jagged edge
//
p3 = new Point3D(p1.X, p1.Y, bh);
p4 = new Point3D(p2.X, p2.Y, bh);
mesh.Positions.Add(p3);
mesh.Positions.Add(p4);
mesh.TriangleIndices.Add(1);
mesh.TriangleIndices.Add(4);
mesh.TriangleIndices.Add(3);
normal = CalculateNormal(p1, p4, p3);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.TriangleIndices.Add(1);
mesh.TriangleIndices.Add(2);
mesh.TriangleIndices.Add(4);
normal = CalculateNormal(p1, p2, p4);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
mesh.Normals.Add(normal);
model = new GeometryModel3D(mesh, material2);
group.Children.Add(model);
return group;
}
private Vector3D CalculateNormal(Point3D p0, Point3D p1, Point3D p2)
{
Vector3D v0 = new Vector3D(
p1.X - p0.X, p1.Y - p0.Y, p1.Z - p0.Z);
Vector3D v1 = new Vector3D(
p2.X - p1.X, p2.Y - p1.Y, p2.Z - p1.Z);
return Vector3D.CrossProduct(v0, v1);
}