![]() |
Не работает скрипт смены цвета
Уважаемый пользователи портала,
Есть docm word 2010 c несколькими кнопками в нём(button,button2 итд). Как при наведении на конкретную active-кнопку(имя-button) указателем оптического манипулятора("мышь") произвести смену цвета,а при отведении-базовый цвет? Есть код-но он не работает. Благодарю Пример: Скрытый текст
For Each ИмяОбъекта In ИмяКоллекции Операции над объектами Next ИмяОбъекта В этом примере показано, как изменить свойство BackColor у всех этикеток (Label), лежащих на форме Код:
Dim x As Object Листинг Скрытый текст
Код:
Public Sub button_MouseMove(ByVal Button As Integer, ByVal Shift _ Файл Скрытый текст
|
Цитата:
|
Добавлено
|
Цитата:
Код:
Public Sub button_MouseMove(ByVal Button As Integer, ByVal Shift _ |
1)Код модуля работает-оставлен частично неработающий код,который не может привести к overflow у кого-либо.
Цитата:
(не знаю почему-подпрограмма "собрана"по образцу("Пример") |
Цитата:
Цитата:
|
Спасибо,
Элемент – это переменная, которая будет хранить значение при каждой итерации (переборе коллекции) Коллекция – собственно, то, что нам надо обработать.Коллекция – по своей природе этот тот же массив, но количество элементов в нем нам неизвестно(нет счётчика). Элемент должен принадлежать коллекции. Код переделан,но не работает Код:
Public Sub button_MouseMove(ByVal Button As Integer, ByVal Shift _ |
Цитата:
Подходящего события (типа указатель уходит за пределы вашей кнопки "control 2") я не увидел. Единственный (правда уж очень кривой, но уж какой есть) вариант могу предложить следующий: вставьте в документ элемент управления - рисунок, подложите его под вашу кнопку, размеры задайте чуть больше вашей кнопки чтобы рисунок образовывал некую окантовку (рамку). Событие, когда мышка находится над рисунком будет активировать код, который будет менять цвет вашей кнопки на исходный. То есть логика следующая: когда курсор прошелся над кнопкой - активируется код из поста №4. Если курсор уйдет с кнопки, он обязательно пройдет над рамкой (рисунком) и активирует код, приведенный в конце этого поста, который перекрасит кнопку в исходный цвет. К сожалению, ширину рамки нужно брать достаточно большую, иначе обработчик не всегда срабатывает при быстром перемещении мышки, но вы можете настроить цвет этой рамки (например - белый в цвет листа, или синий - в цвет скрываемого поля и ширину взять равной ширине поля), чтобы эта рамка не сильно бросалась в глаза. Для этого: во вкладке меню Word "Разработчик" (помнится по умолчанию отображение этой вкладки отключено, возможно придется включить в параметрах) предварительно отобразив ваше текстовое поле, нажмите кнопку "Режим конструктора". В этом же секторе вкладки "Разработчик" -> "Элементы управления" выбрать вставку элемента управления "Изображения" (вставится пустая рамка). Щелкнуть по рамке рисунка и выбрать "формат объекта" -> "положение" -> "За текстом". Переместить поле под кнопку, но так чтобы оно было над вашем текстовым полем (поле можно сдвинуть ниже). В режиме конструктор доступна кнопка "свойства", чтобы поменять например цвет рамки рисунка, фон и т.д. Высоту и ширину изображения подгоняете слегка побольше чем кнопка, чтобы получилась некая рамка, после чего отключаете режим конструктора. Необходимо вставить следующий код: Код
Код:
Private Sub Image1_MouseMove(ByVal Button As Integer, ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single) С любопытством ознакомлюсь с любым более "правильным" вариантом по возвращению кнопке исходного цвета. |
Цитата:
Так переделан-упрощён-не работает. -Dim ctr As Object почему? не др. тип данных VBA(ошибки,кроме Variant) Object-используется только для хранения ссылок на объекты. Требуемая память: 4 байта Данную переменную нельзя ,оказывается, глобально объявить(Public str),как другие в этом коде("перемен не объявлена") -For Each ctr In "Me.CommandBars" Вообще не понятно ,что такое коллекция me.X? Скрытый текст
Код
Код:
Sub button_MouseMove(ByVal Button As Integer, ByVal Shift _ |
victor21043, еще раз терпеливо вам объясняю:
1. чтобы менялся цвет при наведении на кнопку - используйте следующий код: Цитата:
Цитата:
4.По вашему вопросу - в вашем случае этого не нужно, но если хотите почитать: Цитата:
Оператор for... each. тип данных object. Вообще на ресурсе много полезного, можно почитать с начала. |
Не. Тут нужна большая хорошая книжка по VBA в целом и по каждой из объектных моделей — в частности. Каждая — страницы на 900-1500. Тогда будет толк и смысл.
|
Время: 22:06. |
Время: 22:06.
© OSzone.net 2001-