Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/9: Рейтинг темы: голосов - 9, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 11.11.2008
Сообщений: 30

Копирование содержимого EditBox в буфер по правой кнопке мыши (Excel)

17.01.2009, 09:33. Показов 2078. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как в Excele для EditBox-a сдлеать копирование в буфер по правой кнопке мыши? Имею ввиду, чтобы появлялось поп-ап меню с пунктами 'копировать, вырезать, вставить'.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.01.2009, 09:33
Ответы с готовыми решениями:

Клик правой кнопкой мыши по кнопке
Как вызвать событие клик правой кнопкой мыши по кнопке? private void btnCancel_MouseClick(object sender, MouseEventArgs e) { ...

Нажатие правой кнопой мыши по GUI кнопке
Всем привет! У меня возник такой вопрос: Можно ли реализовать нажатие правой кнопкой мыши по GUI кнопке? Если да, то как? :)

Как нажать правой клавишей мыши по кнопке?
Нужно отловить нажатие правой кнопки мыши на кнопке. Как это можно реализовать?

7
1 / 1 / 1
Регистрация: 29.12.2008
Сообщений: 108
18.01.2009, 13:01
Я когда-то реализовывал этот метод. Только один вопрос, где находится твой EditBox, на Worksheet или в UserForm.

Сергей
0
1 / 1 / 0
Регистрация: 11.11.2008
Сообщений: 30
18.01.2009, 15:35  [ТС]
В User_Form
0
1 / 1 / 1
Регистрация: 29.12.2008
Сообщений: 108
19.01.2009, 03:44
Переработал предыдущую версию. Вот, что получилось.

Создай новый модуль и вставляй туда этот Code:
Visual Basic
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
Option Explicit
Const PopUpCommandBarName As String = 'TemporaryPopupMenu'
Sub DeletePopUp()
    On Error Resume Next
    CommandBars(PopUpCommandBarName).Delete
    On Error GoTo 0
End Sub
Sub CreatePopUp()
Dim cb As CommandBar
DeletePopUp
Set cb = CommandBars.Add(PopUpCommandBarName, msoBarPopup, False, True)
With cb
With .Controls.Add(Type:=msoControlButton)
.OnAction = 'MyMacroCut'
.FaceId = 21
.Caption = 'Вырезать'
End With
With .Controls.Add(Type:=msoControlButton)
.OnAction = 'MyMacroCopy'
.FaceId = 19
.Caption = 'Копировать'
End With
With .Controls.Add(Type:=msoControlButton)
.OnAction = 'MyMacroPaste'
.FaceId = 22
.Caption = 'Вставить'
End With
End With
Set cb = Nothing
End Sub
Sub DisplayCustomPopUp()
Application.CommandBars(PopUpCommandBarName).ShowPopup
End Sub
Sub MyMacroCopy()
On Error Resume Next
UserForm5.ActiveControl.Copy
On Error GoTo 0
End Sub
Sub MyMacroPaste()
On Error Resume Next
UserForm5.ActiveControl.Paste
On Error GoTo 0
End Sub
Sub MyMacroCut()
On Error Resume Next
UserForm5.ActiveControl.Cut
On Error GoTo 0
End Sub
Теперь создай UserForm5 вместе с TextBox1 и TextBox2 и вставляй туда Code:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Option Explicit
Private Sub TextBox1_MouseUp(ByVal Button As Integer, ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single)
If Button = 2 Then
DisplayCustomPopUp
End If
End Sub
 
Private Sub TextBox2_MouseUp(ByVal Button As Integer, ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single)
If Button = 2 Then
DisplayCustomPopUp
End If
End Sub
 
Private Sub UserForm_Deactivate()
DeletePopUp
End Sub
 
Private Sub UserForm_Initialize()
CreatePopUp
End Sub
Если заработало - напиши.

Сергей
0
1 / 1 / 0
Регистрация: 11.11.2008
Сообщений: 30
19.01.2009, 09:59  [ТС]
Почти заработало - появляться то меню появляется, а копировать и вставлять - отказывается (
0
1 / 1 / 0
Регистрация: 11.11.2008
Сообщений: 30
19.01.2009, 10:17  [ТС]
О, вроде заработало - кое-какие тонкости в своем проекте - у меня на форме расположен multipage, поэтому он весь сам и являлся activecontrol-ом. Поэтому непонятно было откуда копировать. Но вроде поковырял - заработало. Огроменное спасибо!!!
0
1 / 1 / 0
Регистрация: 11.11.2008
Сообщений: 30
19.01.2009, 11:31  [ТС]
Если кому интересно, то решение было следующим (на крутизну не претендую):
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Sub MyMacroCopy()
On Error Resume Next
If InStr(UserForm5.ActiveControl.Name, 'MultiPage') > 0 Then
ControlName = UserForm5.ActiveControl.Name
  If InStr(UserForm5.Controls(ControlName).SelectedItem.ActiveControl.Name, 'Frame') > 0 Then
    FrameName = UserForm5.Controls(ControlName).SelectedItem.ActiveControl.Name
    UserForm5.Controls(ControlName).SelectedItem.Controls(FrameName).ActiveControl.Copy
  Else
    UserForm5.Controls(ControlName).SelectedItem.ActiveControl.Copy
  End If
Else
UserForm5.ActiveControl.Copy
End If
On Error GoTo 0
End Sub
аналогично для CUT и для PASTE
0
1 / 1 / 1
Регистрация: 29.12.2008
Сообщений: 108
19.01.2009, 13:57
OK

Сергей
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.01.2009, 13:57
Помогаю со студенческими работами здесь

Выход из спящего режима по правой кнопке мыши, отключить
При нажатии ПКМ компьютер "будится". Как это отключить? В диспетчере устройств галку "разрешить этому устройству вывожить...

Выполнять функцию при зажатой правой кнопке мыши
if (Key.isDown(Key.ESCAPE)) { /* */ } как сделать что так же, только заместо ескейта была правая кнопка мыши или левая? (PS возможно ли...

MouseMove при нажатой правой кнопке мыши и рамки в PictureBox
Как избежать изменения действия события pictureBox1_MouseMove при смене рамки изображения внутри процедуры pictureBox1_MouseDown или в...

Как по правой кнопке мыши выделить путь дерева в JTree
Как по правой кнопке мыши выделить путь дерева в JTree так ка это происходит по левой...

Изменение текста в кнопке щелчком правой кнопки мыши (Visual C++ 2010)
есть кнопка, к примеру b1. нужно сделать так чтоб после нажатия по ней правой кнопкой мыши менялся ее текст. что можно сделать?


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru