Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
 Аватар для rediffusion
5 / 5 / 0
Регистрация: 13.11.2016
Сообщений: 90

Undo/Redo или CTRL+Z – CTRL+Y »» не работает для личных макросов

08.08.2019, 23:49. Показов 2878. Ответов 1

Студворк — интернет-сервис помощи студентам
Есть макросы по теме ··· заливка; цвет текста; вставить примечание. Для них не работает Undo/Redo (которые расположены на QAT) ни CTRL+Z – CTRL+Y.
Нашёл вот такие ссылки wellsr.com и jkp-ads.com там есть инфа, правда не понятно как это всё скомбинировать с моими всеми макросами!?

1. Пример XML+VBA реализация книги тут (макрос заливка цвета).
Один юзер предложил рабочий вариант! Вот только досадно то что у меня заливок для цвета много скажем 30-40. Как это всё адаптировать, мож переменную какую то вставить на место xSelection.Interior.Color :

Заметьте что это готовый рабочий вариант Undo/Redo! ↴↴↴ ↴↴↴ ↴↴↴

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
Sub CellColor()
Call CellColor_Do(0)
End Sub
 
Private Sub CellColor_Do(Undo As Integer)
Static xBook As Workbook, xSheet As Worksheet, xSelection As Range, xColor As Long
Const sName As String = "CellColor"
Const sUndo As String = "Undo Color in "
Const sRedo As String = "Redo Color in "
If Undo = 0 Then
    Set xBook = ActiveWorkbook
    Set xSheet = ActiveSheet
    Set xSelection = Selection
    xColor = Selection.Cells(1).Interior.Color
    xSelection.Show
    xSelection.Interior.Color = RGB(227, 38, 54)
    Application.OnUndo (sUndo + xSelection.Address(False, False)), (ThisWorkbook.Name + "!" + sName + "_Undo")
ElseIf xSelection Is Nothing Then
    Beep
Else
    xBook.Activate
    xSheet.Activate
    xSelection.Select
    xSelection.Show
    If Undo < 0 Then
        xSelection.Interior.Color = xColor
        Application.OnRepeat (sRedo + xSelection.Address(False, False)), (ThisWorkbook.Name + "!" + sName + "_Redo")
    Else
        xSelection.Interior.Color = RGB(227, 38, 54)
        Set xSelection = Nothing
    End If
End If
End Sub
 
Private Sub CellColor_Undo()
    Call CellColor_Do(-1)
End Sub
 
Private Sub CellColor_Redo()
    Call CellColor_Do(1)
End Sub
2. Есть ещё макрос к которому тоже хочу прикрутить:

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
Sub Note_FillColor_White()
Dim myComm As Comment
  If Not ActiveCell.Comment Is Nothing Then
    If MsgBox("Ячейка уже содержит примечание, удалить?", 4) - 7 Then
      ActiveCell.Comment.Delete
    Else: Exit Sub
    End If
  End If
 
Set myComm = ActiveCell.AddComment
    With myComm.Shape
      .Height = 110
      .Width = 200
      .Top = 55
      .AutoShapeType = 1             'форма
      .Fill.ForeColor.SchemeColor = 1 'заливка » Белый
      .Line.ForeColor.RGB = RGB(255, 0, 0)
      .DrawingObject.Font.Name = "Consolas"
      .DrawingObject.Font.FontStyle = "normal"
      .DrawingObject.Font.Size = 8
     End With
      'Эмулируем выбор пункта "Изменить `Заметку`"
       SendKeys "+{F2}"
End Sub
3. Ещё макрос (нужна прикрутка):

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
Sub CoverCommentIndicator(control As IRibbonControl)
    'www.contextures.com/xlcomments03.html
    Dim ws As Worksheet
    Dim cmt As Comment
    Dim lCmt As Long
    Dim rngCmt As Range
    Dim shpCmt As Shape
    Dim shpW As Double 'ширина формы
    Dim shpH As Double 'высота формы
    
    Set ws = ActiveSheet
    shpW = 8
    shpH = 6
    lCmt = 1
    
    For Each cmt In ws.Comments
      Set rngCmt = cmt.Parent
      With rngCmt
        Set shpCmt = ws.Shapes.AddShape(msoShapeRectangle, _
          rngCmt.Offset(0, 1).Left - shpW, .Top, shpW, shpH)
      End With
      With shpCmt
        .Name = "CmtNum" & .Name
        With .Fill
          .ForeColor.SchemeColor = 9 'Цвет заливки
          .Visible = msoTrue
          .Solid
        End With
        With .Line
          .Visible = msoTrue
          .ForeColor.SchemeColor = 64 'Цвет обводки, задаётся автоматически для всех индикаторов!
          .Weight = 0.25 'Толщина обводки, задаётся автоматически для всех индикаторов!
        End With
        With .TextFrame
          .Characters.Text = lCmt
          .Characters.Font.Size = 5 'Размер текста
          .Characters.Font.ColorIndex = xlAutomatic
          .MarginLeft = 0#
          .MarginRight = 0#
          .MarginTop = 0#
          .MarginBottom = 0#
          .HorizontalAlignment = xlCenter 'Расположение текста (в данном случае в центре).
        End With
        .Top = .Top + 0.001 'Расположение рамки (в данном случае справа).
      End With
      lCmt = lCmt + 1
    Next cmt
End Sub
На самом деле макросов то у меня много (возможно если понять как прикрутить Undo/Redo к этим маросам - то можно будет понять формулу и в дальнейшем самому адаптировать).
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.08.2019, 23:49
Ответы с готовыми решениями:

Не работает UNDO (Ctrl+Z) в Builder
Например создаю новый проект. На форму накидываю кнопку. Перемещаю её по форме. Хочу што бы она встала обратно(сделать откат нажав ctrl+z)....

Не работает ctrl+c, ctrl+v, ctrl+a, ctrl+x в ubuntu 12.04
Здравствуйте, не работают такие горячие клавиши, может кто уже стыкался з данной проблемой. Как можно устранить такое?

Не работает буфер обмена (Ctrl+C, Ctrl+V) в Visual Studio 2015
Всем привет! Во время работы часто приходится многократно копировать-вставлять код, но возникла проблема: если скопировать код одной...

1
 Аватар для rediffusion
5 / 5 / 0
Регистрация: 13.11.2016
Сообщений: 90
10.08.2019, 10:41  [ТС]
Утро доброе Россияне!

По этому вопросу есть тема.

Первый макрос на мой взгляд самый подходящий. Заметил минусы:
1. Ctrl+Y - не робит.
2. Ctr+Z - только на 1 шаг. А ещё стирает ячейку (то есть полоски/обводка самой ячейки)!
3. Если заливать несколько ячеек (мультиселект) - заливка не чёрная а разная у каждой ячейки (чёрная только первая). Ещё ячейки нумеруются 1, 2, 3 и т. д. (чтобы это значило)!?
4. Второй вариант вобще не торт, квас какой то.

5. @Сергей - кста, поделился хорошей идеей!

Есть какие идеи как это всё накатать на VBA?

Выше макрос которым я поделился оказался лучше... Имеются те же нюансы а из плюсов:
Мультизаливка работает как надо. Нет никакой нумерации.

Наткнулся на вот такую надстройку Ablebits называеься, (пробный период если то с оф. сайта качать ну а ещё всегда есть кряк тут и тута). Имеется свой бэкап Книги:





Я им писал - (они там косят под американцев но я то знаю что там русские сидят) тоже говорят что у них нет доступа к каким то внутренним ресурсам Excel и поэтому реализовали для своих личных макросов такой `BackUP`. Используя кнопки в этой надстройке, заметил что Ctrl+Z где то робит где то нет. Не смотря на то что смастерили драконскую надстройку а Ctrl+Z реализовать не получилось.

---------------------------

Ещё на БУРЖ ресурсе прочитал такое:
Фактически, запуск макроса полностью стирает список отмены, и поэтому вы не можете автоматически отменить эффекты запуска макроса. Нет встроенной команды в Excel или в VBA для сохранения списка отмены.
Есть у кого какие идеи по реализации вот таких вариантов бэкапа:
1. Описанный @Сергей -ем.
2. Ablebits бэкап.
3. Ну или пользоваться стандартным методом, а это - DELETE; удаление чего либо посредством "Context Menu"; Всегда делать копию Книги для отката.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.08.2019, 10:41
Помогаю со студенческими работами здесь

Как отловить нажатие ctrl+v ctrl+c ctrl+x key_Press
Как правильно отловить нажатие ctrl+v ctrl+c ctrl+x в событии key_Press? я пробую так: private void textBox_ServerIP_KeyPress(object...

JTextPane, функции Ctrl+A, Ctrl+C, Ctrl+X перенести на кнопку
Класс JTextPane поддерживает нажатие клавиш таких как Ctrl+A, Ctrl+C, Ctrl+X и т. д. Вопрос заключается в том, чтобы функции, которые...

Не работает ctrl+c,ctrl+v в русской раскладке
Обновился до qt 5.4.0. В widgets перестали работать ctrl+c,ctrl+v при активной русской раскладки. Это как то исправляется, кроме как...

Как сделать сочетание ctrl+z и ctrl+y в виде кнопки для textbox?
Как сделать сочетание ctrl+z и ctrl+y в виде кнопки для textbox? Стандартное сочетание клавиш (ctrl+z или ctrl+y ) работает в поле...

Не работает ctrl+c ctrl+v ubuntu 14.10
Не работает ctrl+c ctrl+v ubuntu 14.10


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru