예제 #1
0
        public void ColorRGBD_Accessor()
        {
            double r = (double)NextComponent(1.0);
            double g = (double)NextComponent(1.0);
            double b = (double)NextComponent(1.0);

            ColorRGBD v = new ColorRGBD(r, g, b);
            float     c;

            Assert.DoesNotThrow(() => c = v[0]);
            Assert.DoesNotThrow(() => c = v[1]);
            Assert.DoesNotThrow(() => c = v[2]);
            Assert.Throws <IndexOutOfRangeException>(() => c = v[+3]);
            Assert.Throws <IndexOutOfRangeException>(() => c = v[-1]);

            Assert.DoesNotThrow(() => v[0] = 1.0f);
            Assert.DoesNotThrow(() => v[1] = 1.0f);
            Assert.DoesNotThrow(() => v[2] = 1.0f);
            Assert.Throws <IndexOutOfRangeException>(() => v[+3] = 0.0f);
            Assert.Throws <IndexOutOfRangeException>(() => v[-1] = 0.0f);

            Assert.DoesNotThrow(() => v[2] = 0.0f);
            Assert.DoesNotThrow(() => v[2] = 1.0f);
            Assert.Throws <InvalidOperationException>(() => v[2] = -1.0f);
            Assert.Throws <InvalidOperationException>(() => v[2] = +1.1f);
        }
예제 #2
0
        public void ColorRGBD_CastFromColor()
        {
            const double Epsilon = 0.25;

            Random random = new Random();
            double r      = NextComponent(random, 1.0);
            double g      = NextComponent(random, 1.0);
            double b      = NextComponent(random, 1.0);

            Color c = Color.FromArgb(byte.MaxValue, (int)(r * byte.MaxValue), (int)(g * byte.MaxValue), (int)(b * byte.MaxValue));

            ColorRGBD v = (ColorRGBD)c;

            Assert.AreEqual((float)r, v[0], Epsilon);
            Assert.AreEqual((float)g, v[1], Epsilon);
            Assert.AreEqual((float)b, v[2], Epsilon);

            // Not influenced by alpha
            c = Color.FromArgb(0, (int)(r * byte.MaxValue), (int)(g * byte.MaxValue), (int)(b * byte.MaxValue));
            v = (ColorRGBD)c;

            Assert.AreEqual((float)r, v[0], Epsilon);
            Assert.AreEqual((float)g, v[1], Epsilon);
            Assert.AreEqual((float)b, v[2], Epsilon);
        }
예제 #3
0
        public void ColorRGBD_PixelType()
        {
            double r = (double)NextComponent(1.0);
            double g = (double)NextComponent(1.0);
            double b = (double)NextComponent(1.0);

            ColorRGBD v = new ColorRGBD(r, g, b);

            Assert.AreNotEqual(PixelLayout.None, v.PixelType);
        }
예제 #4
0
        public void ColorRGBD_TestConstructor1()
        {
            double r = (double)1.0;
            double g = (double)1.0;
            double b = (double)1.0;

            ColorRGBD v = new ColorRGBD(r, g, b);

            Assert.AreEqual(r, v.Red);
            Assert.AreEqual(g, v.Green);
            Assert.AreEqual(b, v.Blue);
        }
예제 #5
0
        public void ColorRGBD_CastToVertex4()
        {
            double r = (double)NextComponent(1.0);
            double g = (double)NextComponent(1.0);
            double b = (double)NextComponent(1.0);

            ColorRGBD v      = new ColorRGBD(r, g, b);
            Vertex3d  vArray = v;

            Assert.AreEqual(r, vArray.x);
            Assert.AreEqual(g, vArray.y);
            Assert.AreEqual(b, vArray.z);
        }
예제 #6
0
        public void ColorRGBD_CastToArray()
        {
            double r = (double)NextComponent(1.0);
            double g = (double)NextComponent(1.0);
            double b = (double)NextComponent(1.0);

            ColorRGBD v = new ColorRGBD(r, g, b);

            double[] vArray = v;

            Assert.AreEqual(3, vArray.Length);
            Assert.AreEqual(r, vArray[0]);
            Assert.AreEqual(g, vArray[1]);
            Assert.AreEqual(b, vArray[2]);
        }