Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Welcome to Software Development on Codidact!

Will you help us build our independent community of developers helping developers? We're small and trying to grow. We welcome questions about all aspects of software development, from design to code to QA and more. Got questions? Got answers? Got code you'd like someone to review? Please join us.

Qt Button changes drastically when setting its `border-radius`.

+7
−0

In a Qt application I have nothing more than a window with a button as its direct child.

I set its background color and all is fine:

Window::Window(QWidget *parent) : QWidget(parent)
{
    button1 = new QPushButton(this);
    button1->setText("1234");
    button1->setStyleSheet("*{background:plum;}");
}

Button

But if I also set its border-radius,

Window::Window(QWidget *parent) : QWidget(parent)
{
    button1 = new QPushButton(this);
    button1->setText("1234");
    button1->setStyleSheet("*{background:plum;border-radius:0;}");
}

the button becomes different in other aspects, namely the background is not a gradient anymore, the border is gone and it is much smaller.

Button after zeroing border-radius

All I expected was for its shape to become rectangular.

What am I missing?

I consulted the Qt stylesheet reference, but that only added to my confusion, since it states that if not specified border-radius is (already) zero.

History
Why does this post require moderator attention?
You might want to add some details to your flag.
Why should this post be closed?

1 comment thread

Hint (1 comment)

1 answer

+7
−0

See this comment:

https://forum.qt.io/topic/60546/qpushbutton-default-windows-style-sheet#3

Stylesheets are a totally different beasts. The default native drawing doesn't use stylesheets. They are a way to override native style dependent painting with HTML-like drawing. Usually if you change one of the basic style elements like border or background Qt disables native painting entirely and falls back to a simple HTML box model. So in short you can't change just one property of a stylesheet and keep original native style painting. There are exceptions to that (e.g. changing text color), but that's what they are - exceptions. In general it's either stylesheets or native painting. Mixing is generally not possible and even if it has the desired result with one theme it might not with another.

You're probably using a native drawing style corresponding to your OS for the first button, which has an exception carved out for the background property but not for the border-radius, so the second button is switching to using the HTML-like style.

History
Why does this post require moderator attention?
You might want to add some details to your flag.

0 comment threads

Sign up to answer this question »