Darc Posted November 2, 2003 Posted November 2, 2003 hey, this kinda falls under interop too, but I wanted to know if GDI (BitBlt) would be faster than .NETs GDI+. I found a way to use old GDI with C++ .DLLs so would it be faster under C++? Quote
*Experts* mutant Posted November 2, 2003 *Experts* Posted November 2, 2003 You dont need to create any C++ DLL to use GDI32 in your .NET app. You can simply declare the function and use it. As far as comparison goes. A lot of people will say that GDI32 is faster than GDI+. But using GDI+ from .NET is MUCH easier. Quote
wyrd Posted November 2, 2003 Posted November 2, 2003 Yes, GDI is much faster. I made a class library a while back to make GDI easier to use. Feel free to expand on it to meet your own needs. If you want to see a sample of it being used, do a search for Sharp Invader. It's a game I made using this GDI library.gdi.zip Quote Gamer extraordinaire. Programmer wannabe.
Darc Posted November 2, 2003 Author Posted November 2, 2003 I don't have C#, I have VB and C++. btw, for using bitblt, do I just use GetWindowsDC(Me.Handle) or something like that? Quote
Darc Posted November 3, 2003 Author Posted November 3, 2003 ok, I tried the following but it gave me: An unhandled exception of type 'System.InvalidOperationException' occurred in system.windows.forms.dll Additional information: The object is currently in use elsewhere. here's the code: Public Sub Blt(ByVal img As Image, ByVal e As Graphics, ByVal rct As Rectangle) Dim graph As Graphics = Graphics.FromImage(img) Dim imgHDC As Long = graph.GetHdc.ToInt64 Dim hdc As Long = e.GetHdc.ToInt64 Dim retval As Long retval = BitBlt(hdc, CRD_AREA.X, CRD_AREA.Y, CRD_AREA.Width, CRD_AREA.Height, imgHDC, 0, 0, &HCC0020) graph.Dispose() End Sub Quote
wyrd Posted November 3, 2003 Posted November 3, 2003 You are using .NET right? It doesn't matter what language you're using, the code is identical (with the exception of syntax, but that's easily translated). If you just want to use C++ unmanaged, then look at this tutorial; http://winprog.org/tutorial/bitmaps.html Quote Gamer extraordinaire. Programmer wannabe.
AndreRyan Posted November 4, 2003 Posted November 4, 2003 BitBlt uses Int32 not Int64 (Integer not Long) Public Sub Blt(ByVal img As Image, ByVal e As Graphics, ByVal rct As Rectangle) Dim graph As Graphics = Graphics.FromImage(img) Dim imgHDC As Integer = graph.GetHdc.ToInt32 Dim hdc As Integer = e.GetHdc.ToInt32 Dim retval As Integer retval = BitBlt(hdc, CRD_AREA.X, CRD_AREA.Y, CRD_AREA.Width, CRD_AREA.Height, imgHDC, 0, 0, &HCC0020) graph.ReleaseDC(imgHDC) graph.Dispose() e.ReleaseDC(hdc) End Sub GDI+ has more features then GDI, If you use GDI+ effeciently the slower speed will make minimal difference Quote .Net allows software to be written for any version of Windows and not break like Unmanaged applications unless using Unmanaged procedures like APIs. If your program uses large amounts of memory but releases it when something else needs it, then what's the problem?
Darc Posted November 4, 2003 Author Posted November 4, 2003 (edited) I'm just using it in a couple places for boosts of speed (simple square images) just a question, how can I convert the integer's to IntPtr, ReleaseHDC doesn't have an overload for Integer Edited November 4, 2003 by Darc Quote
AndreRyan Posted November 6, 2003 Posted November 6, 2003 I recommend using this BitBlt declaration: Declare Function BitBlt Lib "gdi32.dll" (ByVal hDestDC As IntPtr, ByVal x As Int32, _ ByVal y As Int32, ByVal nWidth As Int32, ByVal nHeight As Int32, ByVal hSrcDC As IntPtr, _ ByVal xSrc As Int32, ByVal ySrc As Int32, ByVal dwRop As Int32) As Int32 The Bitblt function can now use IntPtr objects, it works fine. Or if you don't want to do that you can just alter the function: Public Sub Blt(ByVal img As Image, ByVal e As Graphics, ByVal rct As Rectangle) Dim graph As Graphics = Graphics.FromImage(img) Dim imgHDC As IntPtr = graph.GetHdc Dim hdc As IntPtr = e.GetHdc Dim retval As Integer retval = BitBlt(hdc.ToInt32, CRD_AREA.X, CRD_AREA.Y, CRD_AREA.Width, CRD_AREA.Height, imgHDC.ToInt32, 0, 0, &HCC0020) graph.ReleaseDC(imgHDC) graph.Dispose() e.ReleaseDC(hdc) End Sub Quote .Net allows software to be written for any version of Windows and not break like Unmanaged applications unless using Unmanaged procedures like APIs. If your program uses large amounts of memory but releases it when something else needs it, then what's the problem?
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.