Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
467 / 344 / 19
Регистрация: 26.05.2009
Сообщений: 2,696
1

Получение клавиш нажатых не в своем приложении

17.07.2011, 18:39. Показов 2094. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Нужно сделать приложение, ведущее статистику нажатия клавиш (какая клавиша сколько раз нажималась). Подскажите, как ловить все нажатия клавиш на компьютере, а не только те, которые будут посланы событиями в моё приложение.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.07.2011, 18:39
Ответы с готовыми решениями:

Контроль нажатых клавиш в консольном приложении
Здравствуйте. Хотелось бы узнать, как реализовать контроль нажатых клавиш в КОНСОЛЬНОМ приложении?...

Распознавание нажатых клавиш при свёрнутом приложении
допустим что приложение было свёрнуто, как можно сделать так, чтобы оно разворачивалось при нажатии...

Отслеживание нажатых клавиш
Доброго дня! Придумал себе такую задачку: На форме есть кнопки которые стандартный юзер просто...

Подсчет нажатых клавиш
Нужно сделать программу, которая будет считать количество клавиш, которые нажимались. Отрывок...

8
Неадекват
1496 / 1233 / 247
Регистрация: 02.04.2010
Сообщений: 2,799
17.07.2011, 19:40 2
Кейлоггеры зло. А вообще хуки тебе в помощь.
1
467 / 344 / 19
Регистрация: 26.05.2009
Сообщений: 2,696
17.07.2011, 20:07  [ТС] 3
Если бы мне нужен был кейлогер - я бы скачал его (их в интернете горы на любой цвет фломастеров) и не сидел над кодом. Логично, да?
0
Заблокирован
17.07.2011, 20:10 4
Лучший ответ Сообщение было отмечено как решение

Решение

В инете все кейлогеры со своим трояном)))
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
 using System.Diagnostics;
    using System.Runtime.InteropServices;
 
    
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            Hook.StartHook();
            timer1.Enabled = true;
        }
 
        private void timer1_Tick(object sender, EventArgs e)
        {
            textBox1.Text = Hook.s;
        }
 
        private void Form1_FormClosing(object sender, FormClosingEventArgs e)
        {
            Hook.StopHook();
        }
    }
 
    static class Hook
    {
        [DllImport("user32.dll")]
        private static extern IntPtr SetWindowsHookEx(int idHook, LowLevel_KeyboardProc Ipfn, IntPtr hMod, uint dwThreadId);
        //IntPtr- целочисленный указатель на функцию, которая будет обработывать пользовательские хуки
        [DllImport("user32.dll")]
        private static extern IntPtr CallNextHookEx(IntPtr hhk, int nCode, IntPtr wParam, IntPtr lParam);
        [DllImport("user32.dll")]
        [return: MarshalAs(UnmanagedType.Bool)]
        private static extern bool UnhookWindowsHookEx(IntPtr hhk);
 
        private static IntPtr _hookId = IntPtr.Zero;
        private delegate IntPtr LowLevel_KeyboardProc(int nCode, IntPtr wParam, IntPtr lParam);
        private static LowLevel_KeyboardProc _proc = HookCallback;
        private const int WH_KEYBOARD_LL = 13;
        private const int WH_KEYDOWN = 0x0100;
 
        [DllImport("Kernel32.dll")]
        private static extern IntPtr GetModuleHandle(string lpModuleName);
 
        public static string s;
 
        private static IntPtr SetHook(LowLevel_KeyboardProc proc)
        {
            Process pr = Process.GetCurrentProcess();
            ProcessModule prM = pr.MainModule;
            return SetWindowsHookEx(WH_KEYBOARD_LL, proc, GetModuleHandle(prM.ModuleName), 0);
        }
        private static IntPtr HookCallback(int nCode, IntPtr wParam, IntPtr lParam)
        {
            if (nCode >= 0 && wParam == (IntPtr)WH_KEYDOWN)
            {
                int vkCode = Marshal.ReadInt32(lParam);
               
 
                    s += (Keys)vkCode;
               
 
            }
 
           
            return CallNextHookEx(_hookId, nCode, wParam, lParam);
        }
        public static void StartHook()
        {
            _hookId = SetHook(_proc);
        }
        public static void StopHook()
        {
            UnhookWindowsHookEx(_hookId);
        }
 
            
 
    }
Добавлено через 39 секунд
Переделай как тебе надо.
4
freeba
17.07.2011, 20:12
  #5

Не по теме:

Логично:D Основное применение этой фичи - глобальные горячие клавиши. Или написание злобных баннеров-блокировщиков растрясателей кошельков.:beach:

1
467 / 344 / 19
Регистрация: 26.05.2009
Сообщений: 2,696
17.07.2011, 23:21  [ТС] 6
change, если я правильно понимаю, то этот код по таймеру постоянно показывает получает последнюю нажатую клавишу. А как-то можно организовать, чтоб получать её по событию? Иначе я не буду знать сколько раз подряд была нажата одна и та же клавиша.
0
1274 / 975 / 113
Регистрация: 12.01.2010
Сообщений: 1,971
18.07.2011, 00:04 7
на codeproject лежат штук 5 хуков сделанных по всем правилам
ищутся по ключевым словам "keyboard hook" или "global hook" как ни странно )
1
Почетный модератор
Эксперт .NET
8722 / 3674 / 404
Регистрация: 14.06.2010
Сообщений: 4,513
Записей в блоге: 9
18.07.2011, 00:07 8
body90, вот на событиях. Там 2 события: KeyUp и KeyDown.
Главное установите LocalHook в false, иначе хук локальный будет.

m0nax, а сколько их тут уже лежит... )
1
Заблокирован
18.07.2011, 00:08 9
Цитата Сообщение от body90 Посмотреть сообщение
А как-то можно организовать, чтоб получать её по событию?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
using System;
using System.Collections.Generic;
//using System.ComponentModel;
//using System.Data;
//using System.Drawing;
using System.Linq;
//using System.Text;
using System.Windows.Forms;
 
namespace WindowsFormsApplication1
{
    using System.Diagnostics;
    using System.Runtime.InteropServices;
 
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            Hook.StartHook();
        }
        // введи символ клавиши на латинице в тестбокс и нажми кнопку 
        private void button1_Click(object sender, EventArgs e)
        {
            char[] ch = textBox1.Text.ToUpper().ToCharArray();
            var v = Hook.list.Where(c => c == (int)ch[0]).Count();
            MessageBox.Show( String.Format("Клавиша {0} была нажата {1} раз",ch[0],v ));
        }
 
        private void Form1_FormClosing(object sender, FormClosingEventArgs e)
        {
            Hook.StopHook();
        }
    }
    static class Hook
    {
        [DllImport("user32.dll")]
        private static extern IntPtr SetWindowsHookEx(int idHook, LowLevel_KeyboardProc Ipfn, IntPtr hMod, uint dwThreadId);
        //IntPtr- целочисленный указатель на функцию, которая будет обработывать пользовательские хуки
        [DllImport("user32.dll")]
        private static extern IntPtr CallNextHookEx(IntPtr hhk, int nCode, IntPtr wParam, IntPtr lParam);
        [DllImport("user32.dll")]
        [return: MarshalAs(UnmanagedType.Bool)]
        private static extern bool UnhookWindowsHookEx(IntPtr hhk);
 
        private static IntPtr _hookId = IntPtr.Zero;
        private delegate IntPtr LowLevel_KeyboardProc(int nCode, IntPtr wParam, IntPtr lParam);
        private static LowLevel_KeyboardProc _proc = HookCallback;
        private const int WH_KEYBOARD_LL = 13;
        private const int WH_KEYDOWN = 0x0100;
 
        [DllImport("Kernel32.dll")]
        private static extern IntPtr GetModuleHandle(string lpModuleName);
 
        //  public static string s;
 
        public static List<int> list = new List<int>();
 
        private static IntPtr SetHook(LowLevel_KeyboardProc proc)
        {
            Process pr = Process.GetCurrentProcess();
            ProcessModule prM = pr.MainModule;
            return SetWindowsHookEx(WH_KEYBOARD_LL, proc, GetModuleHandle(prM.ModuleName), 0);
        }
        private static IntPtr HookCallback(int nCode, IntPtr wParam, IntPtr lParam)
        {
            if (nCode >= 0 && wParam == (IntPtr)WH_KEYDOWN)
            {
                int vkCode = Marshal.ReadInt32(lParam);
 
 
                //   s += (Keys)vkCode;
 
                list.Add(vkCode);
 
            }
 
 
            return CallNextHookEx(_hookId, nCode, wParam, lParam);
        }
        public static void StartHook()
        {
            _hookId = SetHook(_proc);
        }
        public static void StopHook()
        {
            UnhookWindowsHookEx(_hookId);
        }
 
    }
 
}
1
18.07.2011, 00:08
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.07.2011, 00:08
Помогаю со студенческими работами здесь

Обработка нажатых клавиш
Проблема заключается в следующем: Нужно сменить цвет фона путём нажатия клавиши &quot;Enter&quot;, а также...

Отлавливание нажатых клавиш
Здравствуйте! Подскажите пожалуйста, как можно реализовать улавливание нажатых клавиш, когда моя...

Отсеивание нажатых клавиш
Доброго времени суток! Нужна срочно ваша помошь, дело вот в чем я написал универсальную программу...

Распознование нажатых клавиш
Всем добрый день. Народ, мне через 2 дня сдавать экзамен, а я практически по delphi ничего не знаю....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru