Закругленные края в кнопке C # (WinForms)
Привет, через некоторые исследования вокруг здесь и других сайтов, я сделал кнопку закругленных краев.
protected override void OnPaint(PaintEventArgs e) { base.OnPaint(e); Rectangle Rect = new Rectangle(0, 0, this.Width, this.Height); GraphicsPath GraphPath = new GraphicsPath(); GraphPath.AddArc(Rect.X, Rect.Y, 50, 50, 180, 90); GraphPath.AddArc(Rect.X + Rect.Width - 50, Rect.Y, 50, 50, 270, 90); GraphPath.AddArc(Rect.X + Rect.Width - 50, Rect.Y + Rect.Height - 50, 50, 50, 0, 90); GraphPath.AddArc(Rect.X, Rect.Y + Rect.Height - 50, 50, 50, 90, 90); this.Region = new Region(GraphPath); }
Проблема, с которой я сталкиваюсь, – это «синяя подсветка» кнопки: она отображается на большинстве кнопок, но она не отображается на закругленных краях, поэтому моя кнопка подсвечена и частично не выделена (по краям). Что я могу сделать, чтобы решить эту проблему? Спасибо.
- как изменить фоновое изображение кнопки при нажатии / фокусировке?
- Как использовать jQuery для отображения / скрытия divs на основе выбора переключателя?
- Как изменить цвет кнопки при наведении?
- Прикрепите параметр к действию button.addTarget в Swift
- Рисование прозрачной кнопки
PS: Я не могу использовать WPF. Приложение предназначено для очень старого компьютера; поэтому, пожалуйста, не предлагайте это. Кроме того, у клиента нет денег, чтобы получить новый компьютер.
- swift: как получить indexpath.row при нажатии кнопки в ячейке?
- Кнопка мультитач для работы с Android
- Добавить массив кнопок в GridView в приложении для Android
- Android: Использование findViewById () со строкой / в цикле
- Как эффективно использовать cardlayout в java для переключения с панели с помощью кнопок внутри различных панельных конструкторов
- Добавить параметр в событие Click Button
- Как добавить динамический переключатель в соответствии с заданным количеством отсчетов?
- Переопределить домашнюю и обратную кнопку - это случай, когда логическое значение true
Это быстрый, вы можете настроить мелодию и оптимизировать несколько деталей.
class RoundedButton : Button { GraphicsPath GetRoundPath(RectangleF Rect, int radius) { float r2 = radius / 2f; GraphicsPath GraphPath = new GraphicsPath(); GraphPath.AddArc(Rect.X, Rect.Y, radius, radius, 180, 90); GraphPath.AddLine(Rect.X + r2, Rect.Y, Rect.Width - r2, Rect.Y); GraphPath.AddArc(Rect.X + Rect.Width - radius, Rect.Y, radius, radius, 270, 90); GraphPath.AddLine(Rect.Width, Rect.Y + r2, Rect.Width, Rect.Height - r2); GraphPath.AddArc(Rect.X + Rect.Width - radius, Rect.Y + Rect.Height - radius, radius, radius, 0, 90); GraphPath.AddLine(Rect.Width - r2, Rect.Height, Rect.X + r2, Rect.Height); GraphPath.AddArc(Rect.X, Rect.Y + Rect.Height - radius, radius, radius, 90, 90); GraphPath.AddLine(Rect.X, Rect.Height - r2, Rect.X, Rect.Y + r2); GraphPath.CloseFigure(); return GraphPath; } protected override void OnPaint(PaintEventArgs e) { base.OnPaint(e); RectangleF Rect = new RectangleF(0, 0, this.Width, this.Height); GraphicsPath GraphPath = GetRoundPath(Rect, 50); this.Region = new Region(GraphPath); using (Pen pen = new Pen(Color.CadetBlue, 1.75f)) { pen.Alignment = PenAlignment.Inset; e.Graphics.DrawPath(pen, GraphPath); } } }
Очевидно, что, поскольку у нас есть class, мы можем кэшировать GraphicsPath
в переменной classа. И, конечно, вы выбираете цвет ..
Вы можете использовать WebBrowser, сделать кнопку с HTML и CSS, а затем использовать webbrowser.DocumentText = "your html";
Если не рисовать, я не думаю, что вы можете что-то сделать. Логика рисования базовой кнопки не написана как «показать синюю подсветку вокруг такой-то части любой области windows». Вместо этого он написан с типом региона, который он ожидает – прямоугольным. Поэтому базовая краска всегда рисует прямоугольное изображение в обрезанной форме. У вас будет более легкое время для таких вещей в WPF.