How do I get a bigger static scrollbar (aka normal scrollbar)?
I'm glad the outside overlay scrollbars are finally gone.
But the scrollbar is still a razor thin line that becomes a less razor thin scrollbar, but still thin scrollbar, when the mouse hovers.
How can I get a normal scrollbar? I.e., like in other OSes, like in Firefox, a scrollbar that doesn't change depending on what the mouse points to, and with a nice width.
I already tried
gsettings set com.canonical.desktop.interface scrollbar-mode normal
but no luck.
scrollbar
add a comment |
I'm glad the outside overlay scrollbars are finally gone.
But the scrollbar is still a razor thin line that becomes a less razor thin scrollbar, but still thin scrollbar, when the mouse hovers.
How can I get a normal scrollbar? I.e., like in other OSes, like in Firefox, a scrollbar that doesn't change depending on what the mouse points to, and with a nice width.
I already tried
gsettings set com.canonical.desktop.interface scrollbar-mode normal
but no luck.
scrollbar
how is this still a dang issue and not fix/part of standard system settings? lordy four years ago i rage quite ubuntu over stuff like this and went to mintier pastures...lol
– neuronet
Nov 12 '17 at 16:26
@neuronet Amen, brother
– Steve Cohen
May 6 '18 at 2:47
add a comment |
I'm glad the outside overlay scrollbars are finally gone.
But the scrollbar is still a razor thin line that becomes a less razor thin scrollbar, but still thin scrollbar, when the mouse hovers.
How can I get a normal scrollbar? I.e., like in other OSes, like in Firefox, a scrollbar that doesn't change depending on what the mouse points to, and with a nice width.
I already tried
gsettings set com.canonical.desktop.interface scrollbar-mode normal
but no luck.
scrollbar
I'm glad the outside overlay scrollbars are finally gone.
But the scrollbar is still a razor thin line that becomes a less razor thin scrollbar, but still thin scrollbar, when the mouse hovers.
How can I get a normal scrollbar? I.e., like in other OSes, like in Firefox, a scrollbar that doesn't change depending on what the mouse points to, and with a nice width.
I already tried
gsettings set com.canonical.desktop.interface scrollbar-mode normal
but no luck.
scrollbar
scrollbar
edited Jan 24 '18 at 9:46
muru
1
1
asked May 20 '16 at 14:16
SimonSimon
307139
307139
how is this still a dang issue and not fix/part of standard system settings? lordy four years ago i rage quite ubuntu over stuff like this and went to mintier pastures...lol
– neuronet
Nov 12 '17 at 16:26
@neuronet Amen, brother
– Steve Cohen
May 6 '18 at 2:47
add a comment |
how is this still a dang issue and not fix/part of standard system settings? lordy four years ago i rage quite ubuntu over stuff like this and went to mintier pastures...lol
– neuronet
Nov 12 '17 at 16:26
@neuronet Amen, brother
– Steve Cohen
May 6 '18 at 2:47
how is this still a dang issue and not fix/part of standard system settings? lordy four years ago i rage quite ubuntu over stuff like this and went to mintier pastures...lol
– neuronet
Nov 12 '17 at 16:26
how is this still a dang issue and not fix/part of standard system settings? lordy four years ago i rage quite ubuntu over stuff like this and went to mintier pastures...lol
– neuronet
Nov 12 '17 at 16:26
@neuronet Amen, brother
– Steve Cohen
May 6 '18 at 2:47
@neuronet Amen, brother
– Steve Cohen
May 6 '18 at 2:47
add a comment |
5 Answers
5
active
oldest
votes
Edit this file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
Look for this line (around line 1200): -GtkRange-slider-width: 10;
And change 10 to a bigger number like 20 or 30, and done :)
I also think they're too small...
See this image:
If you change the scrollbar size to 16 and you want them to stay that way, and not shrink when you don't have the mouse on it, then make the changes in the picture above.
If you use a size other than 16, just experiment with the margin sizes to get it right.
1
I set it to 16, and commented all the hover/drag stuff and now the scrollbars are good old static ones ... They are still disappearing after a few seconds though. Is there some animation function I didn't saw ?
– Simon
May 20 '16 at 15:31
Ok, so right below where you made the first change you'll see these:margin-left: 2px;
as well asmargin-right
andmargin-top
. Change all three of these from 2px to 7px and your scrollbars will stay wide.
– Dorian
May 20 '16 at 18:12
I added a pic to my answer to try to make it clear what you need to change in order for the scrollbars to stay large.
– Dorian
May 20 '16 at 18:33
5
Thank you so much! My grandfather was really struggling with the very small scroll bars, but I changed it to 25px and now he's scrolling like a pro!
– Erty Seidohl
Dec 1 '16 at 22:54
1
Note I changed mine to 24, and 7px was still the right size to use for the margins to make sure it stayed correct on hover. Note also be sure to restart your program (e.g., Firefox) to make sure your changes take effect. Great thing.
– neuronet
Nov 12 '17 at 16:48
|
show 3 more comments
I think you should be cautious there. Many of us will NOT recommend you edit the system-wide defaults for a theme, unless you really do intend to interfere with the activity of all user accounts in the system. If you happen to make an error while doing that, then it affects all user accounts. Another point of caution is that when packages are updated, your changes will be erased.
Another shortcoming of this strategy is that it only changes the behavior of one GTK theme, but you might want to change the scrollbar size in ALL GTK-3.0 themes.
Instead, edit configuration files inside a user account. The trick is to figure out which one is the shortest distance to the desired endpoint. The GTK file you edit is part of a CSS (Cascading Style Sheets) setup, so the customization you put in your account will modify the settings.
In your user account, in the folder ~/.config/gtk-3.0/gtk.css I currently have this in a file called "gtk.css"
.scrollbar {
-GtkScrollbar-has-backward-stepper: true;
-GtkScrollbar-has-forward-stepper: true;
-GtkRange-slider-width: 20;
-GtkRange-stepper-size: 20;
}
If you play around with this a little bit, you'll find it is possible to integrate many specific changes from the theme file you were editing above. At one time I tried very hard to fiddle lots of settings, but I'm in the "keep it simple" mode now.
If you really do want to edit a lot of settings, the right thing to do is to COPY the whole gtk-widgets.css file and put it in your ~/.config/gtk-3.0 folder. Then go to town fiddling with settings.
In the same folder, I have a file named "settings.ini"
[Settings]
gtk-primary-button-warps-slider = false
This prevents a click in the scrollbar from moving to a certain point in the file, instead it advances just one screen. I prefer that!
The other thing worth knowing is that changing that theme file (either as previously recommended by @Dorian or by a user account change for all GTK-3.0 based themes as I suggest) only changes programs that are based on the GTK-3.0 toolkit. It does not change the scrollbar for all applications. It is only for the ones that read that gtk-3.0 config file. Since you are editing a gtk-3.0 theme, apps written with QT or gtk-2.0 will not change. Hence, changing the scrollbar size of all programs is rather more difficult/tedious than you might expect.
I have changed the scrollbar width in gtk-2.0 as well. This is done in
a separate folder ~/.config/gtk-2.0. The file to create is named
gtkrc
style "scroll"
{
GtkScrollbar::slider-width = 20
}
Note that gtk-2.0 is a differently designed setup so the syntax is different, you can't just copy the gtk-3.0 css into the gtk-2.0 folder.
I have noticed that some applications behave badly when you make the scrollbar different because the size of the "grabber" inside the slider trough is not resized correctly. I suspect the scrollbar-dragging changes in @Dorian's file would help with that. I may come back and try that. I'll let you know.
Summary: The key "old time Linux system administrator advice is" DON'T edit config files on a system-wide basis. You are putting your system at risk, your changes won't last across revisions, and it requires root access, which is never good for cosmetic things like this. Find a way to make changes in your user account.
PS. If you really you want to fiddle around with system files (sometimes I do if I really want to insist all users have my favorite football team colors as their wallpaper and color scheme :) ), the first thing you should do is make a copy of the original file and name the original "gtk-widgets.css.orig". Then when you edit your file, save a copy of your edit as "gtk-widgets.css.20160919", where I have the YYYYMMDD date on the end of it. This way, when the deb package is updated, you'll have a copy of your edited file. The one you edit named gtk-widgets.css will be obliterated by package installation.
add a comment |
Here are the steps to restore the scrollbars which don't disappear and have permanent width, i.e. "classic" ones. Tested in GNOME Flashback session in Ubuntu 16.04 (works in Unity, too).
Step 1. Make a backup of /etc/environment
. Run sudo nano /etc/environment
and add there the next line:
GTK_OVERLAY_SCROLLING=0
This will prevent scrollbar's autohide behavior.
Step 2. In order to avoid tampering with the main theme file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
we'll borrow some code from there, alter it and put it into user profile folder. Create ~/.config/gtk-3.0/gtk.css
and put the next lines into it:
/* Adding the buttons on the edges (if you don't need them, skip the next 4 lines)
*/
.scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
/* Scrollbar trough squeezes when cursor hovers over it. Disabling that
*/
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical.dragging:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical.dragging:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal.dragging,
.scrollbar.horizontal.slider:hover,
.scrollbar.horizontal.slider.dragging {
margin-top: 0px;
}
/* Slider widens to fill the scrollbar when cursor hovers over it. Making it permanent
*/
.scrollbar.slider.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.slider.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.slider.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
Step 3. Create ~/.config/gtk-3.0/settings.ini
and add the next lines into it:
[Settings]
gtk-primary-button-warps-slider = false
This will restore page-by-page scrolling behavior when you click the scrollbar on the either side of the slider. If this file already exists, just add the last line in the [Settings]
section of it.
Step 4. Uninstall overlay-scrollbar
and overlay-scrollbar-gtk2
packages - you won't need them anymore.
P.S. If you use some applications which need superuser rights (i.e. Synaptic, gksudo etc.) then you should also place these gtk.css
and settings.ini
files into the root's profile folder:
sudo cp ~/.config/gtk-3.0/gtk.css /root/.config/gtk-3.0/
sudo cp ~/.config/gtk-3.0/settings.ini /root/.config/gtk-3.0/
P.P.S. If you find that these scrollbars are too narrow for you, make them broader. Just add the next line to your ~/.config/gtk-3.0/gtk.css
:
.scrollbar {
-GtkRange-slider-width: 15;
}
Increase the width as you see fit (the default is 10). Update /root/.config/gtk-3.0/gtk.css
also, if needed.
I was able to increase the width with the only item:.scrollbar {-GtkRange-slider-width: 15; …
, without all the other options you mentioned. But this was only on a virtual machine. When I tried to do the same on a desktop, nothing worked, though I had tried all of the steps. There is, I suppose a bug in Firefox 52, because on the virtual machine, where the answer helped, the scroll bar reacted correctly for the hover event, and widened automatically. On the desktop it does not handle hovers (which is actually the reason, why I need to widen the scrollbar) and the gtk.css is ignored too
– user907860
Mar 11 '17 at 18:09
1
@user907860 Quite the contrary, all the steps mentioned above are intended to ignore the hover event completely. They are needed to make static, permanent scrollbars which never change their width, as it was in pre-Unity era.
– whtyger
Mar 13 '17 at 7:01
yes, you are correct. I meant just increase of the width, without touching the hover functionality
– user907860
Mar 13 '17 at 15:26
by the way, don't you have any idea, why this does not work in Firefox 52 on a desktop, while it does on a virtual machine? askubuntu.com/questions/892097/…
– user907860
Mar 13 '17 at 15:28
1
This should be the accepted answer. Messing with dconf and themes gave very weird results - not overlay, but not normal either. This answer gives normal scrollbars. It has to be done at the GTK level. Note: Ubunutu is moving to Qt soon.
– Dominic Cerisano
Aug 2 '17 at 7:30
|
show 2 more comments
Changing -GtkRange-slider-width
has no effect on the default GTK+3 theme. Instead, you can do this:
scrollbar slider {
/* Size of the slider */
min-width: 20px;
min-height: 20px;
border-radius: 22px;
/* Padding around the slider */
border: 5px solid transparent;
}
(Place the above in ~/.config/gtk-3.0/gtk.css
.)
1
where should I add it?
– kenn
Oct 28 '17 at 10:37
@kenn~/.config/gtk-3.0/gtk.css
– Vladimir Panteleev
Oct 28 '17 at 16:25
1
Works like a charm on Ubuntu 18.04. Thanks!
– Steve Cohen
May 6 '18 at 22:25
9 months later: This does work like a charm under Ubuntu 18.04 - EXCEPT that it confuses the heck out of the GNUCash application. See lists.gnucash.org/pipermail/gnucash-user/2019-February/…. Making these changes destroys scrollbar functionality in GNUCash, but not other apps. Sigh.
– Steve Cohen
Feb 5 at 21:37
@SteveCohen, I looked at the gnucash link. You wrote "~/.config/gtk-3.0.gtk.css" but it should be~/.config/gtk-3.0/gtk.css
. Also, gnucash appears to be a gtk2 application, not a gtk3 application.
– DK Bose
Feb 6 at 0:44
add a comment |
I'm using Ubuntu 18.04 and this was the only solution that changed the scrollbar for EVERYTHING, from Firefox to LibreOffice to gnome-terminal. The solutions above worked fine for one or two applications but not for everything.
Note: this gives you REALLY big scrollbars which are good for large monitors because you can see them out of the corner of your eye without looking all the way over to the side of the screen every time you want to grab one. If you want smaller ones, change all the 70px's to a smaller number like 20px or 30px and tweak accordingly.
Put the following text into ~/.config/gtk-3.0/gtk.css
:
.scrollbar,
scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
scrollbar slider {
background-color: @scrollbar_track_color;
}
.scrollbar.vertical slider,
scrollbar.vertical slider {
min-height: 150px;
min-width: 70px;
}
.scrollbar.horizontal.slider,
scrollbar.horizontal slider {
min-width: 40px;
min-height: 10px;
}
.scrollbar.vertical.slider:hover,
scrollbar.vertical:hover slider {
min-width: 70px;
}
.scrollbar.horizontal.slider:hover,
scrollbar.horizontal:hover slider {
min-height: 10px;
}
.scrollbar.contents,
scrollbar contents {
background-color: transparent;
background-image: none;
background-size: 0;
border: none;
border-radius: 0;
}
.scrollbar.trough,
scrollbar trough {
background-image: none;
border: none;
}
.scrollbar:hover:backdrop,
.scrollbar.dragging:backdrop,
scrollbar:hover:backdrop,
scrollbar.dragging:backdrop {
background-color: alpha(@backdrop_selected_bg_color, 0.5);
}
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical:active:dir(ltr),
scrollbar.vertical:hover:dir(ltr),
scrollbar.vertical:active:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical:active:dir(rtl),
scrollbar.vertical:hover:dir(rtl),
scrollbar.vertical:active:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal:active,
scrollbar.horizontal:hover,
scrollbar.horizontal:active {
margin-top: 0px;
}
.scrollbar.slider,
scrollbar slider {
background-color: alpha(@backdrop_filling_bg, 0.75);
border-radius: 10px;
}
.scrollbar.slider:hover,
.scrollbar.slider:active,
scrollbar slider:hover,
scrollbar slider:active {
border-radius: 20px;
margin: 0;
}
.scrollbar.vertical:dir(ltr):not(:hover):not(.dragging),
scrollbar.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.vertical:dir(rtl):not(:hover):not(.dragging),
scrollbar.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.horizontal:not(:hover):not(.dragging),
scrollbar.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
.scrollbar.slider:hover,
scrollbar slider:hover {
background-color: alpha(@backdrop_filling_bg, 0.6);
}
.scrollbar.slider:active,
scrollbar slider:active {
background-color: @backdrop_filling_bg;
}
.scrollbar.slider:backdrop,
scrollbar slider:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.75);
}
.scrollbar.slider:hover:backdrop,
scrollbar slider:hover:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.6;
}
.scrollbar.slider:active:backdrop,
scrollbar slider:active:backdrop {
background-color: @backdrop_filling_bg;
}
scrollbar {
min-width: 70px;
min-height: 70px;
}
add a comment |
Your Answer
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "89"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2faskubuntu.com%2fquestions%2f775201%2fhow-do-i-get-a-bigger-static-scrollbar-aka-normal-scrollbar%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
5 Answers
5
active
oldest
votes
5 Answers
5
active
oldest
votes
active
oldest
votes
active
oldest
votes
Edit this file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
Look for this line (around line 1200): -GtkRange-slider-width: 10;
And change 10 to a bigger number like 20 or 30, and done :)
I also think they're too small...
See this image:
If you change the scrollbar size to 16 and you want them to stay that way, and not shrink when you don't have the mouse on it, then make the changes in the picture above.
If you use a size other than 16, just experiment with the margin sizes to get it right.
1
I set it to 16, and commented all the hover/drag stuff and now the scrollbars are good old static ones ... They are still disappearing after a few seconds though. Is there some animation function I didn't saw ?
– Simon
May 20 '16 at 15:31
Ok, so right below where you made the first change you'll see these:margin-left: 2px;
as well asmargin-right
andmargin-top
. Change all three of these from 2px to 7px and your scrollbars will stay wide.
– Dorian
May 20 '16 at 18:12
I added a pic to my answer to try to make it clear what you need to change in order for the scrollbars to stay large.
– Dorian
May 20 '16 at 18:33
5
Thank you so much! My grandfather was really struggling with the very small scroll bars, but I changed it to 25px and now he's scrolling like a pro!
– Erty Seidohl
Dec 1 '16 at 22:54
1
Note I changed mine to 24, and 7px was still the right size to use for the margins to make sure it stayed correct on hover. Note also be sure to restart your program (e.g., Firefox) to make sure your changes take effect. Great thing.
– neuronet
Nov 12 '17 at 16:48
|
show 3 more comments
Edit this file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
Look for this line (around line 1200): -GtkRange-slider-width: 10;
And change 10 to a bigger number like 20 or 30, and done :)
I also think they're too small...
See this image:
If you change the scrollbar size to 16 and you want them to stay that way, and not shrink when you don't have the mouse on it, then make the changes in the picture above.
If you use a size other than 16, just experiment with the margin sizes to get it right.
1
I set it to 16, and commented all the hover/drag stuff and now the scrollbars are good old static ones ... They are still disappearing after a few seconds though. Is there some animation function I didn't saw ?
– Simon
May 20 '16 at 15:31
Ok, so right below where you made the first change you'll see these:margin-left: 2px;
as well asmargin-right
andmargin-top
. Change all three of these from 2px to 7px and your scrollbars will stay wide.
– Dorian
May 20 '16 at 18:12
I added a pic to my answer to try to make it clear what you need to change in order for the scrollbars to stay large.
– Dorian
May 20 '16 at 18:33
5
Thank you so much! My grandfather was really struggling with the very small scroll bars, but I changed it to 25px and now he's scrolling like a pro!
– Erty Seidohl
Dec 1 '16 at 22:54
1
Note I changed mine to 24, and 7px was still the right size to use for the margins to make sure it stayed correct on hover. Note also be sure to restart your program (e.g., Firefox) to make sure your changes take effect. Great thing.
– neuronet
Nov 12 '17 at 16:48
|
show 3 more comments
Edit this file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
Look for this line (around line 1200): -GtkRange-slider-width: 10;
And change 10 to a bigger number like 20 or 30, and done :)
I also think they're too small...
See this image:
If you change the scrollbar size to 16 and you want them to stay that way, and not shrink when you don't have the mouse on it, then make the changes in the picture above.
If you use a size other than 16, just experiment with the margin sizes to get it right.
Edit this file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
Look for this line (around line 1200): -GtkRange-slider-width: 10;
And change 10 to a bigger number like 20 or 30, and done :)
I also think they're too small...
See this image:
If you change the scrollbar size to 16 and you want them to stay that way, and not shrink when you don't have the mouse on it, then make the changes in the picture above.
If you use a size other than 16, just experiment with the margin sizes to get it right.
edited May 20 '16 at 18:30
answered May 20 '16 at 14:41
DorianDorian
5,76511439
5,76511439
1
I set it to 16, and commented all the hover/drag stuff and now the scrollbars are good old static ones ... They are still disappearing after a few seconds though. Is there some animation function I didn't saw ?
– Simon
May 20 '16 at 15:31
Ok, so right below where you made the first change you'll see these:margin-left: 2px;
as well asmargin-right
andmargin-top
. Change all three of these from 2px to 7px and your scrollbars will stay wide.
– Dorian
May 20 '16 at 18:12
I added a pic to my answer to try to make it clear what you need to change in order for the scrollbars to stay large.
– Dorian
May 20 '16 at 18:33
5
Thank you so much! My grandfather was really struggling with the very small scroll bars, but I changed it to 25px and now he's scrolling like a pro!
– Erty Seidohl
Dec 1 '16 at 22:54
1
Note I changed mine to 24, and 7px was still the right size to use for the margins to make sure it stayed correct on hover. Note also be sure to restart your program (e.g., Firefox) to make sure your changes take effect. Great thing.
– neuronet
Nov 12 '17 at 16:48
|
show 3 more comments
1
I set it to 16, and commented all the hover/drag stuff and now the scrollbars are good old static ones ... They are still disappearing after a few seconds though. Is there some animation function I didn't saw ?
– Simon
May 20 '16 at 15:31
Ok, so right below where you made the first change you'll see these:margin-left: 2px;
as well asmargin-right
andmargin-top
. Change all three of these from 2px to 7px and your scrollbars will stay wide.
– Dorian
May 20 '16 at 18:12
I added a pic to my answer to try to make it clear what you need to change in order for the scrollbars to stay large.
– Dorian
May 20 '16 at 18:33
5
Thank you so much! My grandfather was really struggling with the very small scroll bars, but I changed it to 25px and now he's scrolling like a pro!
– Erty Seidohl
Dec 1 '16 at 22:54
1
Note I changed mine to 24, and 7px was still the right size to use for the margins to make sure it stayed correct on hover. Note also be sure to restart your program (e.g., Firefox) to make sure your changes take effect. Great thing.
– neuronet
Nov 12 '17 at 16:48
1
1
I set it to 16, and commented all the hover/drag stuff and now the scrollbars are good old static ones ... They are still disappearing after a few seconds though. Is there some animation function I didn't saw ?
– Simon
May 20 '16 at 15:31
I set it to 16, and commented all the hover/drag stuff and now the scrollbars are good old static ones ... They are still disappearing after a few seconds though. Is there some animation function I didn't saw ?
– Simon
May 20 '16 at 15:31
Ok, so right below where you made the first change you'll see these:
margin-left: 2px;
as well as margin-right
and margin-top
. Change all three of these from 2px to 7px and your scrollbars will stay wide.– Dorian
May 20 '16 at 18:12
Ok, so right below where you made the first change you'll see these:
margin-left: 2px;
as well as margin-right
and margin-top
. Change all three of these from 2px to 7px and your scrollbars will stay wide.– Dorian
May 20 '16 at 18:12
I added a pic to my answer to try to make it clear what you need to change in order for the scrollbars to stay large.
– Dorian
May 20 '16 at 18:33
I added a pic to my answer to try to make it clear what you need to change in order for the scrollbars to stay large.
– Dorian
May 20 '16 at 18:33
5
5
Thank you so much! My grandfather was really struggling with the very small scroll bars, but I changed it to 25px and now he's scrolling like a pro!
– Erty Seidohl
Dec 1 '16 at 22:54
Thank you so much! My grandfather was really struggling with the very small scroll bars, but I changed it to 25px and now he's scrolling like a pro!
– Erty Seidohl
Dec 1 '16 at 22:54
1
1
Note I changed mine to 24, and 7px was still the right size to use for the margins to make sure it stayed correct on hover. Note also be sure to restart your program (e.g., Firefox) to make sure your changes take effect. Great thing.
– neuronet
Nov 12 '17 at 16:48
Note I changed mine to 24, and 7px was still the right size to use for the margins to make sure it stayed correct on hover. Note also be sure to restart your program (e.g., Firefox) to make sure your changes take effect. Great thing.
– neuronet
Nov 12 '17 at 16:48
|
show 3 more comments
I think you should be cautious there. Many of us will NOT recommend you edit the system-wide defaults for a theme, unless you really do intend to interfere with the activity of all user accounts in the system. If you happen to make an error while doing that, then it affects all user accounts. Another point of caution is that when packages are updated, your changes will be erased.
Another shortcoming of this strategy is that it only changes the behavior of one GTK theme, but you might want to change the scrollbar size in ALL GTK-3.0 themes.
Instead, edit configuration files inside a user account. The trick is to figure out which one is the shortest distance to the desired endpoint. The GTK file you edit is part of a CSS (Cascading Style Sheets) setup, so the customization you put in your account will modify the settings.
In your user account, in the folder ~/.config/gtk-3.0/gtk.css I currently have this in a file called "gtk.css"
.scrollbar {
-GtkScrollbar-has-backward-stepper: true;
-GtkScrollbar-has-forward-stepper: true;
-GtkRange-slider-width: 20;
-GtkRange-stepper-size: 20;
}
If you play around with this a little bit, you'll find it is possible to integrate many specific changes from the theme file you were editing above. At one time I tried very hard to fiddle lots of settings, but I'm in the "keep it simple" mode now.
If you really do want to edit a lot of settings, the right thing to do is to COPY the whole gtk-widgets.css file and put it in your ~/.config/gtk-3.0 folder. Then go to town fiddling with settings.
In the same folder, I have a file named "settings.ini"
[Settings]
gtk-primary-button-warps-slider = false
This prevents a click in the scrollbar from moving to a certain point in the file, instead it advances just one screen. I prefer that!
The other thing worth knowing is that changing that theme file (either as previously recommended by @Dorian or by a user account change for all GTK-3.0 based themes as I suggest) only changes programs that are based on the GTK-3.0 toolkit. It does not change the scrollbar for all applications. It is only for the ones that read that gtk-3.0 config file. Since you are editing a gtk-3.0 theme, apps written with QT or gtk-2.0 will not change. Hence, changing the scrollbar size of all programs is rather more difficult/tedious than you might expect.
I have changed the scrollbar width in gtk-2.0 as well. This is done in
a separate folder ~/.config/gtk-2.0. The file to create is named
gtkrc
style "scroll"
{
GtkScrollbar::slider-width = 20
}
Note that gtk-2.0 is a differently designed setup so the syntax is different, you can't just copy the gtk-3.0 css into the gtk-2.0 folder.
I have noticed that some applications behave badly when you make the scrollbar different because the size of the "grabber" inside the slider trough is not resized correctly. I suspect the scrollbar-dragging changes in @Dorian's file would help with that. I may come back and try that. I'll let you know.
Summary: The key "old time Linux system administrator advice is" DON'T edit config files on a system-wide basis. You are putting your system at risk, your changes won't last across revisions, and it requires root access, which is never good for cosmetic things like this. Find a way to make changes in your user account.
PS. If you really you want to fiddle around with system files (sometimes I do if I really want to insist all users have my favorite football team colors as their wallpaper and color scheme :) ), the first thing you should do is make a copy of the original file and name the original "gtk-widgets.css.orig". Then when you edit your file, save a copy of your edit as "gtk-widgets.css.20160919", where I have the YYYYMMDD date on the end of it. This way, when the deb package is updated, you'll have a copy of your edited file. The one you edit named gtk-widgets.css will be obliterated by package installation.
add a comment |
I think you should be cautious there. Many of us will NOT recommend you edit the system-wide defaults for a theme, unless you really do intend to interfere with the activity of all user accounts in the system. If you happen to make an error while doing that, then it affects all user accounts. Another point of caution is that when packages are updated, your changes will be erased.
Another shortcoming of this strategy is that it only changes the behavior of one GTK theme, but you might want to change the scrollbar size in ALL GTK-3.0 themes.
Instead, edit configuration files inside a user account. The trick is to figure out which one is the shortest distance to the desired endpoint. The GTK file you edit is part of a CSS (Cascading Style Sheets) setup, so the customization you put in your account will modify the settings.
In your user account, in the folder ~/.config/gtk-3.0/gtk.css I currently have this in a file called "gtk.css"
.scrollbar {
-GtkScrollbar-has-backward-stepper: true;
-GtkScrollbar-has-forward-stepper: true;
-GtkRange-slider-width: 20;
-GtkRange-stepper-size: 20;
}
If you play around with this a little bit, you'll find it is possible to integrate many specific changes from the theme file you were editing above. At one time I tried very hard to fiddle lots of settings, but I'm in the "keep it simple" mode now.
If you really do want to edit a lot of settings, the right thing to do is to COPY the whole gtk-widgets.css file and put it in your ~/.config/gtk-3.0 folder. Then go to town fiddling with settings.
In the same folder, I have a file named "settings.ini"
[Settings]
gtk-primary-button-warps-slider = false
This prevents a click in the scrollbar from moving to a certain point in the file, instead it advances just one screen. I prefer that!
The other thing worth knowing is that changing that theme file (either as previously recommended by @Dorian or by a user account change for all GTK-3.0 based themes as I suggest) only changes programs that are based on the GTK-3.0 toolkit. It does not change the scrollbar for all applications. It is only for the ones that read that gtk-3.0 config file. Since you are editing a gtk-3.0 theme, apps written with QT or gtk-2.0 will not change. Hence, changing the scrollbar size of all programs is rather more difficult/tedious than you might expect.
I have changed the scrollbar width in gtk-2.0 as well. This is done in
a separate folder ~/.config/gtk-2.0. The file to create is named
gtkrc
style "scroll"
{
GtkScrollbar::slider-width = 20
}
Note that gtk-2.0 is a differently designed setup so the syntax is different, you can't just copy the gtk-3.0 css into the gtk-2.0 folder.
I have noticed that some applications behave badly when you make the scrollbar different because the size of the "grabber" inside the slider trough is not resized correctly. I suspect the scrollbar-dragging changes in @Dorian's file would help with that. I may come back and try that. I'll let you know.
Summary: The key "old time Linux system administrator advice is" DON'T edit config files on a system-wide basis. You are putting your system at risk, your changes won't last across revisions, and it requires root access, which is never good for cosmetic things like this. Find a way to make changes in your user account.
PS. If you really you want to fiddle around with system files (sometimes I do if I really want to insist all users have my favorite football team colors as their wallpaper and color scheme :) ), the first thing you should do is make a copy of the original file and name the original "gtk-widgets.css.orig". Then when you edit your file, save a copy of your edit as "gtk-widgets.css.20160919", where I have the YYYYMMDD date on the end of it. This way, when the deb package is updated, you'll have a copy of your edited file. The one you edit named gtk-widgets.css will be obliterated by package installation.
add a comment |
I think you should be cautious there. Many of us will NOT recommend you edit the system-wide defaults for a theme, unless you really do intend to interfere with the activity of all user accounts in the system. If you happen to make an error while doing that, then it affects all user accounts. Another point of caution is that when packages are updated, your changes will be erased.
Another shortcoming of this strategy is that it only changes the behavior of one GTK theme, but you might want to change the scrollbar size in ALL GTK-3.0 themes.
Instead, edit configuration files inside a user account. The trick is to figure out which one is the shortest distance to the desired endpoint. The GTK file you edit is part of a CSS (Cascading Style Sheets) setup, so the customization you put in your account will modify the settings.
In your user account, in the folder ~/.config/gtk-3.0/gtk.css I currently have this in a file called "gtk.css"
.scrollbar {
-GtkScrollbar-has-backward-stepper: true;
-GtkScrollbar-has-forward-stepper: true;
-GtkRange-slider-width: 20;
-GtkRange-stepper-size: 20;
}
If you play around with this a little bit, you'll find it is possible to integrate many specific changes from the theme file you were editing above. At one time I tried very hard to fiddle lots of settings, but I'm in the "keep it simple" mode now.
If you really do want to edit a lot of settings, the right thing to do is to COPY the whole gtk-widgets.css file and put it in your ~/.config/gtk-3.0 folder. Then go to town fiddling with settings.
In the same folder, I have a file named "settings.ini"
[Settings]
gtk-primary-button-warps-slider = false
This prevents a click in the scrollbar from moving to a certain point in the file, instead it advances just one screen. I prefer that!
The other thing worth knowing is that changing that theme file (either as previously recommended by @Dorian or by a user account change for all GTK-3.0 based themes as I suggest) only changes programs that are based on the GTK-3.0 toolkit. It does not change the scrollbar for all applications. It is only for the ones that read that gtk-3.0 config file. Since you are editing a gtk-3.0 theme, apps written with QT or gtk-2.0 will not change. Hence, changing the scrollbar size of all programs is rather more difficult/tedious than you might expect.
I have changed the scrollbar width in gtk-2.0 as well. This is done in
a separate folder ~/.config/gtk-2.0. The file to create is named
gtkrc
style "scroll"
{
GtkScrollbar::slider-width = 20
}
Note that gtk-2.0 is a differently designed setup so the syntax is different, you can't just copy the gtk-3.0 css into the gtk-2.0 folder.
I have noticed that some applications behave badly when you make the scrollbar different because the size of the "grabber" inside the slider trough is not resized correctly. I suspect the scrollbar-dragging changes in @Dorian's file would help with that. I may come back and try that. I'll let you know.
Summary: The key "old time Linux system administrator advice is" DON'T edit config files on a system-wide basis. You are putting your system at risk, your changes won't last across revisions, and it requires root access, which is never good for cosmetic things like this. Find a way to make changes in your user account.
PS. If you really you want to fiddle around with system files (sometimes I do if I really want to insist all users have my favorite football team colors as their wallpaper and color scheme :) ), the first thing you should do is make a copy of the original file and name the original "gtk-widgets.css.orig". Then when you edit your file, save a copy of your edit as "gtk-widgets.css.20160919", where I have the YYYYMMDD date on the end of it. This way, when the deb package is updated, you'll have a copy of your edited file. The one you edit named gtk-widgets.css will be obliterated by package installation.
I think you should be cautious there. Many of us will NOT recommend you edit the system-wide defaults for a theme, unless you really do intend to interfere with the activity of all user accounts in the system. If you happen to make an error while doing that, then it affects all user accounts. Another point of caution is that when packages are updated, your changes will be erased.
Another shortcoming of this strategy is that it only changes the behavior of one GTK theme, but you might want to change the scrollbar size in ALL GTK-3.0 themes.
Instead, edit configuration files inside a user account. The trick is to figure out which one is the shortest distance to the desired endpoint. The GTK file you edit is part of a CSS (Cascading Style Sheets) setup, so the customization you put in your account will modify the settings.
In your user account, in the folder ~/.config/gtk-3.0/gtk.css I currently have this in a file called "gtk.css"
.scrollbar {
-GtkScrollbar-has-backward-stepper: true;
-GtkScrollbar-has-forward-stepper: true;
-GtkRange-slider-width: 20;
-GtkRange-stepper-size: 20;
}
If you play around with this a little bit, you'll find it is possible to integrate many specific changes from the theme file you were editing above. At one time I tried very hard to fiddle lots of settings, but I'm in the "keep it simple" mode now.
If you really do want to edit a lot of settings, the right thing to do is to COPY the whole gtk-widgets.css file and put it in your ~/.config/gtk-3.0 folder. Then go to town fiddling with settings.
In the same folder, I have a file named "settings.ini"
[Settings]
gtk-primary-button-warps-slider = false
This prevents a click in the scrollbar from moving to a certain point in the file, instead it advances just one screen. I prefer that!
The other thing worth knowing is that changing that theme file (either as previously recommended by @Dorian or by a user account change for all GTK-3.0 based themes as I suggest) only changes programs that are based on the GTK-3.0 toolkit. It does not change the scrollbar for all applications. It is only for the ones that read that gtk-3.0 config file. Since you are editing a gtk-3.0 theme, apps written with QT or gtk-2.0 will not change. Hence, changing the scrollbar size of all programs is rather more difficult/tedious than you might expect.
I have changed the scrollbar width in gtk-2.0 as well. This is done in
a separate folder ~/.config/gtk-2.0. The file to create is named
gtkrc
style "scroll"
{
GtkScrollbar::slider-width = 20
}
Note that gtk-2.0 is a differently designed setup so the syntax is different, you can't just copy the gtk-3.0 css into the gtk-2.0 folder.
I have noticed that some applications behave badly when you make the scrollbar different because the size of the "grabber" inside the slider trough is not resized correctly. I suspect the scrollbar-dragging changes in @Dorian's file would help with that. I may come back and try that. I'll let you know.
Summary: The key "old time Linux system administrator advice is" DON'T edit config files on a system-wide basis. You are putting your system at risk, your changes won't last across revisions, and it requires root access, which is never good for cosmetic things like this. Find a way to make changes in your user account.
PS. If you really you want to fiddle around with system files (sometimes I do if I really want to insist all users have my favorite football team colors as their wallpaper and color scheme :) ), the first thing you should do is make a copy of the original file and name the original "gtk-widgets.css.orig". Then when you edit your file, save a copy of your edit as "gtk-widgets.css.20160919", where I have the YYYYMMDD date on the end of it. This way, when the deb package is updated, you'll have a copy of your edited file. The one you edit named gtk-widgets.css will be obliterated by package installation.
answered Sep 20 '16 at 2:03
pauljohn32pauljohn32
2,374924
2,374924
add a comment |
add a comment |
Here are the steps to restore the scrollbars which don't disappear and have permanent width, i.e. "classic" ones. Tested in GNOME Flashback session in Ubuntu 16.04 (works in Unity, too).
Step 1. Make a backup of /etc/environment
. Run sudo nano /etc/environment
and add there the next line:
GTK_OVERLAY_SCROLLING=0
This will prevent scrollbar's autohide behavior.
Step 2. In order to avoid tampering with the main theme file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
we'll borrow some code from there, alter it and put it into user profile folder. Create ~/.config/gtk-3.0/gtk.css
and put the next lines into it:
/* Adding the buttons on the edges (if you don't need them, skip the next 4 lines)
*/
.scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
/* Scrollbar trough squeezes when cursor hovers over it. Disabling that
*/
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical.dragging:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical.dragging:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal.dragging,
.scrollbar.horizontal.slider:hover,
.scrollbar.horizontal.slider.dragging {
margin-top: 0px;
}
/* Slider widens to fill the scrollbar when cursor hovers over it. Making it permanent
*/
.scrollbar.slider.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.slider.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.slider.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
Step 3. Create ~/.config/gtk-3.0/settings.ini
and add the next lines into it:
[Settings]
gtk-primary-button-warps-slider = false
This will restore page-by-page scrolling behavior when you click the scrollbar on the either side of the slider. If this file already exists, just add the last line in the [Settings]
section of it.
Step 4. Uninstall overlay-scrollbar
and overlay-scrollbar-gtk2
packages - you won't need them anymore.
P.S. If you use some applications which need superuser rights (i.e. Synaptic, gksudo etc.) then you should also place these gtk.css
and settings.ini
files into the root's profile folder:
sudo cp ~/.config/gtk-3.0/gtk.css /root/.config/gtk-3.0/
sudo cp ~/.config/gtk-3.0/settings.ini /root/.config/gtk-3.0/
P.P.S. If you find that these scrollbars are too narrow for you, make them broader. Just add the next line to your ~/.config/gtk-3.0/gtk.css
:
.scrollbar {
-GtkRange-slider-width: 15;
}
Increase the width as you see fit (the default is 10). Update /root/.config/gtk-3.0/gtk.css
also, if needed.
I was able to increase the width with the only item:.scrollbar {-GtkRange-slider-width: 15; …
, without all the other options you mentioned. But this was only on a virtual machine. When I tried to do the same on a desktop, nothing worked, though I had tried all of the steps. There is, I suppose a bug in Firefox 52, because on the virtual machine, where the answer helped, the scroll bar reacted correctly for the hover event, and widened automatically. On the desktop it does not handle hovers (which is actually the reason, why I need to widen the scrollbar) and the gtk.css is ignored too
– user907860
Mar 11 '17 at 18:09
1
@user907860 Quite the contrary, all the steps mentioned above are intended to ignore the hover event completely. They are needed to make static, permanent scrollbars which never change their width, as it was in pre-Unity era.
– whtyger
Mar 13 '17 at 7:01
yes, you are correct. I meant just increase of the width, without touching the hover functionality
– user907860
Mar 13 '17 at 15:26
by the way, don't you have any idea, why this does not work in Firefox 52 on a desktop, while it does on a virtual machine? askubuntu.com/questions/892097/…
– user907860
Mar 13 '17 at 15:28
1
This should be the accepted answer. Messing with dconf and themes gave very weird results - not overlay, but not normal either. This answer gives normal scrollbars. It has to be done at the GTK level. Note: Ubunutu is moving to Qt soon.
– Dominic Cerisano
Aug 2 '17 at 7:30
|
show 2 more comments
Here are the steps to restore the scrollbars which don't disappear and have permanent width, i.e. "classic" ones. Tested in GNOME Flashback session in Ubuntu 16.04 (works in Unity, too).
Step 1. Make a backup of /etc/environment
. Run sudo nano /etc/environment
and add there the next line:
GTK_OVERLAY_SCROLLING=0
This will prevent scrollbar's autohide behavior.
Step 2. In order to avoid tampering with the main theme file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
we'll borrow some code from there, alter it and put it into user profile folder. Create ~/.config/gtk-3.0/gtk.css
and put the next lines into it:
/* Adding the buttons on the edges (if you don't need them, skip the next 4 lines)
*/
.scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
/* Scrollbar trough squeezes when cursor hovers over it. Disabling that
*/
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical.dragging:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical.dragging:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal.dragging,
.scrollbar.horizontal.slider:hover,
.scrollbar.horizontal.slider.dragging {
margin-top: 0px;
}
/* Slider widens to fill the scrollbar when cursor hovers over it. Making it permanent
*/
.scrollbar.slider.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.slider.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.slider.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
Step 3. Create ~/.config/gtk-3.0/settings.ini
and add the next lines into it:
[Settings]
gtk-primary-button-warps-slider = false
This will restore page-by-page scrolling behavior when you click the scrollbar on the either side of the slider. If this file already exists, just add the last line in the [Settings]
section of it.
Step 4. Uninstall overlay-scrollbar
and overlay-scrollbar-gtk2
packages - you won't need them anymore.
P.S. If you use some applications which need superuser rights (i.e. Synaptic, gksudo etc.) then you should also place these gtk.css
and settings.ini
files into the root's profile folder:
sudo cp ~/.config/gtk-3.0/gtk.css /root/.config/gtk-3.0/
sudo cp ~/.config/gtk-3.0/settings.ini /root/.config/gtk-3.0/
P.P.S. If you find that these scrollbars are too narrow for you, make them broader. Just add the next line to your ~/.config/gtk-3.0/gtk.css
:
.scrollbar {
-GtkRange-slider-width: 15;
}
Increase the width as you see fit (the default is 10). Update /root/.config/gtk-3.0/gtk.css
also, if needed.
I was able to increase the width with the only item:.scrollbar {-GtkRange-slider-width: 15; …
, without all the other options you mentioned. But this was only on a virtual machine. When I tried to do the same on a desktop, nothing worked, though I had tried all of the steps. There is, I suppose a bug in Firefox 52, because on the virtual machine, where the answer helped, the scroll bar reacted correctly for the hover event, and widened automatically. On the desktop it does not handle hovers (which is actually the reason, why I need to widen the scrollbar) and the gtk.css is ignored too
– user907860
Mar 11 '17 at 18:09
1
@user907860 Quite the contrary, all the steps mentioned above are intended to ignore the hover event completely. They are needed to make static, permanent scrollbars which never change their width, as it was in pre-Unity era.
– whtyger
Mar 13 '17 at 7:01
yes, you are correct. I meant just increase of the width, without touching the hover functionality
– user907860
Mar 13 '17 at 15:26
by the way, don't you have any idea, why this does not work in Firefox 52 on a desktop, while it does on a virtual machine? askubuntu.com/questions/892097/…
– user907860
Mar 13 '17 at 15:28
1
This should be the accepted answer. Messing with dconf and themes gave very weird results - not overlay, but not normal either. This answer gives normal scrollbars. It has to be done at the GTK level. Note: Ubunutu is moving to Qt soon.
– Dominic Cerisano
Aug 2 '17 at 7:30
|
show 2 more comments
Here are the steps to restore the scrollbars which don't disappear and have permanent width, i.e. "classic" ones. Tested in GNOME Flashback session in Ubuntu 16.04 (works in Unity, too).
Step 1. Make a backup of /etc/environment
. Run sudo nano /etc/environment
and add there the next line:
GTK_OVERLAY_SCROLLING=0
This will prevent scrollbar's autohide behavior.
Step 2. In order to avoid tampering with the main theme file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
we'll borrow some code from there, alter it and put it into user profile folder. Create ~/.config/gtk-3.0/gtk.css
and put the next lines into it:
/* Adding the buttons on the edges (if you don't need them, skip the next 4 lines)
*/
.scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
/* Scrollbar trough squeezes when cursor hovers over it. Disabling that
*/
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical.dragging:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical.dragging:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal.dragging,
.scrollbar.horizontal.slider:hover,
.scrollbar.horizontal.slider.dragging {
margin-top: 0px;
}
/* Slider widens to fill the scrollbar when cursor hovers over it. Making it permanent
*/
.scrollbar.slider.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.slider.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.slider.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
Step 3. Create ~/.config/gtk-3.0/settings.ini
and add the next lines into it:
[Settings]
gtk-primary-button-warps-slider = false
This will restore page-by-page scrolling behavior when you click the scrollbar on the either side of the slider. If this file already exists, just add the last line in the [Settings]
section of it.
Step 4. Uninstall overlay-scrollbar
and overlay-scrollbar-gtk2
packages - you won't need them anymore.
P.S. If you use some applications which need superuser rights (i.e. Synaptic, gksudo etc.) then you should also place these gtk.css
and settings.ini
files into the root's profile folder:
sudo cp ~/.config/gtk-3.0/gtk.css /root/.config/gtk-3.0/
sudo cp ~/.config/gtk-3.0/settings.ini /root/.config/gtk-3.0/
P.P.S. If you find that these scrollbars are too narrow for you, make them broader. Just add the next line to your ~/.config/gtk-3.0/gtk.css
:
.scrollbar {
-GtkRange-slider-width: 15;
}
Increase the width as you see fit (the default is 10). Update /root/.config/gtk-3.0/gtk.css
also, if needed.
Here are the steps to restore the scrollbars which don't disappear and have permanent width, i.e. "classic" ones. Tested in GNOME Flashback session in Ubuntu 16.04 (works in Unity, too).
Step 1. Make a backup of /etc/environment
. Run sudo nano /etc/environment
and add there the next line:
GTK_OVERLAY_SCROLLING=0
This will prevent scrollbar's autohide behavior.
Step 2. In order to avoid tampering with the main theme file /usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
we'll borrow some code from there, alter it and put it into user profile folder. Create ~/.config/gtk-3.0/gtk.css
and put the next lines into it:
/* Adding the buttons on the edges (if you don't need them, skip the next 4 lines)
*/
.scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
/* Scrollbar trough squeezes when cursor hovers over it. Disabling that
*/
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical.dragging:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical.dragging:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal.dragging,
.scrollbar.horizontal.slider:hover,
.scrollbar.horizontal.slider.dragging {
margin-top: 0px;
}
/* Slider widens to fill the scrollbar when cursor hovers over it. Making it permanent
*/
.scrollbar.slider.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.slider.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.slider.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
Step 3. Create ~/.config/gtk-3.0/settings.ini
and add the next lines into it:
[Settings]
gtk-primary-button-warps-slider = false
This will restore page-by-page scrolling behavior when you click the scrollbar on the either side of the slider. If this file already exists, just add the last line in the [Settings]
section of it.
Step 4. Uninstall overlay-scrollbar
and overlay-scrollbar-gtk2
packages - you won't need them anymore.
P.S. If you use some applications which need superuser rights (i.e. Synaptic, gksudo etc.) then you should also place these gtk.css
and settings.ini
files into the root's profile folder:
sudo cp ~/.config/gtk-3.0/gtk.css /root/.config/gtk-3.0/
sudo cp ~/.config/gtk-3.0/settings.ini /root/.config/gtk-3.0/
P.P.S. If you find that these scrollbars are too narrow for you, make them broader. Just add the next line to your ~/.config/gtk-3.0/gtk.css
:
.scrollbar {
-GtkRange-slider-width: 15;
}
Increase the width as you see fit (the default is 10). Update /root/.config/gtk-3.0/gtk.css
also, if needed.
answered Jan 12 '17 at 13:57
whtygerwhtyger
4,39332236
4,39332236
I was able to increase the width with the only item:.scrollbar {-GtkRange-slider-width: 15; …
, without all the other options you mentioned. But this was only on a virtual machine. When I tried to do the same on a desktop, nothing worked, though I had tried all of the steps. There is, I suppose a bug in Firefox 52, because on the virtual machine, where the answer helped, the scroll bar reacted correctly for the hover event, and widened automatically. On the desktop it does not handle hovers (which is actually the reason, why I need to widen the scrollbar) and the gtk.css is ignored too
– user907860
Mar 11 '17 at 18:09
1
@user907860 Quite the contrary, all the steps mentioned above are intended to ignore the hover event completely. They are needed to make static, permanent scrollbars which never change their width, as it was in pre-Unity era.
– whtyger
Mar 13 '17 at 7:01
yes, you are correct. I meant just increase of the width, without touching the hover functionality
– user907860
Mar 13 '17 at 15:26
by the way, don't you have any idea, why this does not work in Firefox 52 on a desktop, while it does on a virtual machine? askubuntu.com/questions/892097/…
– user907860
Mar 13 '17 at 15:28
1
This should be the accepted answer. Messing with dconf and themes gave very weird results - not overlay, but not normal either. This answer gives normal scrollbars. It has to be done at the GTK level. Note: Ubunutu is moving to Qt soon.
– Dominic Cerisano
Aug 2 '17 at 7:30
|
show 2 more comments
I was able to increase the width with the only item:.scrollbar {-GtkRange-slider-width: 15; …
, without all the other options you mentioned. But this was only on a virtual machine. When I tried to do the same on a desktop, nothing worked, though I had tried all of the steps. There is, I suppose a bug in Firefox 52, because on the virtual machine, where the answer helped, the scroll bar reacted correctly for the hover event, and widened automatically. On the desktop it does not handle hovers (which is actually the reason, why I need to widen the scrollbar) and the gtk.css is ignored too
– user907860
Mar 11 '17 at 18:09
1
@user907860 Quite the contrary, all the steps mentioned above are intended to ignore the hover event completely. They are needed to make static, permanent scrollbars which never change their width, as it was in pre-Unity era.
– whtyger
Mar 13 '17 at 7:01
yes, you are correct. I meant just increase of the width, without touching the hover functionality
– user907860
Mar 13 '17 at 15:26
by the way, don't you have any idea, why this does not work in Firefox 52 on a desktop, while it does on a virtual machine? askubuntu.com/questions/892097/…
– user907860
Mar 13 '17 at 15:28
1
This should be the accepted answer. Messing with dconf and themes gave very weird results - not overlay, but not normal either. This answer gives normal scrollbars. It has to be done at the GTK level. Note: Ubunutu is moving to Qt soon.
– Dominic Cerisano
Aug 2 '17 at 7:30
I was able to increase the width with the only item:
.scrollbar {-GtkRange-slider-width: 15; …
, without all the other options you mentioned. But this was only on a virtual machine. When I tried to do the same on a desktop, nothing worked, though I had tried all of the steps. There is, I suppose a bug in Firefox 52, because on the virtual machine, where the answer helped, the scroll bar reacted correctly for the hover event, and widened automatically. On the desktop it does not handle hovers (which is actually the reason, why I need to widen the scrollbar) and the gtk.css is ignored too– user907860
Mar 11 '17 at 18:09
I was able to increase the width with the only item:
.scrollbar {-GtkRange-slider-width: 15; …
, without all the other options you mentioned. But this was only on a virtual machine. When I tried to do the same on a desktop, nothing worked, though I had tried all of the steps. There is, I suppose a bug in Firefox 52, because on the virtual machine, where the answer helped, the scroll bar reacted correctly for the hover event, and widened automatically. On the desktop it does not handle hovers (which is actually the reason, why I need to widen the scrollbar) and the gtk.css is ignored too– user907860
Mar 11 '17 at 18:09
1
1
@user907860 Quite the contrary, all the steps mentioned above are intended to ignore the hover event completely. They are needed to make static, permanent scrollbars which never change their width, as it was in pre-Unity era.
– whtyger
Mar 13 '17 at 7:01
@user907860 Quite the contrary, all the steps mentioned above are intended to ignore the hover event completely. They are needed to make static, permanent scrollbars which never change their width, as it was in pre-Unity era.
– whtyger
Mar 13 '17 at 7:01
yes, you are correct. I meant just increase of the width, without touching the hover functionality
– user907860
Mar 13 '17 at 15:26
yes, you are correct. I meant just increase of the width, without touching the hover functionality
– user907860
Mar 13 '17 at 15:26
by the way, don't you have any idea, why this does not work in Firefox 52 on a desktop, while it does on a virtual machine? askubuntu.com/questions/892097/…
– user907860
Mar 13 '17 at 15:28
by the way, don't you have any idea, why this does not work in Firefox 52 on a desktop, while it does on a virtual machine? askubuntu.com/questions/892097/…
– user907860
Mar 13 '17 at 15:28
1
1
This should be the accepted answer. Messing with dconf and themes gave very weird results - not overlay, but not normal either. This answer gives normal scrollbars. It has to be done at the GTK level. Note: Ubunutu is moving to Qt soon.
– Dominic Cerisano
Aug 2 '17 at 7:30
This should be the accepted answer. Messing with dconf and themes gave very weird results - not overlay, but not normal either. This answer gives normal scrollbars. It has to be done at the GTK level. Note: Ubunutu is moving to Qt soon.
– Dominic Cerisano
Aug 2 '17 at 7:30
|
show 2 more comments
Changing -GtkRange-slider-width
has no effect on the default GTK+3 theme. Instead, you can do this:
scrollbar slider {
/* Size of the slider */
min-width: 20px;
min-height: 20px;
border-radius: 22px;
/* Padding around the slider */
border: 5px solid transparent;
}
(Place the above in ~/.config/gtk-3.0/gtk.css
.)
1
where should I add it?
– kenn
Oct 28 '17 at 10:37
@kenn~/.config/gtk-3.0/gtk.css
– Vladimir Panteleev
Oct 28 '17 at 16:25
1
Works like a charm on Ubuntu 18.04. Thanks!
– Steve Cohen
May 6 '18 at 22:25
9 months later: This does work like a charm under Ubuntu 18.04 - EXCEPT that it confuses the heck out of the GNUCash application. See lists.gnucash.org/pipermail/gnucash-user/2019-February/…. Making these changes destroys scrollbar functionality in GNUCash, but not other apps. Sigh.
– Steve Cohen
Feb 5 at 21:37
@SteveCohen, I looked at the gnucash link. You wrote "~/.config/gtk-3.0.gtk.css" but it should be~/.config/gtk-3.0/gtk.css
. Also, gnucash appears to be a gtk2 application, not a gtk3 application.
– DK Bose
Feb 6 at 0:44
add a comment |
Changing -GtkRange-slider-width
has no effect on the default GTK+3 theme. Instead, you can do this:
scrollbar slider {
/* Size of the slider */
min-width: 20px;
min-height: 20px;
border-radius: 22px;
/* Padding around the slider */
border: 5px solid transparent;
}
(Place the above in ~/.config/gtk-3.0/gtk.css
.)
1
where should I add it?
– kenn
Oct 28 '17 at 10:37
@kenn~/.config/gtk-3.0/gtk.css
– Vladimir Panteleev
Oct 28 '17 at 16:25
1
Works like a charm on Ubuntu 18.04. Thanks!
– Steve Cohen
May 6 '18 at 22:25
9 months later: This does work like a charm under Ubuntu 18.04 - EXCEPT that it confuses the heck out of the GNUCash application. See lists.gnucash.org/pipermail/gnucash-user/2019-February/…. Making these changes destroys scrollbar functionality in GNUCash, but not other apps. Sigh.
– Steve Cohen
Feb 5 at 21:37
@SteveCohen, I looked at the gnucash link. You wrote "~/.config/gtk-3.0.gtk.css" but it should be~/.config/gtk-3.0/gtk.css
. Also, gnucash appears to be a gtk2 application, not a gtk3 application.
– DK Bose
Feb 6 at 0:44
add a comment |
Changing -GtkRange-slider-width
has no effect on the default GTK+3 theme. Instead, you can do this:
scrollbar slider {
/* Size of the slider */
min-width: 20px;
min-height: 20px;
border-radius: 22px;
/* Padding around the slider */
border: 5px solid transparent;
}
(Place the above in ~/.config/gtk-3.0/gtk.css
.)
Changing -GtkRange-slider-width
has no effect on the default GTK+3 theme. Instead, you can do this:
scrollbar slider {
/* Size of the slider */
min-width: 20px;
min-height: 20px;
border-radius: 22px;
/* Padding around the slider */
border: 5px solid transparent;
}
(Place the above in ~/.config/gtk-3.0/gtk.css
.)
edited Jan 24 '18 at 14:47
answered Apr 25 '17 at 4:32
Vladimir PanteleevVladimir Panteleev
4511615
4511615
1
where should I add it?
– kenn
Oct 28 '17 at 10:37
@kenn~/.config/gtk-3.0/gtk.css
– Vladimir Panteleev
Oct 28 '17 at 16:25
1
Works like a charm on Ubuntu 18.04. Thanks!
– Steve Cohen
May 6 '18 at 22:25
9 months later: This does work like a charm under Ubuntu 18.04 - EXCEPT that it confuses the heck out of the GNUCash application. See lists.gnucash.org/pipermail/gnucash-user/2019-February/…. Making these changes destroys scrollbar functionality in GNUCash, but not other apps. Sigh.
– Steve Cohen
Feb 5 at 21:37
@SteveCohen, I looked at the gnucash link. You wrote "~/.config/gtk-3.0.gtk.css" but it should be~/.config/gtk-3.0/gtk.css
. Also, gnucash appears to be a gtk2 application, not a gtk3 application.
– DK Bose
Feb 6 at 0:44
add a comment |
1
where should I add it?
– kenn
Oct 28 '17 at 10:37
@kenn~/.config/gtk-3.0/gtk.css
– Vladimir Panteleev
Oct 28 '17 at 16:25
1
Works like a charm on Ubuntu 18.04. Thanks!
– Steve Cohen
May 6 '18 at 22:25
9 months later: This does work like a charm under Ubuntu 18.04 - EXCEPT that it confuses the heck out of the GNUCash application. See lists.gnucash.org/pipermail/gnucash-user/2019-February/…. Making these changes destroys scrollbar functionality in GNUCash, but not other apps. Sigh.
– Steve Cohen
Feb 5 at 21:37
@SteveCohen, I looked at the gnucash link. You wrote "~/.config/gtk-3.0.gtk.css" but it should be~/.config/gtk-3.0/gtk.css
. Also, gnucash appears to be a gtk2 application, not a gtk3 application.
– DK Bose
Feb 6 at 0:44
1
1
where should I add it?
– kenn
Oct 28 '17 at 10:37
where should I add it?
– kenn
Oct 28 '17 at 10:37
@kenn
~/.config/gtk-3.0/gtk.css
– Vladimir Panteleev
Oct 28 '17 at 16:25
@kenn
~/.config/gtk-3.0/gtk.css
– Vladimir Panteleev
Oct 28 '17 at 16:25
1
1
Works like a charm on Ubuntu 18.04. Thanks!
– Steve Cohen
May 6 '18 at 22:25
Works like a charm on Ubuntu 18.04. Thanks!
– Steve Cohen
May 6 '18 at 22:25
9 months later: This does work like a charm under Ubuntu 18.04 - EXCEPT that it confuses the heck out of the GNUCash application. See lists.gnucash.org/pipermail/gnucash-user/2019-February/…. Making these changes destroys scrollbar functionality in GNUCash, but not other apps. Sigh.
– Steve Cohen
Feb 5 at 21:37
9 months later: This does work like a charm under Ubuntu 18.04 - EXCEPT that it confuses the heck out of the GNUCash application. See lists.gnucash.org/pipermail/gnucash-user/2019-February/…. Making these changes destroys scrollbar functionality in GNUCash, but not other apps. Sigh.
– Steve Cohen
Feb 5 at 21:37
@SteveCohen, I looked at the gnucash link. You wrote "~/.config/gtk-3.0.gtk.css" but it should be
~/.config/gtk-3.0/gtk.css
. Also, gnucash appears to be a gtk2 application, not a gtk3 application.– DK Bose
Feb 6 at 0:44
@SteveCohen, I looked at the gnucash link. You wrote "~/.config/gtk-3.0.gtk.css" but it should be
~/.config/gtk-3.0/gtk.css
. Also, gnucash appears to be a gtk2 application, not a gtk3 application.– DK Bose
Feb 6 at 0:44
add a comment |
I'm using Ubuntu 18.04 and this was the only solution that changed the scrollbar for EVERYTHING, from Firefox to LibreOffice to gnome-terminal. The solutions above worked fine for one or two applications but not for everything.
Note: this gives you REALLY big scrollbars which are good for large monitors because you can see them out of the corner of your eye without looking all the way over to the side of the screen every time you want to grab one. If you want smaller ones, change all the 70px's to a smaller number like 20px or 30px and tweak accordingly.
Put the following text into ~/.config/gtk-3.0/gtk.css
:
.scrollbar,
scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
scrollbar slider {
background-color: @scrollbar_track_color;
}
.scrollbar.vertical slider,
scrollbar.vertical slider {
min-height: 150px;
min-width: 70px;
}
.scrollbar.horizontal.slider,
scrollbar.horizontal slider {
min-width: 40px;
min-height: 10px;
}
.scrollbar.vertical.slider:hover,
scrollbar.vertical:hover slider {
min-width: 70px;
}
.scrollbar.horizontal.slider:hover,
scrollbar.horizontal:hover slider {
min-height: 10px;
}
.scrollbar.contents,
scrollbar contents {
background-color: transparent;
background-image: none;
background-size: 0;
border: none;
border-radius: 0;
}
.scrollbar.trough,
scrollbar trough {
background-image: none;
border: none;
}
.scrollbar:hover:backdrop,
.scrollbar.dragging:backdrop,
scrollbar:hover:backdrop,
scrollbar.dragging:backdrop {
background-color: alpha(@backdrop_selected_bg_color, 0.5);
}
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical:active:dir(ltr),
scrollbar.vertical:hover:dir(ltr),
scrollbar.vertical:active:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical:active:dir(rtl),
scrollbar.vertical:hover:dir(rtl),
scrollbar.vertical:active:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal:active,
scrollbar.horizontal:hover,
scrollbar.horizontal:active {
margin-top: 0px;
}
.scrollbar.slider,
scrollbar slider {
background-color: alpha(@backdrop_filling_bg, 0.75);
border-radius: 10px;
}
.scrollbar.slider:hover,
.scrollbar.slider:active,
scrollbar slider:hover,
scrollbar slider:active {
border-radius: 20px;
margin: 0;
}
.scrollbar.vertical:dir(ltr):not(:hover):not(.dragging),
scrollbar.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.vertical:dir(rtl):not(:hover):not(.dragging),
scrollbar.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.horizontal:not(:hover):not(.dragging),
scrollbar.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
.scrollbar.slider:hover,
scrollbar slider:hover {
background-color: alpha(@backdrop_filling_bg, 0.6);
}
.scrollbar.slider:active,
scrollbar slider:active {
background-color: @backdrop_filling_bg;
}
.scrollbar.slider:backdrop,
scrollbar slider:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.75);
}
.scrollbar.slider:hover:backdrop,
scrollbar slider:hover:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.6;
}
.scrollbar.slider:active:backdrop,
scrollbar slider:active:backdrop {
background-color: @backdrop_filling_bg;
}
scrollbar {
min-width: 70px;
min-height: 70px;
}
add a comment |
I'm using Ubuntu 18.04 and this was the only solution that changed the scrollbar for EVERYTHING, from Firefox to LibreOffice to gnome-terminal. The solutions above worked fine for one or two applications but not for everything.
Note: this gives you REALLY big scrollbars which are good for large monitors because you can see them out of the corner of your eye without looking all the way over to the side of the screen every time you want to grab one. If you want smaller ones, change all the 70px's to a smaller number like 20px or 30px and tweak accordingly.
Put the following text into ~/.config/gtk-3.0/gtk.css
:
.scrollbar,
scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
scrollbar slider {
background-color: @scrollbar_track_color;
}
.scrollbar.vertical slider,
scrollbar.vertical slider {
min-height: 150px;
min-width: 70px;
}
.scrollbar.horizontal.slider,
scrollbar.horizontal slider {
min-width: 40px;
min-height: 10px;
}
.scrollbar.vertical.slider:hover,
scrollbar.vertical:hover slider {
min-width: 70px;
}
.scrollbar.horizontal.slider:hover,
scrollbar.horizontal:hover slider {
min-height: 10px;
}
.scrollbar.contents,
scrollbar contents {
background-color: transparent;
background-image: none;
background-size: 0;
border: none;
border-radius: 0;
}
.scrollbar.trough,
scrollbar trough {
background-image: none;
border: none;
}
.scrollbar:hover:backdrop,
.scrollbar.dragging:backdrop,
scrollbar:hover:backdrop,
scrollbar.dragging:backdrop {
background-color: alpha(@backdrop_selected_bg_color, 0.5);
}
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical:active:dir(ltr),
scrollbar.vertical:hover:dir(ltr),
scrollbar.vertical:active:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical:active:dir(rtl),
scrollbar.vertical:hover:dir(rtl),
scrollbar.vertical:active:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal:active,
scrollbar.horizontal:hover,
scrollbar.horizontal:active {
margin-top: 0px;
}
.scrollbar.slider,
scrollbar slider {
background-color: alpha(@backdrop_filling_bg, 0.75);
border-radius: 10px;
}
.scrollbar.slider:hover,
.scrollbar.slider:active,
scrollbar slider:hover,
scrollbar slider:active {
border-radius: 20px;
margin: 0;
}
.scrollbar.vertical:dir(ltr):not(:hover):not(.dragging),
scrollbar.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.vertical:dir(rtl):not(:hover):not(.dragging),
scrollbar.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.horizontal:not(:hover):not(.dragging),
scrollbar.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
.scrollbar.slider:hover,
scrollbar slider:hover {
background-color: alpha(@backdrop_filling_bg, 0.6);
}
.scrollbar.slider:active,
scrollbar slider:active {
background-color: @backdrop_filling_bg;
}
.scrollbar.slider:backdrop,
scrollbar slider:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.75);
}
.scrollbar.slider:hover:backdrop,
scrollbar slider:hover:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.6;
}
.scrollbar.slider:active:backdrop,
scrollbar slider:active:backdrop {
background-color: @backdrop_filling_bg;
}
scrollbar {
min-width: 70px;
min-height: 70px;
}
add a comment |
I'm using Ubuntu 18.04 and this was the only solution that changed the scrollbar for EVERYTHING, from Firefox to LibreOffice to gnome-terminal. The solutions above worked fine for one or two applications but not for everything.
Note: this gives you REALLY big scrollbars which are good for large monitors because you can see them out of the corner of your eye without looking all the way over to the side of the screen every time you want to grab one. If you want smaller ones, change all the 70px's to a smaller number like 20px or 30px and tweak accordingly.
Put the following text into ~/.config/gtk-3.0/gtk.css
:
.scrollbar,
scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
scrollbar slider {
background-color: @scrollbar_track_color;
}
.scrollbar.vertical slider,
scrollbar.vertical slider {
min-height: 150px;
min-width: 70px;
}
.scrollbar.horizontal.slider,
scrollbar.horizontal slider {
min-width: 40px;
min-height: 10px;
}
.scrollbar.vertical.slider:hover,
scrollbar.vertical:hover slider {
min-width: 70px;
}
.scrollbar.horizontal.slider:hover,
scrollbar.horizontal:hover slider {
min-height: 10px;
}
.scrollbar.contents,
scrollbar contents {
background-color: transparent;
background-image: none;
background-size: 0;
border: none;
border-radius: 0;
}
.scrollbar.trough,
scrollbar trough {
background-image: none;
border: none;
}
.scrollbar:hover:backdrop,
.scrollbar.dragging:backdrop,
scrollbar:hover:backdrop,
scrollbar.dragging:backdrop {
background-color: alpha(@backdrop_selected_bg_color, 0.5);
}
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical:active:dir(ltr),
scrollbar.vertical:hover:dir(ltr),
scrollbar.vertical:active:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical:active:dir(rtl),
scrollbar.vertical:hover:dir(rtl),
scrollbar.vertical:active:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal:active,
scrollbar.horizontal:hover,
scrollbar.horizontal:active {
margin-top: 0px;
}
.scrollbar.slider,
scrollbar slider {
background-color: alpha(@backdrop_filling_bg, 0.75);
border-radius: 10px;
}
.scrollbar.slider:hover,
.scrollbar.slider:active,
scrollbar slider:hover,
scrollbar slider:active {
border-radius: 20px;
margin: 0;
}
.scrollbar.vertical:dir(ltr):not(:hover):not(.dragging),
scrollbar.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.vertical:dir(rtl):not(:hover):not(.dragging),
scrollbar.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.horizontal:not(:hover):not(.dragging),
scrollbar.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
.scrollbar.slider:hover,
scrollbar slider:hover {
background-color: alpha(@backdrop_filling_bg, 0.6);
}
.scrollbar.slider:active,
scrollbar slider:active {
background-color: @backdrop_filling_bg;
}
.scrollbar.slider:backdrop,
scrollbar slider:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.75);
}
.scrollbar.slider:hover:backdrop,
scrollbar slider:hover:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.6;
}
.scrollbar.slider:active:backdrop,
scrollbar slider:active:backdrop {
background-color: @backdrop_filling_bg;
}
scrollbar {
min-width: 70px;
min-height: 70px;
}
I'm using Ubuntu 18.04 and this was the only solution that changed the scrollbar for EVERYTHING, from Firefox to LibreOffice to gnome-terminal. The solutions above worked fine for one or two applications but not for everything.
Note: this gives you REALLY big scrollbars which are good for large monitors because you can see them out of the corner of your eye without looking all the way over to the side of the screen every time you want to grab one. If you want smaller ones, change all the 70px's to a smaller number like 20px or 30px and tweak accordingly.
Put the following text into ~/.config/gtk-3.0/gtk.css
:
.scrollbar,
scrollbar {
-GtkScrollbar-has-backward-stepper: 1;
-GtkScrollbar-has-forward-stepper: 1;
}
scrollbar slider {
background-color: @scrollbar_track_color;
}
.scrollbar.vertical slider,
scrollbar.vertical slider {
min-height: 150px;
min-width: 70px;
}
.scrollbar.horizontal.slider,
scrollbar.horizontal slider {
min-width: 40px;
min-height: 10px;
}
.scrollbar.vertical.slider:hover,
scrollbar.vertical:hover slider {
min-width: 70px;
}
.scrollbar.horizontal.slider:hover,
scrollbar.horizontal:hover slider {
min-height: 10px;
}
.scrollbar.contents,
scrollbar contents {
background-color: transparent;
background-image: none;
background-size: 0;
border: none;
border-radius: 0;
}
.scrollbar.trough,
scrollbar trough {
background-image: none;
border: none;
}
.scrollbar:hover:backdrop,
.scrollbar.dragging:backdrop,
scrollbar:hover:backdrop,
scrollbar.dragging:backdrop {
background-color: alpha(@backdrop_selected_bg_color, 0.5);
}
.scrollbar.vertical:hover:dir(ltr),
.scrollbar.vertical:active:dir(ltr),
scrollbar.vertical:hover:dir(ltr),
scrollbar.vertical:active:dir(ltr) {
margin-left: 0px;
}
.scrollbar.vertical:hover:dir(rtl),
.scrollbar.vertical:active:dir(rtl),
scrollbar.vertical:hover:dir(rtl),
scrollbar.vertical:active:dir(rtl) {
margin-right: 0px;
}
.scrollbar.horizontal:hover,
.scrollbar.horizontal:active,
scrollbar.horizontal:hover,
scrollbar.horizontal:active {
margin-top: 0px;
}
.scrollbar.slider,
scrollbar slider {
background-color: alpha(@backdrop_filling_bg, 0.75);
border-radius: 10px;
}
.scrollbar.slider:hover,
.scrollbar.slider:active,
scrollbar slider:hover,
scrollbar slider:active {
border-radius: 20px;
margin: 0;
}
.scrollbar.vertical:dir(ltr):not(:hover):not(.dragging),
scrollbar.vertical:dir(ltr):not(:hover):not(.dragging) {
margin-left: 0px;
}
.scrollbar.vertical:dir(rtl):not(:hover):not(.dragging),
scrollbar.vertical:dir(rtl):not(:hover):not(.dragging) {
margin-right: 0px;
}
.scrollbar.horizontal:not(:hover):not(.dragging),
scrollbar.horizontal:not(:hover):not(.dragging) {
margin-top: 0px;
}
.scrollbar.slider:hover,
scrollbar slider:hover {
background-color: alpha(@backdrop_filling_bg, 0.6);
}
.scrollbar.slider:active,
scrollbar slider:active {
background-color: @backdrop_filling_bg;
}
.scrollbar.slider:backdrop,
scrollbar slider:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.75);
}
.scrollbar.slider:hover:backdrop,
scrollbar slider:hover:backdrop {
background-color: alpha(@backdrop_filling_bg, 0.6;
}
.scrollbar.slider:active:backdrop,
scrollbar slider:active:backdrop {
background-color: @backdrop_filling_bg;
}
scrollbar {
min-width: 70px;
min-height: 70px;
}
edited Jan 26 at 17:14
answered Sep 22 '18 at 23:09
s. wolfes. wolfe
314
314
add a comment |
add a comment |
Thanks for contributing an answer to Ask Ubuntu!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2faskubuntu.com%2fquestions%2f775201%2fhow-do-i-get-a-bigger-static-scrollbar-aka-normal-scrollbar%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
how is this still a dang issue and not fix/part of standard system settings? lordy four years ago i rage quite ubuntu over stuff like this and went to mintier pastures...lol
– neuronet
Nov 12 '17 at 16:26
@neuronet Amen, brother
– Steve Cohen
May 6 '18 at 2:47