|
|
sorry. i meant c# class that inherits from unmanaged c++. is there a way to accomplish this?
|
|
|
|
|
No. You would have to encapsulate this unmanaged C++ class in a managed class. The easiest way would be to create a mixed mode Managed C++ assembly that encapsulates this in a managed class, then extend that from C#.
Microsoft MVP, Visual C#
My Articles
|
|
|
|
|
Heath Stewart wrote:
easiest way would be to create a mixed mode Managed C++ assembly that encapsulates this in a managed class
ok. can you point me to some info about that?
thanks.
|
|
|
|
|
Um, try the .NET Framework SDK. You did install that with Visual Studio .NET or with the .NET Framework SDK download, did you not?
Specifically, see Managed Extensions for C++ Programming[^] in the VS.NET product documentation.
Most importantly, remember that the managed code has the same access to .NET assemblies (including the base class library) that every other .NET language. That's the whole point of language interoperability.
Microsoft MVP, Visual C#
My Articles
|
|
|
|
|
Hey,
I'd like to develop some open source software for the public mainly for gaming. I would like to take mouse input and convert it so that the computer will assume it as a keystoke.
For example on an intellimouse which has 5buttons if the middle mouse button is pressed i would like to fire say a Keystroke p.
The old microsoft software allowed you to do this, the new ones do not, and hence here i am
Atul
|
|
|
|
|
Do a search on hooks (intercepting the mouse input at a system wide low level) and the SendInput call (simulating a keyboard press).
Both of these things are low level and not represented in the framwork classes, so you'll have to do some interop to get this stuff done in C#.
I, for one, do not think the problem was that the band was down. I think that the problem may have been that there was a Stonehenge monument on the stage that was in danger of being crushed by a dwarf.
-David St. Hubbins
|
|
|
|
|
Good Luck!
Perl combines all the worst aspects of C and Lisp: a billion different sublanguages in one monolithic executable. It combines the power of C with the readability of PostScript. -- Jamie Zawinski
|
|
|
|
|
Update:
part of the solution[^]
the answer was under my nose
this is part of the solution just need to stick a gui on and work out how to fire a keyboard event and i'm nearly there
Hopefully all gamers can use this who have 5 button mice and no software
once i'm finished i'll stick the source up on here
|
|
|
|
|
SendInput is the Win32 function you want to use for this. It can be used to simulate keyboard and mouse actually. You'll definitely need to use interop to make the calls from C#.
I've played around with using it to simulate mouse calls, and it's worked fine in other DirectX games (at the time I was trying to do a little macroing in a popular MMORPG).
If you run into any problems, let me know.
I, for one, do not think the problem was that the band was down. I think that the problem may have been that there was a Stonehenge monument on the stage that was in danger of being crushed by a dwarf.
-David St. Hubbins
|
|
|
|
|
as.thakor@ntlworld.com
could i speak to you by email direct ?
it would be greatly appreciated
Thanks
Atul
|
|
|
|
|
Here's a chunk of code I wrote. This class was basically being hosted by remoting (thus the MarshalByRefObject), but it moves the mouse where you want it. It shows how to interop with SendInput (importing the definition and defining a few structures you'll need).
<div style="font-family:Courier New;font-size:10pt;background-color:#FFFFFF" >
<span style="color:#0000FF;">using </span><span style="color:#000000;">System;<br>
</span><span style="color:#0000FF;">using </span><span style="color:#000000;">System.Runtime.InteropServices;<br>
<br>
<br>
[StructLayout(LayoutKind.Explicit, Size=28)]<br>
</span><span style="color:#0000FF;">public struct </span><span style="color:#000000;">Input<br>
{<br>
[FieldOffset (0)]<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">type;<br>
[FieldOffset (4)]<br>
</span><span style="color:#0000FF;">public </span><span style="color:#000000;">MouseInput mi;<br>
[FieldOffset (4)]<br>
</span><span style="color:#0000FF;">public </span><span style="color:#000000;">KeyboardInput ki;<br>
[FieldOffset (4)]<br>
</span><span style="color:#0000FF;">public </span><span style="color:#000000;">HardwareInput hi;<br>
<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">INPUT_MOUSE = 0;<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">INPUT_KEYBOARD = 1;<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">INPUT_HARDWARE = 2;<br>
}<br>
<br>
[StructLayout(LayoutKind.Sequential, Size=24)]<br>
</span><span style="color:#0000FF;">public struct </span><span style="color:#000000;">MouseInput<br>
{<br>
</span><span style="color:#0000FF;">public int </span><span style="color:#000000;">dx;<br>
</span><span style="color:#0000FF;">public int </span><span style="color:#000000;">dy;<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">mouseData;<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">dwFlags;<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">time;<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">dwExtraInfo;<br>
<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_MOVE = 0x0001; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_LEFTDOWN = 0x0002; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_LEFTUP = 0x0004; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_RIGHTDOWN = 0x0008; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_RIGHTUP = 0x0010; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_MIDDLEDOWN = 0x0020; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_MIDDLEUP = 0x0040; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_XDOWN = 0x0080; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_XUP = 0x0100; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_WHEEL = 0x0800; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_VIRTUALDESK = 0x4000; </span><span style="color:#008000;"><br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">MOUSEEVENTF_ABSOLUTE = 0x8000; </span><span style="color:#008000;"><br>
</span><span style="color:#000000;">}<br>
<br>
[StructLayout(LayoutKind.Sequential, Size=24)]<br>
</span><span style="color:#0000FF;">public struct </span><span style="color:#000000;">KeyboardInput<br>
{<br>
</span><span style="color:#0000FF;">public ushort </span><span style="color:#000000;">wVk;<br>
</span><span style="color:#0000FF;">public ushort </span><span style="color:#000000;">wScan;<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">dwFlags;<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">time;<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">dwExtraInfo;<br>
<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">KEYEVENTF_EXTENDEDKEY = 0x0001;<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">KEYEVENTF_KEYUP = 0x0002;<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">KEYEVENTF_UNICODE = 0x0004;<br>
</span><span style="color:#0000FF;">public const uint </span><span style="color:#000000;">KEYEVENTF_SCANCODE = 0x0008;<br>
}<br>
<br>
[StructLayout(LayoutKind.Sequential, Size=24)]<br>
</span><span style="color:#0000FF;">public struct </span><span style="color:#000000;">HardwareInput<br>
{<br>
</span><span style="color:#0000FF;">public uint </span><span style="color:#000000;">uMsg;<br>
</span><span style="color:#0000FF;">public ushort </span><span style="color:#000000;">wParamL;<br>
</span><span style="color:#0000FF;">public ushort </span><span style="color:#000000;">wParamH;<br>
}<br>
<br>
<br>
<br>
</span><span style="color:#0000FF;">namespace </span><span style="color:#000000;">InputSimulation<br>
{<br>
</span><span style="color:#808080;"> </span><span style="color:#808080;"><br>
</span><span style="color:#0000FF;">public class </span><span style="color:#000000;">InputSimulation : MarshalByRefObject<br>
{<br>
<br>
[DllImport("user32.dll")]</span><span style="color:#0000FF;">public static extern uint </span><span style="color:#000000;">SendInput(</span><span style="color:#0000FF;">uint </span><span style="color:#000000;">nInputs, </span><span style="color:#0000FF;">ref </span><span style="color:#000000;">Input inputs, </span><span style="color:#0000FF;">int </span><span style="color:#000000;">sizeofInput);<br>
<br>
</span><span style="color:#0000FF;">public </span><span style="color:#000000;">InputSimulation()<br>
{<br>
}<br>
<br>
</span><span style="color:#0000FF;">public void </span><span style="color:#000000;">MouseMove(</span><span style="color:#0000FF;">ushort </span><span style="color:#000000;">x, </span><span style="color:#0000FF;">ushort </span><span style="color:#000000;">y)<br>
{<br>
Input[] i = {</span><span style="color:#0000FF;">new </span><span style="color:#000000;">Input()};<br>
i[0].type = 0;<br>
i[0].mi.dx = (</span><span style="color:#0000FF;">int</span><span style="color:#000000;">) x;<br>
i[0].mi.dy = (</span><span style="color:#0000FF;">int</span><span style="color:#000000;">) y;<br>
i[0].mi.dwExtraInfo = 0;<br>
i[0].mi.dwFlags = MouseInput.MOUSEEVENTF_ABSOLUTE | MouseInput.MOUSEEVENTF_MOVE | MouseInput.MOUSEEVENTF_VIRTUALDESK;<br>
i[0].mi.mouseData = 0;<br>
i[0].mi.time = 0;<br>
<br>
</span><span style="color:#0000FF;">uint </span><span style="color:#000000;">ret = SendInput(1, </span><span style="color:#0000FF;">ref </span><span style="color:#000000;">i[0], System.Runtime.InteropServices.Marshal.SizeOf(i[0]));<br>
}<br>
<br>
</span><span style="color:#0000FF;">public void </span><span style="color:#000000;">MouseClick()<br>
{<br>
Input[] i = {</span><span style="color:#0000FF;">new </span><span style="color:#000000;">Input(), </span><span style="color:#0000FF;">new </span><span style="color:#000000;">Input()};<br>
<br>
}<br>
}<br>
}<br>
</span>
</div>
I, for one, do not think the problem was that the band was down. I think that the problem may have been that there was a Stonehenge monument on the stage that was in danger of being crushed by a dwarf.
-David St. Hubbins
|
|
|
|
|
|
I have just started playing with the code and read that its possible to make a global hook
http://support.microsoft.com/default.aspx?scid=KB;EN-US;Q319524
|
|
|
|
|
I was wondering how that was going to work (I'm actually not sure the exact purpose of installing a hook that's not global to be honest...I need to read more about that). I knew you had to write a DLL with a specific signature that gets loaded by every application (I wrote one once for a kiosk that disabled and enabled things like CTRL-ALT-DELETE once they typed in a password).
I looks like almost the entire project would have to be a straight Win32 DLL in C/C++ (since the keyboard hook would be calling SendInput). You'd most likely write an application that installs and uninstalls the hook as well (which wouldn't necessarily have to be written in C/C++).
Have you ever done any C++? This DLL wouldn't actually be that big...you just have to get it perfect since everything is calling it . If I get a chance tonight, I'll play around with writing a hook (busy at work at the moment).
I, for one, do not think the problem was that the band was down. I think that the problem may have been that there was a Stonehenge monument on the stage that was in danger of being crushed by a dwarf.
-David St. Hubbins
|
|
|
|
|
i got hold of a dll hook someone used in VB maybe its convertable to be used in .net ?
http://www.allapi.net/php/redirect/redirect.php?action=download&id=372
thats the link to the sample prog and .dll
nope i havent much experience in c++
only the very basics of c but i am willing to learn
|
|
|
|
|
That app uses Visual Basic (not VB.NET) to create a DLL. His DLL might have even been written in C/C++, but in any event you can specify exactly how the DLL should look in any of those languages (some more easier than others)
I could be wrong (wouldn't be the first time), but I don't think you can create a .NET "Win32 Dll" (there might be some third party stuff that lets you do this, but I don't know). That is to say, I don't think you can create something in .NET that's just a DLL (and not a managed assembly). You can create a DLL that exposes COM functionality, but I don't think you can get as specific as you need for this DLL in .NET (either VB.NET or C#).
I think this job would actually require something other than .NET.
I, for one, do not think the problem was that the band was down. I think that the problem may have been that there was a Stonehenge monument on the stage that was in danger of being crushed by a dwarf.
-David St. Hubbins
|
|
|
|
|
http://msdn.microsoft.com/msdnmag/issues/02/10/cuttingedge/default.aspx
Apparently a Global hook.......
doesnt seem to do much though
|
|
|
|
|
Google 2 Win it seems
http://www.planet-source-code.com/vb/scripts/ShowCode.asp?txtCodeId=872&lngWId=10
has the source code for someone who has created something pretty much what i want in vb.net
just gotta translate ye old code to c# now or just use the vb.net stuff
if your still intrested in having a mess about with this project your very welcome
as your input has been extremely value!
|
|
|
|
|
k had a look at the source........
<br />
Private Declare Function GetCursor Lib "user32" () As Int32<br />
Private Declare Function GetCursorPos Lib "user32" Alias "GetCursorPos" (ByRef lpPoint As POINTAPI) As Int32<br />
Private Declare Function WindowFromPoint Lib "user32" (ByVal xPoint As Int32, ByVal yPoint As Int32) As Int32<br />
Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Int32, ByRef lpdwProcessId As Int32) As Int32<br />
Private Declare Function AttachThreadInput Lib "user32" Alias "AttachThreadInput" (ByVal idAttach As Int32, ByVal idAttachTo As Int32, ByVal fAttach As Int32) As Int32<br />
Private Declare Function GetAsyncKeyState Lib "user32" Alias "GetAsyncKeyState" (ByVal vKey As Int32) As Int16<br />
k i understand GetCursor is the function name and it returns in Integer ....... but "user32" refers to a library and i have no idea how to port that part of the code over to c#
just out of interest is this...... code actually intercepting the events or simply reading them as they fly by as i need to read process and act
|
|
|
|
|
Not sure if that technique would work for DirectX games etc. It might not be low level enough.
I think hooks might be the only way to do it, and doing global hooks seems truly impossible to do entirely in .NET.
It's not too hard to get unmanaged code (C/C++/VB) to talk to managed code via a COM. That might be the easiest way: create a C/C++ hook, create a .NET class that gets wrapped as a COM component, let the hook call the .NET class.
This would allow you to do most of your development in C#, but I think some C/C++ is going to be unavoidable.
I, for one, do not think the problem was that the band was down. I think that the problem may have been that there was a Stonehenge monument on the stage that was in danger of being crushed by a dwarf.
-David St. Hubbins
|
|
|
|
|
http://www.planet-source-code.com/vb/scripts/ShowCode.asp?txtCodeId=1052&lngWId=10
This one is definately low level enough
seems it anyway
Public Class frmMain<br />
Inherits System.Windows.Forms.Form<br />
<br />
Declare Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" (ByVal idHook As Integer, ByVal lpfn As LowLevelKeyboardProcDelegate, ByVal hMod As Integer, ByVal dwThreadId As Integer) As Integer<br />
Declare Function UnhookWindowsHookEx Lib "user32" Alias "UnhookWindowsHookEx" (ByVal hHook As Integer) As Integer<br />
Delegate Function LowLevelKeyboardProcDelegate(ByVal nCode As Integer, ByVal wParam As Integer, ByRef lParam As KBDLLHOOKSTRUCT) As Integer<br />
Declare Function CallNextHookEx Lib "user32" Alias "CallNextHookEx" (ByVal hHook As Integer, ByVal nCode As Integer, ByVal wParam As Integer, ByRef lParam As KBDLLHOOKSTRUCT) As Integer<br />
<br />
Const WH_KEYBOARD_LL = 13<br />
<br />
Structure KBDLLHOOKSTRUCT<br />
Dim vkCode As Integer<br />
Dim scanCode As Integer<br />
Dim flags As Integer<br />
Dim time As Integer<br />
Dim dwExtraInfo As Integer<br />
End Structure<br />
<br />
Dim intLLKey As Integer<br />
<br />
#Region " Windows Form Designer generated code "<br />
<br />
Public Sub New()<br />
MyBase.New()<br />
<br />
'This call is required by the Windows Form Designer.<br />
InitializeComponent()<br />
<br />
'Add any initialization after the InitializeComponent() call<br />
<br />
End Sub<br />
<br />
'Form overrides dispose to clean up the component list.<br />
Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)<br />
If disposing Then<br />
If Not (components Is Nothing) Then<br />
components.Dispose()<br />
End If<br />
End If<br />
MyBase.Dispose(disposing)<br />
End Sub<br />
<br />
'Required by the Windows Form Designer<br />
Private components As System.ComponentModel.IContainer<br />
<br />
'NOTE: The following procedure is required by the Windows Form Designer<br />
'It can be modified using the Windows Form Designer. <br />
'Do not modify it using the code editor.<br />
<System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()<br />
Me.lblInfo = New System.Windows.Forms.Label()<br />
Me.SuspendLayout()<br />
'<br />
'lblInfo<br />
'<br />
Me.lblInfo.Location = New System.Drawing.Point(16, 16)<br />
Me.lblInfo.Name = "lblInfo"<br />
Me.lblInfo.Size = New System.Drawing.Size(216, 88)<br />
Me.lblInfo.TabIndex = 0<br />
Me.lblInfo.Text = "Alt-Tab, Alt-Esc, Ctrl-Esc, and the Windows key are disabled. Ctrl-Alt-Del and Al" & _<br />
"t-F4 are still enabled. Close the application to reset the keyboard. While this " & _<br />
"program is running, the low-level keyboard effect is global."<br />
'<br />
'frmMain<br />
'<br />
Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)<br />
Me.ClientSize = New System.Drawing.Size(248, 118)<br />
Me.Controls.AddRange(New System.Windows.Forms.Control() {Me.lblInfo})<br />
Me.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog<br />
Me.MaximizeBox = False<br />
Me.MinimizeBox = False<br />
Me.Name = "frmMain"<br />
Me.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen<br />
Me.Text = "LowLevel Keyboard Hook"<br />
Me.ResumeLayout(False)<br />
<br />
End Sub<br />
<br />
#End Region<br />
<br />
Private Sub frmMain_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load<br />
intLLKey = SetWindowsHookEx(WH_KEYBOARD_LL, AddressOf LowLevelKeyboardProc, System.Runtime.InteropServices.Marshal.GetHINSTANCE(System.Reflection.Assembly.GetExecutingAssembly.GetModules()(0)).ToInt32(), 0)<br />
End Sub<br />
<br />
Private Sub frmMain_Closing(ByVal sender As Object, ByVal e As System.ComponentModel.CancelEventArgs) Handles MyBase.Closing<br />
UnhookWindowsHookEx(intLLKey)<br />
End Sub<br />
<br />
Private Function LowLevelKeyboardProc(ByVal nCode As Integer, ByVal wParam As Integer, ByRef lParam As KBDLLHOOKSTRUCT) As Integer<br />
Dim blnEat As Boolean = False<br />
<br />
Select Case wParam<br />
Case 256, 257, 260, 261<br />
'Alt+Tab, Alt+Esc, Ctrl+Esc, Windows Key<br />
blnEat = ((lParam.vkCode = 9) AndAlso (lParam.flags = 32)) Or _<br />
((lParam.vkCode = 27) AndAlso (lParam.flags = 32)) Or _<br />
((lParam.vkCode = 27) AndAlso (lParam.flags = 0)) Or _<br />
((lParam.vkCode = 91) AndAlso (lParam.flags = 1)) Or _<br />
((lParam.vkCode = 92) AndAlso (lParam.flags = 1))<br />
End Select<br />
<br />
If blnEat = True Then<br />
Return 1<br />
Else<br />
Return CallNextHookEx(0, nCode, wParam, lParam)<br />
End If<br />
End Function<br />
Friend WithEvents lblInfo As System.Windows.Forms.Label<br />
End Class<br />
|
|
|
|
|
Hello folks,
I am new to windows .NET programing and was wondering how I could open a file with my application from the system context menu (open with...). My intuition told me that the specified file was probably encapsulated in the argument String array from my Main method, but my application craches when I try to do Explorer, right click on file -> Open with...-> MyApp.exe!
To resume: regular executing my exe works fine, opening my exe by open file with... (OS context menu) craches my application.
anybody knows how to do that ???
Thanks
|
|
|
|
|
Explorer passes the complete filename (including path) as the first argument to your entry point. You need to validate that an argument was provided and pass that to your main form when/after you instantiate it:
public class MainForm : Form
{
public static void Main(string[] args)
{
string filename = null;
if (args.Length > 0) filename = args[0];
Application.Run(new MainForm(filename));
}
public MainForm() : this(null)
{
}
private string filename;
public MainForm(string filename)
{
this.filename = filename;
}
public string Filename
{
get { return this.filename; }
set { this.filename = value; }
}
} Alternatively, you can use Environment.GetCommandLineArgs in your application somewhere to essentially do the same thing as was done in the Main entry point method.
Microsoft MVP, Visual C#
My Articles
|
|
|
|
|
how to draw an X axis by datetime data!
my problem is to deal with the datetime,and the coordinate convert!
Please give me a sample!
|
|
|
|