Как получить выделенный текст из других приложений и сохранить текст буфера обмена одновременно

c# .net clipboard

136 просмотра

2 ответа

Я пытаюсь получить выделенный текст из других приложений, используя следующие четыре строки, и у меня нет проблем с этим:

Thread.Sleep(20);
SendCtrlC(GetWindowUnderCursor());
Thread.Sleep(30);
label1.Text = Clipboard.GetText();

Моя проблема в том, что в то же время я хочу сохранить текст буфера обмена, потому что SendCtrlC(GetWindowUnderCursor());изменяет текст буфера обмена, для этого я использовал переменную, beforeподобную следующему коду:

string before = ""; //use before to keep clipboard text

//keep clipboard text
IDataObject iData = Clipboard.GetDataObject();
if (iData.GetDataPresent(DataFormats.Text))
before = ((String)iData.GetData(DataFormats.Text));

//get selected text
Thread.Sleep(20);
SendCtrlC(GetWindowUnderCursor());
Thread.Sleep(30);
label1.Text = Clipboard.GetText();

//return clipboard text back
Clipboard.SetText(before);

Но это не сохраняет текст и данные буфера обмена по-прежнему теряются ...
кто-то знает, в чем причина?

вот весь код:

using MouseKeyboardActivityMonitor;
using MouseKeyboardActivityMonitor.WinApi;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace WindowsFormsApplication1
{
    public partial class Form1 : Form
    {
        private readonly KeyboardHookListener m_KeyboardHookManager;
        private readonly MouseHookListener m_MouseHookManager;
        private bool ctrlHeld;
        string pressedKey;
        public Form1()
        {
            InitializeComponent();

            m_KeyboardHookManager = new KeyboardHookListener(new GlobalHooker());
            m_KeyboardHookManager.Enabled = true;
            m_KeyboardHookManager.KeyDown += HookManager_KeyDown;
            m_KeyboardHookManager.KeyUp += HookManager_KeyUp;

            m_MouseHookManager = new MouseHookListener(new GlobalHooker());
            m_MouseHookManager.Enabled = true;
            m_MouseHookManager.MouseDown += HookManager_MouseDown;
            m_MouseHookManager.MouseUp += HookManager_MouseUp;

        }

        private void HookManager_KeyDown(object sender, KeyEventArgs e)
        {
            pressedKey = e.KeyCode + "";
            if (pressedKey == "LControlKey")
            {
                ctrlHeld = true;
            }
        }

        private void HookManager_KeyUp(object sender, KeyEventArgs e)
        {
            pressedKey = e.KeyCode + "";
            if (pressedKey == "LControlKey")
            {
                ctrlHeld = false;
            }
        }

        private void HookManager_MouseUp(object sender, MouseEventArgs e)
        {
            if (e.Button == MouseButtons.Left && (ctrlHeld))
            {
                string before = "";

                IDataObject iData = Clipboard.GetDataObject();
                if (iData.GetDataPresent(DataFormats.Text))
                    before = ((String)iData.GetData(DataFormats.Text));

                Thread.Sleep(20);
                SendCtrlC(GetWindowUnderCursor());
                Thread.Sleep(30);
                label1.Text = Clipboard.GetText();

                Clipboard.SetText(before);

            }
        }


        private void HookManager_MouseDown(object sender, MouseEventArgs e)
        {

        }


        [DllImport("user32.dll")]
        public static extern IntPtr WindowFromPoint(Point lpPoint);

        [DllImport("user32.dll")]
        public static extern bool GetCursorPos(out Point lpPoint);

        public static IntPtr GetWindowUnderCursor()
        {
            Point ptCursor = new Point();

            if (!(Form1.GetCursorPos(out ptCursor)))
                return IntPtr.Zero;

            return WindowFromPoint(ptCursor);
        }

        /////////////////////////////////////////////////////////

        [DllImport("User32.dll")]
        private static extern bool SetForegroundWindow(IntPtr hWnd);

        [DllImport("user32.dll", CharSet = CharSet.Auto)]
        static public extern IntPtr GetForegroundWindow();

        [DllImport("user32.dll")]
        static extern void keybd_event(byte bVk, byte bScan, uint dwFlags, uint dwExtraInfo);

        private void SendCtrlC(IntPtr hWnd)
        {
            uint KEYEVENTF_KEYUP = 2;
            byte VK_CONTROL = 0x11;
            SetForegroundWindow(hWnd);
            keybd_event(VK_CONTROL, 0, 0, 0);
            keybd_event(0x43, 0, 0, 0); //Send the C key (43 is "C")
            keybd_event(0x43, 0, KEYEVENTF_KEYUP, 0);
            keybd_event(VK_CONTROL, 0, KEYEVENTF_KEYUP, 0);// 'Left Control Up

        }
    }
}
Автор: Hamreen Ahmad Источник Размещён: 08.11.2019 11:05

Ответы (2)


1 плюс

Решение

Попробуй это:

// Get previous selcetd text
string before = Clipboard.GetText(TextDataFormat.UnicodeText);

// Get the selected text
Thread.Sleep(20);
SendCtrlC(GetWindowUnderCursor());
Thread.Sleep(30);
label1.Text = Clipboard.GetText(TextDataFormat.UnicodeText);

// Set the clipboard text back to the original value.
Clipboard.SetDataObject(before, false, 10, 2000);
// Clipboard.SetDataObject(string value, ignore this, try changing the clipboard a few times, the delay inbetween trying to chnage it in milliseconds);
Автор: user6438653 Размещён: 20.08.2016 09:36

0 плюса

Не уверен в прямом пути для достижения - попробуйте этот обходной маршрут.

При отправке в SendCtrlC (GetWindowUnderCursor ()), почему вы не можете попробовать с SendCtrlC (GetWindowUnderCursor () + + Старые данные буфера обмена)

Непечатаемый символ - первые 31 символ ASCII не могут быть введены с клавиатуры

Считать данные из старого буфера обмена и объединить

Когда вы читаете данные, вы разделяете, используя тот же непечатаемый символ.

Автор: Barani Размещён: 20.08.2016 09:49
32x32