C # 3D wpf черные сетки - PullRequest
       7

C # 3D wpf черные сетки

0 голосов
/ 02 сентября 2011

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);
    }

1 Ответ

0 голосов
/ 05 сентября 2011

Ошибка была в том, что мои источники света были определены в коде XAML, но я случайно удалил их в исходном коде, что привело к странному результату, когда объекты были "видимы" но все в черном цвете, независимо от материала

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...