|
HI Dragon,
have a look at Win32_DiskDrive WMI Class!
"Opinions are neither right nor wrong. I cannot change your opinion. I can, however, change what influences your opinion." - David Crow
cheers,
Alok Gupta
|
|
|
|
|
LPTSTR lpVolumeNameBuffer[100];
LPDWORD lpVolumeSerialNumber;
LPDWORD lpMaximumComponentLength;
LPDWORD lpFileSystemFlags;
LPTSTR lpFileSystemNameBuffer[100];
GetVolumeInformation("C:\\",lpVolumeNameBuffer,100,&lpVolumeSerialNumber,
lpMaximumComponentLength,lpFileSystemFlags,lpFileSystemNameBuffer,100 );
use the above function it returns the Volume Serial Number of the physical C drive .
Cheers
|
|
|
|
|
Hmmm. How about:
<br />
TCHAR caVolumeNameBuffer[ 100 ];<br />
DWORD dwVolumeSerialNumber = 0;<br />
DWORD dwMaximumComponentLength = 0;<br />
DWORD dwFileSystemFlags = 0;<br />
TCHAR caFileSystemNameBuffer[ 100 ];<br />
<br />
GetVolumeInformation( _T( "C:\\" ), caVolumeNameBuffer, 100, &dwVolumeSerialNumber, &dwMaximumComponentLength, &dwFileSystemFlags, caFileSystemNameBuffer, 100 );<br />
Your example was not passing in valid pointers, only uninitialized ones. Might want to ensure proper termination of the TCHAR buffers as well.
However, I think the OP was asking about the physical device name for the drive, not its serial number; I think they were looking for information such as if a drive is \\.\PhysicalDrive0 or \\.\PhysicalDrive1 , etc. You need that information to open the device itself (the hard drive itself) to do things like send IOCTLs. I do not think that the function you specified will return that information.
Peace!
-=- James If you think it costs a lot to do it right, just wait until you find out how much it costs to do it wrong! Tip for new SUV drivers: Professional Driver on Closed Course does not mean your Dumb Ass on a Public Road! DeleteFXPFiles & CheckFavorites (Please rate this post!)
|
|
|
|
|
If you need that to do something like send IOCTLs (DeviceIoControl ), you can also open the device by using the following syntax:
\\.\C: - Open physical device for drive "C"
\\.\D: - Open physical device for drive "D"
\\.\A: - Open physical device for drive "A"
I do not know all of the cases where that format and the \\.\PhysicalDrivex format are interchangable, but I know you can use it when getting a HANDLE to use with DeviceIoControl .
Also, not that you are likely to hit it, but there is a bug in older versions of the Win32_DiskDrive WMI class that limits the number of drives returned. The above method should also work on Windows NT 4.0 versions prior to SP4, but the WMI method will not.
Peace!
-=- James If you think it costs a lot to do it right, just wait until you find out how much it costs to do it wrong! Tip for new SUV drivers: Professional Driver on Closed Course does not mean your Dumb Ass on a Public Road! DeleteFXPFiles & CheckFavorites (Please rate this post!)
|
|
|
|
|
Thanks a lot! I just need to use \\.\PhysicalDrivex to open the disk contains the appointed logical volumn.
I've lookup in MSDN and found the method.
Use DeviceIoControl and send IOCTL_VOLUME_GET_VOLUME_DISK_EXTENTS.
But MSDN says it can only use in win2000 and later version.
Let's roll!
|
|
|
|
|
Hi!
In my application I get a top down raw bitmap that can be of 1,8,24 bits per pixel.
I get this in the form of Bitmapfileheader, BitmapInfo and then bitmap data in a buffer.
Now I want to add a watermark to this image without changing any of its properties like bits per pixel , width , height etc...and get the bitmapdata buffer modified.
Basicaly I am getting this image in some way, I have to just add watermark and send it to printer...
Can anybody tell me what is the easiest way to do this ..with minimum amount of memory involved...Preferably using only win32 APIs...
Thanks
|
|
|
|
|
If you want to add a watermark, that's a blend of your info and the info there, so you probably want to manipulate the bitmap data directly. There's no extra memory required, because you're using the array you have, not creating any others.
Christian Graus - Microsoft MVP - C++
|
|
|
|
|
Hi!
Can you give me some sample code or some link where I can find such sample
It will be of great help...
Thanks
|
|
|
|
|
You can read my image processing articles for general help, and there is an article on watermarking here on CP as well.
Christian Graus - Microsoft MVP - C++
|
|
|
|
|
Thanks for ur help... But I have a very basic problem, I get the info about bitmap as a parameter, what I get is 3 parameters BITMAPINFO, BITMAPFILEINFO, and BitmapData in a buffer.
Now my problem is how to get HBITMAP from this?
I tried CreateBitmap() but as my bitmap has got negative height it fails.
I treid with CreateDIBitmap() but it creates a bitmap with 32bit/pix where as my original bitmap was only 1 bit/pix. and also makes height positive.
Now my second question is if I have created a bitmap and recvd. HBITMAP then I will write text on that. What I want is that my buffer which is holding BitmapData is modified and I get that buffer so that I can pass that to another function.
So what actually i am interested in is how to get modified buffer which is holding bitmapdata.
Thanks
|
|
|
|
|
Naveen_mah wrote:
I tried CreateBitmap() but as my bitmap has got negative height it fails.
It probably has a negative height because the scanlines in a bitmap go from the bottom to the top. try reversing the sign, perhaps ?
Given that you have the bitmapdata, you can create a DIBSection ( which has a HBITMAP and a pointer to bitmap data ) and copy your data into it. A DIBSection is very likely to solve a lot of your problems, actually.
Naveen_mah wrote:
Now my second question is if I have created a bitmap and recvd. HBITMAP then I will write text on that.
If your HBITMAP is a DIBSECTION, then GetObject will return a BITMAP structure with a pointer to the bits. If this fails, you need to create a DIBSECTION and copy your HBITMAP into it, BitBlt will do this for you.
Naveen_mah wrote:
What I want is that my buffer which is holding BitmapData is modified and I get that buffer so that I can pass that to another function.
Yes, if you have a buffer with bitmap data, modifying that seems the best approach, which is what I suggested in the first place.
Naveen_mah wrote:
So what actually i am interested in is how to get modified buffer which is holding bitmapdata.
You have bitmap data, I'm suggesting you iterate through it and modify it, not that you turn it into a HBITMAP or use any GDI functions on it.
Christian Graus - Microsoft MVP - C++
|
|
|
|
|
Christian Graus wrote:
You have bitmap data, I'm suggesting you iterate through it and modify it, not that you turn it into a HBITMAP or use any GDI functions on it.
How can I do that? What I have to write is a text that can be on any size, angle, color, font, and more over I want it to be transparent so that text and bitmap both are seen.
So how can I modify the bitmap data directly without using GDI API's
Thanks
|
|
|
|
|
Naveen_mah wrote:
How can I do that? What I have to write is a text that can be on any size, angle, color, font, and more over I want it to be transparent so that text and bitmap both are seen.
The fact that you want to merge text with the bitmap underneath DEMANDS that you do it directly, unless you use GDI+, in which case you can create a semi transparent brush to draw the text for you.
Naveen_mah wrote:
So how can I modify the bitmap data directly without using GDI API's
Well, you have the bitmap data as a byte array, so you would figure out where you want to put something, and iterate through the bits, placing it on. I didn't realise you wanted to rotate your text, or change it's colour, I assumed you had a standard watermark you wanted to add, in which case you could store it in a resource bitmap, and use the values in that bitmap to merge into your source image.
Christian Graus - Microsoft MVP - C++
|
|
|
|
|
So what do u think is the best way to do this? As my watermark is dynamic and can be of any kind.
Below is the code I have simplified and pasted here, But I am not able to BitBlt bitmap and getting insuficient memory error...
Can anybody help me out ...where I have gone wrong?
My bitmap is 1 bit bitmap and is top down bitmap 2275x3300 (file size 928 KB)
<br />
void AddText(HWND hWnd)<br />
{<br />
HDC hdc = GetDC(hWnd); <br />
FILE * fp = NULL;<br />
fp = _wfopen(L"d:\\bmp.bmp",L"r+");<br />
int width,height; <br />
if (fp)<br />
{<br />
BITMAPFILEHEADER bmFileHeader;<br />
BITMAPINFOHEADER bmInfoHeader;<br />
PBYTE pBmData = NULL;<br />
fread(&bmFileHeader,sizeof(BITMAPFILEHEADER),1,fp);<br />
fread(&bmInfoHeader,sizeof(BITMAPINFOHEADER),1,fp);<br />
BITMAPINFO* pBmInfo;<br />
int size;<br />
<br />
if (bmInfoHeader.biBitCount == 24)<br />
{<br />
size = sizeof(BITMAPINFOHEADER);<br />
}<br />
else size = sizeof(BITMAPINFOHEADER) + 2 * sizeof(RGBQUAD);<br />
<br />
pBmInfo = (PBITMAPINFO)new BYTE[size];<br />
<br />
fseek(fp,sizeof(BITMAPFILEHEADER),SEEK_SET);<br />
fread(pBmInfo,size,1,fp);<br />
pBmInfo->bmiHeader.biHeight*= -1;<br />
width = pBmInfo->bmiHeader.biWidth;<br />
height = pBmInfo->bmiHeader.biHeight;<br />
<br />
<br />
pBmData = new BYTE[bmInfoHeader.biSizeImage];<br />
fread(pBmData,1,bmInfoHeader.biSizeImage,fp);<br />
fclose(fp);<br />
<br />
pBmInfo->bmiHeader.biClrImportant = 2;<br />
pBmInfo->bmiHeader.biClrUsed = 2;<br />
<br />
DWORD fdwInit = CBM_INIT;<br />
HBITMAP hBitmap = CreateBitmap(width,height,bmInfoHeader.biPlanes,bmInfoHeader.biBitCount,pBmData);<br />
DWORD err = GetLastError();<br />
<br />
BITMAP bitmap; GetObject(hBitmap,sizeof(BITMAP),&bitmap);<br />
<br />
HDC TmpDC = CreateCompatibleDC(hdc);<br />
BYTE *pbase;<br />
HBITMAP TmpBmp=CreateDIBSection(TmpDC,<br />
pBmInfo,DIB_PAL_COLORS,(void**)&pbase,0,0);<br />
HGDIOBJ TmpObj=SelectObject(TmpDC,TmpBmp);<br />
<br />
HDC dcBmp=CreateCompatibleDC(TmpDC);<br />
HGDIOBJ TmpObj2 = SelectObject(dcBmp,hBitmap);<br />
int ret = BitBlt(TmpDC,0,0,width,height,dcBmp,0,0,SRCCOPY);<br />
err = GetLastError();<br />
<br />
SelectObject(decBmp,TmpObj2);<br />
DeleteDC(dcBmp);<br />
TextOut(TmpDC,100,100,L"Watermark",lstrlen(L"Watermark"));<br />
<br />
DeleteObject(hBitmap);<br />
hBitmap=TmpBmp;<br />
DIBSECTION dib;<br />
GetObject(hBitmap,sizeof(DIBSECTION),&dib);<br />
<br />
<br />
SelectObject(TmpDC,TmpObj);<br />
DeleteDC(TmpDC);<br />
DeleteDC(hdc);<br />
delete []pBmData;<br />
delete []pBmInfo;<br />
<br />
}<br />
<br />
}<br />
Thanks
|
|
|
|
|
Naveen_mah wrote:
HDC hdc = GetDC(hWnd);
Why ? You realise this means your HDC will have the bit depth of your PC, you won't control it ?
Naveen_mah wrote:
FILE * fp = NULL;
Man, C file reading is ugly....
Naveen_mah wrote:
DIBSECTION dib;
GetObject(hBitmap,sizeof(DIBSECTION),&dib);
/// Dont get any data in dib.dsBm.bmBits
The data is in pbase, you get it out of calling CreateDIBSection.
Naveen_mah wrote:
My bitmap is 1 bit bitmap and is top down bitmap 2275x3300 (file size 928 KB)
How on earth do you hope to create a watermark in a 1 bit bitmap ? If each bit is just on or off, one of two colours, then you just want to write text over it, you don't want a watermark at all. A watermark is a generally invisible signature that's blended into an image. There's no blending when you have only two colours.
Perhaps you need to redefine what you're trying to do here ? If you're using anything less than 16 bit, you need to use GDI functions, because keeping track of palettes and stuff is just too painful.
Christian Graus - Microsoft MVP - C++
|
|
|
|
|
I have my basic application together what I want to do is call one dialog box from my base application (an about box). The main application is a dialog box itself.
|
|
|
|
|
|
I think you only need some basic MFC Programming book.
Jack
---------------------------------------------------------------------------------
XD++ MFC/C++ Flow/Diagram Library -- http://www.ucancode.net
|
|
|
|
|
i am currently implementing a program where i need to print the screen and take its picture (the same function performed by the print screen key on the keyboard) but i want to do this automaticly so is there any c++ command or any other way that i can use to perform such function
gobar
|
|
|
|
|
depends if you're using MFC or not.
With a multi-doc MFC app it does print screen for you.
|
|
|
|
|
Type print screen in CodeProject's "Search" box.
/ravi
My new year's resolution: 2048 x 1536
Home | Articles | Freeware | Music
ravib@ravib.com
|
|
|
|
|
|
Repost from COM forum which seems dead.
Question 1:
I have:
1. exe COM client A.
2. exe outofproc COM server B which is also a client to:
3. dll inproc COM server C.
So B creates an instance of C. And passes the pointer to it to A. Can A actualy call C which is in B process space?
Question 2:
I have:
1. A is an exe COM client .
2. B is an exe outofproc COM server.
When A releases all instances of B, B unloads. Good! That's what I need. BUT! If:
2. B is a dll inproc COM server.
Then When A releases all instances of B, dll B still is loaded by A process for a while.
Is there a way to force it to unload?
Thanks a lot!
|
|
|
|
|
Take these with a grain of salt, I am no COM expert...
Question 1: I do not think that is directly possible, but I think that when you pass the interface pointer to another process (from B to A), you will get a marshalled interface pointer, which will not really be the same pointer value you passed over. Instead, it will be one that COM created during the "pass" operation. This new interface pointer will not be in B's address space, it will be in A's. If it pointed to a location in B's address space (for example, you passed over the value of the interface pointer), you would likely crash the instant you tried to use it because it would not point to the same location anymore (if it pointed anywhere valid at all).
Question 2: You have the FreeLibrary function, but you cannot get directly ahold of the handle for the DLL that contains the the InProc COM object*. It was loaded by the COM subsystem, and even if you did manage to get that handle and force an unload, I think you would be basically snatching the rug out from under COM and that might be bad...
* Yes, you could call LoadLibrary again and might get the same instance handle...
Peace!
-=- James If you think it costs a lot to do it right, just wait until you find out how much it costs to do it wrong! Tip for new SUV drivers: Professional Driver on Closed Course does not mean your Dumb Ass on a Public Road! DeleteFXPFiles & CheckFavorites (Please rate this post!)
|
|
|
|
|
inner wrote:
Can A actualy call C which is in B process space?
I'm pretty sure you can't do this. Sharing of a COM object must be managed by the object itself.
inner wrote:
Is there a way to force it to unload?
Not easily. Is there any reason why you'd want to though? Windows manages this quite well.
Ryan "Punctuality is only a virtue for those who aren't smart enough to think of good excuses for being late" John Nichol "Point Of Impact"
|
|
|
|
|