我想从Kinect的视频输入中绘制一个带有纹理的简单2D四边形,但我的代码无效。
这是我的ColorFrameReady事件:
void Sensor_ColorFrameReady(object sender, ColorImageFrameReadyEventArgs e)
{
ColorImageFrame cif = e.OpenColorImageFrame();
if (cif != null)
{
middleBitmapSource = cif.ToBitmapSource();
cif.Dispose();
}
}
这是我的OpenGL绘制方法:
private void OpenGLControl_OpenGLDraw(object sender, OpenGLEventArgs args)
{
// Get the OpenGL instance being pushed to us.
gl = args.OpenGL;
// Clear the colour and depth buffers.
gl.Clear(OpenGL.GL_COLOR_BUFFER_BIT | OpenGL.GL_DEPTH_BUFFER_BIT);
// Enable textures
gl.Enable(OpenGL.GL_TEXTURE_2D);
// Reset the modelview matrix.
gl.LoadIdentity();
// Load textures
if (middleBitmapSource != null)
{
middleBitmap = getBitmap(middleBitmapSource, quadMiddleWidth, quadMiddleHeight);
//middleBitmap = new System.Drawing.Bitmap("C:\\Users\\Bobble\\Pictures\\Crate.bmp"); // When I use this texture, it works fine
gl.GenTextures(1, textures);
gl.BindTexture(OpenGL.GL_TEXTURE_2D, textures[0]);
gl.TexImage2D(OpenGL.GL_TEXTURE_2D, 0, 3, middleBitmap.Width, middleBitmap.Height, 0, OpenGL.GL_BGR, OpenGL.GL_UNSIGNED_BYTE,
middleBitmap.LockBits(new System.Drawing.Rectangle(0, 0, middleBitmap.Width, middleBitmap.Height),
System.Drawing.Imaging.ImageLockMode.ReadOnly, System.Drawing.Imaging.PixelFormat.Format24bppRgb).Scan0);
gl.TexParameter(OpenGL.GL_TEXTURE_2D, OpenGL.GL_TEXTURE_MIN_FILTER, OpenGL.GL_LINEAR);
gl.TexParameter(OpenGL.GL_TEXTURE_2D, OpenGL.GL_TEXTURE_MAG_FILTER, OpenGL.GL_LINEAR);
}
// Move back a bit
gl.Translate(0.0f, 0.0f, -25.0f);
gl.BindTexture(OpenGL.GL_TEXTURE_2D, textures[0]);
// Draw a quad.
gl.Begin(OpenGL.GL_QUADS);
// Draw centre quad
gl.TexCoord(0.0f, 0.0f); gl.Vertex(-(quadMiddleWidth / 2), quadMiddleHeight / 2, quadDepthFar);
gl.TexCoord(0.0f, 1.0f); gl.Vertex(quadMiddleWidth / 2, quadMiddleHeight / 2, quadDepthFar);
gl.TexCoord(1.0f, 1.0f); gl.Vertex(quadMiddleWidth / 2, -(quadMiddleHeight / 2), quadDepthFar);
gl.TexCoord(1.0f, 0.0f); gl.Vertex(-(quadMiddleWidth / 2), -(quadMiddleHeight / 2), quadDepthFar);
gl.End();
gl.Flush();
}
这是一个帮助方法,它将BitmapSource转换为给定大小的位图:
private System.Drawing.Bitmap getBitmap(BitmapSource bitmapSource, double rectangleWidth, double rectangleHeight)
{
double newWidthRatio = rectangleWidth / (double)bitmapSource.PixelWidth;
double newHeightRatio = ((rectangleWidth * bitmapSource.PixelHeight) / (double)bitmapSource.PixelWidth) / (double)bitmapSource.PixelHeight;
BitmapSource transformedBitmapSource = new TransformedBitmap(bitmapSource, new ScaleTransform(newWidthRatio, newHeightRatio));
int width = transformedBitmapSource.PixelWidth;
int height = transformedBitmapSource.PixelHeight;
//int stride = width * ((transformedBitmapSource.Format.BitsPerPixel + 7) / 8);
int stride = ((width * transformedBitmapSource.Format.BitsPerPixel + 31) & ~31) / 8; // See: http://stackoverflow.com/questions/1983781/why-does-bitmapsource-create-throw-an-argumentexception/1983886#1983886
byte[] bits = new byte[height * stride];
transformedBitmapSource.CopyPixels(bits, stride, 0);
unsafe
{
fixed (byte* pBits = bits)
{
IntPtr ptr = new IntPtr(pBits);
System.Drawing.Bitmap bitmap = new System.Drawing.Bitmap(
width, height, stride, System.Drawing.Imaging.PixelFormat.Format32bppArgb, ptr);
return bitmap;
}
}
}
四边形渲染,但它只是白色,没有纹理。
答案 0 :(得分:0)
这是SharpGL的一个问题 - 我正在使用的OpenGL库。
http://sharpgl.codeplex.com/discussions/348278 - 对CodePlex的讨论导致SharpGL开发人员解决了这个问题。
答案 1 :(得分:0)
我也有一张白色照片,但是当我将函数TexImage2D
的输入更改为使用宽度和高度为2的倍数时,它就起作用了。根据文件:
纹理图像的宽度(必须是2的幂,例如64)。
纹理图像的高度(必须是2的幂,例如32)。