Как сделать треугольную кнопку в wpf
цель этого пошагового руководства — научиться создавать анимированную кнопку для использования в приложении Windows Presentation Foundation (WPF). В этом пошаговом руководстве используются стили и шаблон для создания настраиваемого ресурса кнопки, который позволяет повторно использовать код и разделение логики кнопки из объявления кнопки. Это пошаговое руководство написано полностью в XAML (XAML).
В этом пошаговом руководстве описано, как создать приложение, введя или скопировав и вставляя XAML (XAML) в Visual Studio. Если вы предпочитаете использовать конструктор для создания того же приложения, см. раздел Создание кнопки с помощью Microsoft Expression Blend.
На следующем рисунке показаны готовые кнопки.
Создание основных кнопок
Начнем с создания нового проекта и добавления нескольких кнопок в окно.
Создание нового проекта WPF и добавление в него кнопок
Запустите среду Visual Studio.
Создайте новый проект WPF: В меню файл наведите указатель мыши на пункт создатьи выберите пункт Project. найдите шаблон приложения Windows (WPF) и присвойте проекту имя "аниматедбуттон". Это приведет к созданию каркаса для приложения.
Добавить основные кнопки по умолчанию: Все файлы, необходимые для этого пошагового руководства, предоставляются шаблоном. Откройте файл Window1. XAML, дважды щелкнув его в обозреватель решений. По умолчанию Grid в Window1. XAML присутствует элемент. Удалите Grid элемент и добавьте несколько кнопок на страницу XAML (XAML), введя или скопировав и вставляя следующий выделенный код в Window1. XAML:
Нажмите клавишу F5, чтобы запустить приложение. Вы увидите набор кнопок, которые выглядят как на следующем рисунке.
Теперь, когда основные кнопки созданы, вы завершили работу в файле Window1. XAML. Остальная часть пошагового руководства посвящена файлу app. XAML, определяющему стили и шаблон для кнопок.
Задание основных свойств
Теперь давайте настроим некоторые свойства на этих кнопках, чтобы управлять внешним видом и макетом кнопки. Вместо того чтобы устанавливать свойства на кнопки по отдельности, вы будете использовать ресурсы для определения свойств кнопки для всего приложения. Ресурсы приложения концептуально похожи на внешние каскадные таблицы стилей (CSS) для веб-страниц. Тем не менее ресурсы являются гораздо более мощными, чем каскадные таблицы стилей (CSS), как вы увидите в конце этого пошагового руководства. Дополнительные сведения о ресурсах см. в разделе ресурсы XAML.
Использование стилей для задания основных свойств кнопок
Определите блок Application. Resources: Откройте App. XAML и добавьте следующую выделенную разметку, если она еще не существует:
Область ресурсов определяется местом, где определяется ресурс. Определение ресурсов в Application.Resources файле App. XAML позволяет использовать ресурс из любого места в приложении. Дополнительные сведения об определении области ресурсов см. в разделе ресурсы XAML.
Создайте стиль и определите в нем основные значения свойств: Добавьте в блок следующую разметку . Эта разметка создает объект Style , который применяется ко всем кнопкам в приложении, присвоив параметрам для Width кнопок значение 90 и значение Margin 10.
TargetTypeСвойство указывает, что стиль применяется ко всем объектам типа Button . Каждый Setter из них задает другое значение свойства для Style . Таким образом, на этом этапе каждая кнопка в приложении имеет ширину 90 и поле, равное 10. Если нажать клавишу F5 для запуска приложения, появится следующее окно.
С помощью стилей можно выполнять множество других задач, в том числе различные способы точной настройки объектов, указания сложных значений свойств и даже использования стилей в качестве входных данных для других стилей. Более подробную информацию см. в разделе Стилизация и использование шаблонов.
Задайте ресурсу значение свойства Style: Ресурсы обеспечивают простой способ повторного использования часто заданных объектов и значений. Особенно полезно определить сложные значения с помощью ресурсов, чтобы сделать код более модульным. Добавьте следующую выделенную разметку в App. XAML.
Нажмите клавишу F5 для запуска приложения. Это должно выглядеть примерно так.
Создание шаблона, определяющего вид кнопки
В этом разделе вы создадите шаблон, который настраивает внешний вид (представление) кнопки. Кнопка презентации состоит из нескольких объектов, включая прямоугольники и другие компоненты, чтобы дать кнопке уникальный вид.
До сих пор Управление тем, как выглядят кнопки в приложении, было ограничено изменением свойств кнопки. Что делать, если вы хотите внести более коренные изменения в внешний вид кнопки? Шаблоны обеспечивают мощный контроль над представлением объекта. Поскольку шаблоны можно использовать в стилях, можно применить шаблон ко всем объектам, к которым применяется стиль (в этом пошаговом руководстве это кнопка).
Использование шаблона для определения вида кнопки
Настройте шаблон: Так как элементы управления, такие как Template , имеют свойство, можно определить значение свойства шаблона так же, как и другие значения свойств, заданные в Style с помощью Setter . Добавьте следующую выделенную разметку в стиль кнопки.
Изменить представление кнопки: На этом этапе необходимо определить шаблон. Добавьте следующую выделенную разметку. Эта разметка определяет два Rectangle элемента с закругленными краями, за которыми следует DockPanel . DockPanelИспользуется для размещения ContentPresenter кнопки. ContentPresenterОтображает содержимое кнопки. В этом пошаговом руководстве содержимое является текстом ("Кнопка 1", "Кнопка 2", "Кнопка 3"). Все компоненты шаблона (прямоугольники и DockPanel ) размещаются внутри Grid .
Нажмите клавишу F5 для запуска приложения. Это должно выглядеть примерно так.
Добавьте глассеффект в шаблон: Далее вы добавите стекло. Сначала необходимо создать ресурсы, которые создают эффект прозрачного градиента. Добавьте эти ресурсы градиента в любом месте Application.Resources блока:
Эти ресурсы используются в качестве Fill для прямоугольника, который мы вставляем в Grid шаблон кнопки. Добавьте в шаблон следующую выделенную разметку.
Взаимодействие кнопки "создать"
В этом разделе вы создадите триггеры свойств и триггеры событий для изменения значений свойств и запуска анимации в ответ на действия пользователя, такие как перемещение указателя мыши над кнопкой и нажатие кнопки.
Простой способ добавления интерактивности (нажатие кнопки мыши, выхода из мыши, щелчка и т. д.) заключается в определении триггеров в шаблоне или стиле. Чтобы создать объект Trigger , определите свойство "Condition", например: IsMouseOver значение свойства кнопки равно true . Затем определяются методы задания (Actions), которые выполняются, когда условие триггера имеет значение true.
Создание интерактивной активности кнопки
Добавить триггеры шаблона: Добавьте выделенную разметку в шаблон.
Добавить триггеры свойств: Добавьте выделенную разметку в блок:
Нажмите клавишу F5, чтобы запустить приложение и увидеть результат при выполнении указателя мыши над кнопками.
Добавить триггер фокуса: Далее мы добавим несколько аналогичных методов задания, которые будут обработаны, когда кнопка будет иметь фокус (например, после того, как пользователь щелкнет его).
Нажмите клавишу F5, чтобы запустить приложение, и нажмите одну из кнопок. Обратите внимание, что кнопка остается выделенной после ее нажатия, так как она по-прежнему имеет фокус. Если щелкнуть другую кнопку, кнопка Создать получит фокус, а последний теряет ее.
Добавить анимацию для и : Далее мы добавим несколько анимаций к триггерам. Добавьте следующую разметку в любое место внутри ControlTemplate.Triggers блока.
Прозрачный прямоугольник сжимается при наведении указателя мыши на кнопку и возвращается к нормальному размеру, когда указатель покидает.
Существует две анимации, которые запускаются при наведении указателя мыши на кнопку ( MouseEnter событие вызывается). Эти анимации сжимают стеклянный прямоугольник вдоль осей X и Y. Обратите внимание на свойства DoubleAnimation элементов — Duration и By . DurationУказывает, что анимация выполняется в течение половины секунды и By указывает, что стекло сжимается на 10%.
Второй триггер события ( MouseLeave ) просто останавливает первый из них. Когда вы останавливаете Storyboard , все анимированные свойства возвращают значения по умолчанию. Таким образом, когда пользователь перемещает указатель мыши за пределы кнопки, кнопка возвращается к способу, который находился перед перемещением курсора по кнопке. Дополнительные сведения о анимациях см. в разделе Общие сведения об анимации.
Добавить анимацию при нажатии кнопки: Последним шагом является добавление триггера для, когда пользователь нажимает кнопку. Добавьте следующую разметку в любом месте ControlTemplate.Triggers блока:
Нажмите клавишу F5, чтобы запустить приложение, и нажмите одну из кнопок. При нажатии кнопки прозрачный прямоугольник вращается вокруг.
Сводка
В этом пошаговом руководстве вы выполнили следующие упражнения:
Нацелен на Style тип объекта ( Button ).
Контролируемые основные свойства кнопок во всем приложении, использующих Style .
Созданные ресурсы, такие как градиенты, используемые для значений свойств Style методов задания.
Настройка вида кнопок во всем приложении путем применения шаблона к кнопкам.
Настраиваемое поведение кнопок в ответ на действия пользователя (например,, MouseEnterMouseLeave и Click ), которые включают эффекты анимации.
Я хочу изменить кнопку, чтобы она имела форму эллипса. Я использую приложение wpf.
Я видел некоторые ответы, кто-то предлагал "прямолинейную" вещь, но я не получил ее. Также я не хочу добавлять изображение (это был ответ и на вопрос тоже).
Попробуйте следующее в XAML,
Предоставленный ответ верен, если вы планируете применить его к одной кнопке, но реальный вопрос, если вы хотите использовать один и тот же шаблон для нескольких кнопок, это будет проблемой. Для этого, пожалуйста, следуйте приведенному ниже методу
Приносим извинения. Запрошенное содержимое было удалено. Вы будете автоматически перенаправлены через 1 секунду.
Лучший отвечающий
Вопрос
Возникла новая проблемка. Нужна кнопка шестиугольной формы, с обводкой и плюс к этому с 80% прозрачностью. При наведении на которую курсора мыши, прозрачность с 80 уменьшается до 40, тот же эффект при отводе курсора. Никогда ничего подобного делать не приходилось, поэтому даже незнаю с чего начать и как такое возможно сделать. Помогите кто чем может
Ответы
Они не куда не делись просто принцип размещения не визуальных объектов стал другой. Конкретно по таймеру скажу так - лично мне проще использовать старый добрый из пространства имен Windows.Forms, так как он работает в основном потоке.
Добавляешь ссылку на System.Windows.Forms, в коде программы пишешь:
Dim tim As New Windows.Forms.Timer
Далее в событии загрузки формы задаешь начальные значеня и ссылку на событие таймера
Private Sub Window_Loaded(ByVal sender As System.Object, ByVal e As System.Windows.RoutedEventArgs) Handles MyBase.Loaded
tim.Interval = 1000 ' в милисекундах
AddHandler tim.Tick, AddressOf Tim_tic
tim.Start()
End Sub
И собственно сама процедура срабатывания таймера
Private Sub Tim_tic()
'Твой код
End Sub
Все ответы
И почему так мало литературы по Visual basic. Хоть какие нибудь книги были хорошие.
Нашел, за прозрачность отвечает Opacity. Осталось как то нарисовать шестигранник с Border и Color, отследить клик внутри него.
В принципе это можно реализовать с помощью картинки. Просто поместите на вашу форму picturebox, выставте свойства, чтобы она не рисовала бордеров. А картинку внутрь поставьте такую, какой должна быть кнопка.
Отслеживать наведение мыши можно через подписку на ивенты в picturebox - MouseEnter, MouseLeave, MouseClick. Ентер и Лив будут отвечать за изменение Опасити picturebox елемента. Или можно создать две картинки и просто заменять одну на другую в picturebox по указаных ивентах.
Если делать собственный контрол, а не имитацию, как предложил я, все будет сложнее.
Don't forget to mark the correct answer Blog
И еще одно - возможно есть смысл посмотреть в сторону WPF. Эта технология как раз предназначена для такого рода кнопок и всяких других рюшек. Don't forget to mark the correct answer Blog
Нет Картинка исключено. У нее квадратные границы, нужно именно 6 угольные. WPF это отдельное приложение, и на изучение, можно сказать, другого языка или синтаксиса времени не хватит. Мне кажется тут проще будет создать через Button.Paint. Используем Region и Draving2D.GraphicsPath, обрезаем кнопку. как, еще пока незнаю :) И в его обработчике Paint заливаем ее, например, серым цветом и рисуем 6-угольник как Border. Вроде бы так?
Все вроде бы отлично, получилась кнопка, но Opacity только для формы, а как сделать кнопку прозрачной?
Кнопки нестандартных форм прекрасно делаются в WPF. Вам уже предложили хороший вариант. Сделайте в любом графическом разработчике (Blend или Illustrator) нужную вам форму, затем под эту форму делаете изображение, и в стиле
Еще раз говорю, что мне кнопка с рисунком не нужна! WPF еще изучить нужно, и я незнаю можно ли созданную кнопку потом вставить в проэкт Windows Form. Уже шестиуголник есть. Осталось только его сделать прозрачным. Можете подсказать как? Без WPF! Я даже не представляю что это такое. По описанию чем то на HTML код похоже.
Если нет времени изучать WPF, то придется потратить время на поиск решения проблемы. В WinForm нет абсолютной прозрачности, поэтому приемы вроде тех что вам нужны реализовать очень сложно. Если такие задачи нужно будет решать часто, то все же потом или сейчас, но переходите на WPF, там это сделать за 5 минут можно. Лично я перешел на WPF за 3 месяца и с одной книгой и теперь меня обратно на WinForm ничем не загонишь!
Отличие WPF от WinForm в концепции, а принципы программирования и языки остаются те же.
В основе идеи шаблонов лежит концепция отделения функциональности от внешнего вида.
Посмотрите на вот этот рисунок:
Как видно на кнопке размещается CheckBox, картинка, набор RadioButton и даже еще одна кнопка! И все это, как не странно, работает. Достигается это за счет того, что основная масса компонентов имеет свойство Content, в рамках которого мы можем создавать практически любое наполнение. Основной недостаток, мы не можем переопределить саму базовую кнопку. Например, сделать ее треугольной или круглой, хотя цвет, размер и много другое изменить достаточно легко.
Для изменения всего способа отображения и используются шаблоны.
В WPF существует несколько видов шаблонов:
1. ControlTemplate - позволяет задавать шаблон для любого визуального компонента.
2. ItemsPanelTemplate - позволяет задавать шаблон компоновки для контейнеров.
3. DataTemplate - задает шаблоны отображения данных.
4. HierarchicalDataTemplate - задает шаблоны древовидных структур.
Рассмотрим самый простой случай ControlTemplate:
Как видно мы задаем новый стиль (строка 2), который переопределяет свойство Template - как раз тот самый шаблон (строка 7 и далее). Все остальное достаточно понятно, кроме наверно строки 17 где цвет задается не как конкретный цвет (напрмер - Red), а как переход к цвету подложки - Transparent. И конечно строка 21 в которой мы задаем, что в нашем шаблоне кнопки в качестве контента должно быть то, что помещено в контент кнопки к которой применен шаблон. В строках 24 и 25 задаются тригеры для изменения цвета кнопки при наведении мышки и при нажатии.
Вот так все это выглядит в обычном режиме, при наведении мышки и нажатии.
Кстати, попробуйте сделать круглую кнопку ;)
Читайте также: