|
I would like to be able to perform background work in my C# .net Windows Service if no mouse messages or key messages have be received for 10 minutes.
It involves downloading, uploading and processing, I would like to be able to tell if the computer has been idle from the user to a 10 minute period and then I would start these routines/processes.
I see how to do this with Forms with overriding the WinProc method, but I need Windows Messages for a Service, and I think the Forms WinProc method only gets events when the mouse is moved over top of it. I need Messages that occure anywhere within Windows/OS/Desktop.
Is there any Windows API methods to import or any idea how to do this?
Thanks in advance.
|
|
|
|
|
krisp wrote:
I see how to do this with Forms with overriding the WinProc method, but I need Windows Messages for a Service, and I think the Forms WinProc method only gets events when the mouse is moved over top of it. I need Messages that occure anywhere within Windows/OS/Desktop.
You'll need to use a system-wide hook DLL, which cannot be written from C# - you'll probably want to write it in C++. You can then use this from your C# application.
|
|
|
|
|
If you are using Windows 2000 or above, you can use the GetLastInputInfo API call. You get a structure with the tick count when the last input event happened.
|
|
|
|
|
Awesome, thanks alot Jeff, that is exaclty what I needed, i guess I can just call it in a seperate thread every minute or so. Thanks again
The GetLastInputInfo function retrieves the time of the last input event.
Syntax:
BOOL GetLastInputInfo( PLASTINPUTINFO plii );
Parameters:
plii - [out] - Pointer to a LASTINPUTINFO structure that receives the time of the last input event.
Return Value:
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero.
Remarks:
This is useful for input idle detection.
Function Information:
Header Declared in Winuser.h, include Windows.h
Import library User32.lib
Minimum operating systems Windows 2000
See Also:
Keyboard Input, LASTINPUTINFO
|
|
|
|
|
I've a similar question. I'm being with a project which can create shortcuts for windows. Is it possible to get a signal if for example the "P" button is pressed
Jonathan Slenders
|
|
|
|
|
If I have a base class A and class B implments class A, how can I get access to class B from class A.
I want to use reflection to loop through the properties of class B in class A, but I need a reference to the object in order to do this.
Thanks for your help.
|
|
|
|
|
not sure if this is what you want...
within class A if you think it is a type of class B then
// c#
if( this is ClassB )
{
( ( ClassB )this ).ClassBMethodCall();
}
// or
ClassB b = this as ClassB;
if( b != null )
{
b.ClassBMethodCall();
}
Not sure what you mean by using reflection, if all you want to do is call a ClassB method from its parent class, then I dont htink you need reflection. Unless im mistaken by what you mean/want.
|
|
|
|
|
Thanks for your reply.
The problem with this is that the base class (class A) does not know what class B is, as any class can implement class A. Therefore, you cannot explicitly reference ClassB.
This is why I have resorted to sending class B through to the base class (class A) when I need to reference its properties. But of course I don't think this could be the best way.
Any other thoughts?
|
|
|
|
|
So you are not making specific derived classes that your parent class would know about at compile time of the parent class?
Is there a certain propery you want to call of the derived/child class (class B) or you just want to iterate through them all. Because you can make properies virtual or abstract as well so that your child class would have the property you are looking for.
As far as iterating through them, you should be able to use reflection and call the this.GetType().GetProperties(); and then iterate throught the returned PropertyInfo[] which has a Name and PropertyType property.
this.GetType() will return the type of the lowest child class not the type of the class that it is called within.
That help any?
|
|
|
|
|
If all the Class Bs have the same set of properties you could create an interface and inherit from the interface as well as Class A. Then when you are iterating through all the objects via the reference to class A you can cast to the interface.
class B : A, IMyCommonProperties
{
}
foreach(A myObject in myObjectCollection)
{
IMyCommonProperties mcp = (IMyCommonProperties)myObject;
mcp.MyProperty1;
}
--Colin Mackay--
"In the confrontation between the stream and the rock, the stream always wins - not through strength but perseverance." (H. Jackson Brown)
|
|
|
|
|
in the document on .Net Framework you can find some information about cachedbitmab and its finction drawcahcedbitmap but if you search all the classes of .Net Framework for c# you could not found any thing about it, any body know's about this class ??
Mhmoud Rawas
------------
Software Eng.
|
|
|
|
|
CachedBitmaps are created from normal bitmaps, to store them optimized for a display device.
The contructor is
CachedBitmap( Bitmap*, Graphics* )
Graphics (GDI+, not System.Drawing!) is associated with a display device. CachedBitmap formats the bitmap for this device.
CachedBitmap belongs to GDI+, is derived from GdiPlusBase and declared in Gdiplusheaders.h, Gdiplus.h.
|
|
|
|
|
Dear Corinna,
I am asking about cached bitmap in c# so if you know how to create an instance of that class could you send me a code smaple for that cuz i could not find the class constructor......
Mhmoud Rawas
------------
Software Eng.
|
|
|
|
|
Unfortunately, in .NET, CachedBitmap is an internal class - you can't use it yourself. I really hope that this will change in future versions of the .NET Framework.
|
|
|
|
|
I hoop so but do you know any way to stor the bitmap in the display card memory for improve the appliaction performance ???
Mhmoud Rawas
------------
Software Eng.
|
|
|
|
|
mhmoud rawas wrote:
do you know any way to stor the bitmap in the display card memory
There might be some way, but it won't be easy, you won't be able to do it from C#, and there's no need to do that. The CachedBitmap doesn't do this - it just creates a bitmap that's optimized for the current display settings.
|
|
|
|
|
So in your oppenion what is the way to accelerate the drawing method in C# if you have an application which draw a large bitmap on mouse movement (Some thing like paning in the graphics application) and so we have to be carefull while dealing with large bitmaps cuz some times it takes'a large space in the memory espesialy while redrawing it
do you have a way to do that
Mhmoud Rawas
------------
Software Eng.
|
|
|
|
|
in my windows application,i embeded a web browser,by this method we can show web component.But i want control this component such as draw to a new position.How can i do this.Help
|
|
|
|
|
I think you can create a solution consist's of web service project and control project which reference the web service project and get's the information you need from it every period of time try it ....
Mhmoud Rawas
------------
Software Eng.
|
|
|
|
|
If you're hosting the IWebBrowser2 interface, you can use the MSHTML hosting interfaces like IDocHostUIHandler (see the PSDK for more details). This and several other hosting interfaces give you control over context menus, object placement and drawing, and much more functionality.
To implement IDocHostUIHandler (which pretty much sets everything else up), you must either redefine the interface in .NET (making sure to use the right GUID...or another technique which I'll link to later) and implement that on your class. You can QI (or cast in .NET) the WebBrowser control (or an IHTMLDocument* interface) to ICustomDoc and call SetUIHandler , passing a reference to your implementation of IDocHostUIHandler (but that only lets you use UI customization methods), or implement IOleClientSite . The WebBrowser control will QI for this interface on the host (you) and make calls to the IDocHostUIHandler for all methods.
You can read more about hosting the WebBrowser control and MSHTML by looking at http://msdn.microsoft.com/workshop/browser/prog_browser_node_entry.asp[^].
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
Heath Stewart wrote:
You can QI (or cast in .NET) the WebBrowser control (or an IHTMLDocument* interface) to ICustomDoc and call SetUIHandler, passing a reference to your implementation of IDocHostUIHandler (but that only lets you use UI customization methods)
Just to give a quick example:
ICustomDoc cDoc = (ICustomDoc)webBrowser.Document;
cDoc.SetUIHandler((IDocHostUIHandler)this);
There's something I'd like to warn people about with the WebBrowser control. I replaced the default context menu for the WebBrowser, but whenever my context menu closed (after an item was clicked), the next item on the default context menu was executed, even though it never appeared. I was just about at my wit's end when I realized that the context menu must be sending something back to the window it was shown on behalf of - the WebBrowser control - and it was executing the default menu's commands. Changing the window passed into the context menu to the form instead of the WebBrowser solved the problem.
|
|
|
|
|
Oh, about those other links: rather than manually defining all the interfaces, you can use a technique that described in this article: http://www.codeproject.com/csharp/advhost.asp[^]
You create an IDL file (used in COM programming) to forward-define interfaces and compile that to a typelib (TLB). Then you use the tlbimp.exe utility in the .NET SDK to create an interop assembly out of that. Now you're got your interfaces defined correctly and just have to implement them! A word of caution, though: all the methods return void . Some methods require that you return S_FALSE in COM, which is still a success code. Since the return type is void , you can't return anything and you can't use a COMException because that creates an error state. In these cases, you will have to define the interface yourself and for those methods make them return an int and add the PreserveSignature=true property statement to the MarshalAsAttribute that you must add to the method.
Also, another helpful article here on CP is a book excerpt: http://www.codeproject.com/books/0764549146_8.asp[^]
These are both pretty good, but I still recommend you read that link I gave you to MSDN. It's the best way to learn about hosting the WebBrowser control or MSHTML.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
Heath Stewart wrote:
A word of caution, though: all the methods return void. Some methods require that you return S_FALSE in COM, which is still a success code. Since the return type is void, you can't return anything and you can't use a COMException because that creates an error state.
Actually, I've successfully done this in the IDocHostUIHandler.TranslateAccelerator method. The way I know I was successful is that it no longer "ate" all keyboad messages that were sent to the WebBrowser control. But yes, it's better to re-define the interface.
throw new System.Runtime.InteropServices.COMException("S_CANCEL - No custom handling",1);
|
|
|
|
|
COM+ Transaction 70-320 exam question
[Transaction(TransactionOption.Required)]
[SecurityRole("Admin")]
public class SalesProcessor
{
public void PlaceOrder()
{
//STEP 1: Code here to insert order to order table, calling method on another COM+ component participating in the transaction.
objCOM1.InsertOrder(...);
//STEP 2: Code here to update shipping table. Again, calling method on a second COM+ component participating in the transaction.
objCOM2.UpdateShipping(...);
}
}
The question is, what do you need to add in order for the transaction initiated by PlaceOrder to be executed properly. You options are:
a. Add [AutoComplete(true)] to PlaceOrder
b. Add EnableCommit( ) to "End" of PlaceOrder method.
c. ... not viable option ...
d. ... not viable option ...
The model answer is "EnableCommit" (That's option *b*). But I don't understand why. I never used EnableCommit( ) before, never had to. If I don't use [AutoComplete(true)] to automatically call SetComplete and SetAbort, I'd do it manually:
public void PlaceOrder()
{
ContextUtil.EnableCommit( ); //Is this how you use EnableCommit()? But "option b" suggested that it should be added at the END of the method after the processing... That's weird.
try
{
objCOM1.InsertOrder(...);
objCOM2.UpdateShipping(...);
ContextUtil.SetComplete(...);
}
catch(Exception er)
{
... exception prcessing ...
ContextUtil.SetAbort( );
}
}
Otherwise, [AutoComplete(true)] would do the job:
[AutoComplete(true)]
public void PlaceOrder()
{
objCOM1.InsertOrder(...);
objCOM2.UpdateShipping(...);
}
Thanks.
|
|
|
|
|
I have a WEB form associated to a C#. One of my issues is to show a file Dialog for choosing a file and process it.
How can I get this using a Web Development? In Windows forms it is clear.
|
|
|
|