Observations from KDE Trunk and Qt 4

Since KDE migrated to Subversion, I have been creating semi-weekly development builds in the hopes of finding bugs to report. Notable new features include Konqueror's new adblocking mechanism and Kicker's new applet manager. Since everyone likes screenshots, I created two articles with screenshots from my observational usage: previews of KDE's trunk code and Trolltech's Qt 4 alongside brief documentation of what one is looking at.

Comments

I am compiling KDE svn trunk on a nightly basis with my own scripts and it really rocks. I am here to thank everyone from the KDE team (and the cool people from #kde-devel) for their carefully work on keeping svn trunk always in shape. There are rarely any issues with svn trunk and it usually compiles over night without any issues. Rarely you need to do some manual work to have it finish the compile and the committs to svn trunk are usually tested and work. Thanks to the people for having created a nice, round and feature complete Desktop Environment for the Open Source world to get serious business, science and normal work done. Stuff that feel mature, complete, consistent and truly integrated.

by Levi Durham (not verified)

You should give kdesvn-build, located in kdesdk/scripts, a try, it can't do everything yet (l10n doesn't quite work). But, all in all, it's a great script. And I'm not just saying that because i wrote the code to make it do apidox.

Levi
http://www.freepgs.com/levidurham/

I know about it but still prefer using my own ones. They are also available for other people to use as alternative.

by naomen (not verified)

It is nice of the person for doing screenshots,
but me thinks that it is better for doing them
in the default window decoration, theme and
iconset.

by phil (not verified)

Yeah, at least follow the standards:

http://i18n.kde.org/doc/screenshots.php

by jui jim (not verified)

I think that these instructions are meant to apply to screenshots created for documentation purposes. The instructions must be old because they make reference to XFree86 instead of XOrg.

Anyway way to be an ass about wanting to regulate screenshots that are not even official and given at the convenience of those who make them or spend their time compiling the software to make them.

by ac (not verified)

okay, but...

What happens when an outsider (non-KDE-geek) grabs these images. All they can think is, THAT'S the next KDE?

by Jim (not verified)

I cannot stress enough how important ad-blocking is. I'd never consider using any browser that didn't have something similar to Firefox's AdBlock.

I think Konqueror would also gain a lot more users if it was easier to extend. The extensions I have installed are the main thing keeping me on Firefox.

With Firefox, you can just write a bit of Javascript and XML. With both Firefox and Opera, you can add features by writing a few lines of Javascript with Greasemonkey/user Javascript.

How much quicker would this Konqueror ad-blocking have come about if Konqueror was as easy as Firefox to extend?

Does anybody know if there is ongoing development of KaXUL? Or has it been abandoned?

by Mickael Marchand (not verified)

well actually the extensions in firefox is also the source of their biggest security holes they have (hopefully _had_).
I prefer not having 'dynamic' extensions if I lose security.
I am fed up of all these browsers that in the name of extensibility drops basic security measures.
Firefox really disappointed me in that area.
These days, security in browsers should always be first and I have to say that konqui is one of those too few browsers I have never had major security concerns.

as soon as you allow a dynamic thing to come into your browser, you definitely open new security bugs.

just my 2c.

Cheers,
Mik

by Jim (not verified)

> well actually the extensions in firefox is also the source of their biggest security holes they have

What's your basis for claiming that?

http://www.mozilla.org/projects/security/known-vulnerabilities.html#Firefox

Doesn't look like many of them are related to extensions as far as I can see.

> as soon as you allow a dynamic thing to come into your browser, you definitely open new security bugs.

Well then Konqueror is no good either, unless you switch off Java, Javascript, plugins, etc.

by Phase II (not verified)

Agreed, Konqueror needs to be able to be extended. I'd like to see Konqueror to become as good as Opera as a browser. I still use Opera for all its small conveniences which is also where I find Koqueror (KDE 3.3 here) still lacking.. something like the session thing could be done as an extension, the rest probably needs to be done in Koqueror itself -- some kind of wishlist here:

- save & restore sessions (Operas *.win files), also session restoring for crashes
- mouse gestures (admittedly I didn't test KHotKeys yet but an Opera compliant preset would be nice)
- the hopefully soon arriving panning (aka continuous smooth scrolling)
- and some more settings as how many connections to allow for one site and overall

Problems I still have with Konqueror:
- different kind of tabs than Opera (again). This also applies to Firefox. The advantage of the more pushbutton like tabs in Opera is that they can be minimized so you can change which tabs you want to see and when. Any chance for it being implemented?
- fullscreen not really implemented? It's just half a fullscreen, menus, address bar (ok might be useful)and status bar still there. Will a full fullscreen be done where only the page can be seen? To me both seems useful.
- revenge of the kparts: currently an image is shown in a gwenview tab here where I can email or compress it or copy it to a location with a rightclick. Somehow this is lacking important functions for the image (on rightclick) like save it, copy it, copy url and properties. Don't really know if Konqueror can't show images on its own or if these functions are missing in the Gwenview kpart.

Konqueror is really good and usable apart from that, but at least for me needs still some tuning to make it first choice as a browser.

Konqueror has "panning", Shift+(UpArrow|DownArrow), at least in 3.4. It also has mouse gestures vie KHotkeys, and it works great and you can configure it as you like.

It also has sessions, called "View Profiles".

by Hans (not verified)

Konqueror has sommth scrolling (like firefox), just use the Suse RPMs
(or integrate Suse's patch into SVN)

by Phase II (not verified)

But no panning on third mouse button which triggers the notorious x clipboard.

ok the Profiles seemed more like (and probably are) for setting the layout, but perhaps could be fleshed out, with the history of the saved sites. Wasn't that obvious under the settings tab. (usability to the rescue).

The stuff noted under "problems" remains.
Especially Konqueror loading an image in a Gwenview kpart should be emphasized.
This might be handy on a local filesystem, but it's just unusable on a website.
I'd just need about four basic operations on rightclick (save image..., copy image, copy image url, image properties)
and all four are gone because the picture is embedded in the viewing part of an application. Instead I can rotate it now in the browser.. *sigh*
Don't know anymore how it was handled before I installed Gwenview.

I think it's indeed Gwenview that decides what options are shown there.

If you don't want Gwenview to be used for embedded viewing you can tweak that in the control center under KDE Components -> File Associations (for each image type in question): Just change the "Service Preference Order" on the "Embedding tab" of each image type. The entry on top is used.

That way you can keep Gwenview installed and still use something else inside Konqueror.

by Dolio (not verified)

Konqueror does have panning on the third mouse button.

Settings
> Configure Konqueror
> Web Behavior
> Mouse Behavior
> Middle Click Opens URL in Selection

That's enabled by default, but if you turn it off, it does scrolling just as in Firefox, IE and, I assume, Opera.

by Roland Wolf (not verified)

Hi Jim
I am using Konqueror with an open source ad-blocker:
http://www.privoxy.org
It removes all the blinking stuff from pages. The filter can be tailored to your needs. Give it a try.
Regards, Roland

Hmmm, that doesn't sound useful. If it removes all the bl*nking stuff from the page, what's left?

by Anonymous (not verified)

It's more useful and powerful than that, but it requires quite a bit of tweaking to adjust to your needs.

You don't blinking say? =)

by Jim (not verified)

Sorry Roland, Privoxy just doesn't compare. With AdBlock, I see something annoying, I right-click, and block it. Messing around with a proxy every time I see something annoying is too much hassle, I'd rather just put up with the ads.

by Víctor Fernández (not verified)

Firefox extensions create a lot of security holes and make it unstable. I'm the developer of Plastikfox and extensions usually step one on top of other forcing me to do dirty hacks to make it work. They have full access to all the parts of the browser, which is very dangerous. Also, extension developers don't usually care not to do things that could break other extensions. They just care their extension works but sometimes two extensions try to access the same resource causing problems. The result is a bunch of bloated dirty code running on your computer that could explode in your face at any time. If they were implemented in a clean way it would be a point but they don't. That's the reason I don't like extensions and I wouldn't like Konqueror to get that too, or at least in a similar way to Firefox. Perhaps if extensions were implemented in a way similar like plugins are (being them all independent and one extension not having access to others' variables an code) it would be much better.

by Jim (not verified)

> Firefox extensions create a lot of security holes and make it unstable.

What is your basis for saying that? As I pointed out to another person who said the same thing, the facts don't seem to agree with your opinion.

> That's the reason I don't like extensions and I wouldn't like Konqueror to get that too

Erm... Konqueror has been extendable for years. What I'm talking about is making it *easier* to extend.

Right now, you need to extend Konqueror in C++, and that opens up a hell of a lot more ways for an extension writer to screw up than Firefox extensions.

by mabinogi (not verified)

and why did you think you'd find bugs related to 3rd party extensions in the mozilla bug database?

The trouble with Firefox extensions is that they've given full access to the browser, but are generally only written and maintained by one person. Often someone with very little experience.
They just don't have the same level of QA as the browser itself.

Obviously there are exceptions, but the Firefox extension mechanism opens itself up for a whole lot of half arsed buggy, insecure extensions.

by fast_rizwaan (not verified)

So, at last after many years, KDE Developers got the courage to have Icon+Text! Congrats, but make it beautiful, attractive, customizable, animated. Support MNG and GIF for K button. Allow 4 state png/mng for k buttons! unfocused, focused(hover), pressed (focused), pressed (not hover).

Congrats on becoming bold!

by Víctor Fernández (not verified)

Please, no text in the K-Menu! Or at least a text different than "Applications", I don't want a Gnome clone and Gnome people will say we're dropping our pants. Also make it a configurable option so people can disable the text (I will do!).

by Aaron J. Seigo (not verified)

a) it is configurable
b) it's not on by default

i turned it on by default for one week (and turned it back off at the end of that period of time) so that the code path for button text would get wide testing. apparently these screenshots where taken during that week =)

one of the problems with having as many features, several of them "hidden", in an application such as kicker where people tend to run it in a more-or-less static configuration is that getting good testing coverage can be difficult. so i occasionally turn things on or off by default in SVN to get some testing by those who follow svn. KConfigXT has made this easier since i just modify an XML file and it doesn't write default values to the rc; both features are nice for this =)

unfortunately there isn't much that a test suite could automate here, either, since most of the "output" of kicker is graphical and interactive in nature requiring a user to try things and interpret the results as "expected" or "buggy". kicker behaviour is also sensitive to things like X configurations, including having save-unders enabled, Xinerama setups, dual-head configurations and screen resolutions.

by Mark Hannessen (not verified)

nice...

the word "Applications" takes way to much space in the kicker.
it's a bad thing to do. please keep the UI clean.

by agreed (not verified)

agreed 100%

by light (not verified)

++

by ch (not verified)

how does the new kde *feel* ?

by Illissius (not verified)

It feels somewhere between a yellow.

by chris (not verified)

ehehe , i meant , could you somehow distinguish between qt3 and qt4 toolkit (more responsive, more colors , more ..... i dont know)

or perhaps its just for the programmers under the hood . ??

by Illissius (not verified)

Current svn trunk is for 3.5, so it's still Qt3. It feels mostly like 3.4 did, a bit more gnomeish (not a bad thing) due to the 'add applet' dialog and the hidden option to have taskbar buttons take up the full length of the taskbar.

(The Qt4 branch probably feels not much more than buggy at this early stage, though I haven't tried it...)

by Erik Hensema (not verified)

AFAIK the Qt4 branch doesn't even compile yet. Though it wouldn't suprise me if it already does, given the pace of development.

by mikeyd (not verified)

I was trying to enjoy the new Qt but all I could think was "Arrgh, motif's coming back!" Seriously, that theme is _horrible_.

by Macavity (not verified)

>I would encourage the viewer to ignore the rest of the desktop, for I use
>KDE's CDE/Motif theme, which many people find unattractive

uhm....? ;-)

~Macavity

by mikeyd (not verified)

I did my best, but it's that bright horrible red, draws the eye even when you're trying to ignore it.

by Tim (not verified)

>>(KMix has a separate tab for device switches.)

Just like GNOME too.

And why dont get rid of th annoying Vertical Text?

by Veton (not verified)

+1. I agree totally. This need some plasma ray =)

by Ryan (not verified)

What ever happened to the improvements suggested here:
http://kdelook.org/content/show.php?content=16962

I love that sidebar with HORIZONTAL text!
I think the last I heard is that some of this was accepted, but some also required Qt changes, which couldn't be done.
Too bad really, it looks really nice.
cheers,
-Ryan

by Anonymous (not verified)

It doesn't scale well.

by Ryan (not verified)

In what respect? The length of text/languanges?

by ac (not verified)

Trying to get the sidebar to "scale" is clearly a case of overengineering. There are wayyyy too many tabs if you need it to "scale" beyond 3 or 4. Usability wise that would just be suicide to have too many tabs. Well I guess it's suicide right now already. =)

This is why the horizontal design is superior. It solves the right problem not an invented "scale" issue.

by mornfall (not verified)

You forgot the uninvented i need to run over the full screen height to switch tabs suckage. Forget it. It's no solution. And it's annoying when you misclick. Go think again (and come with something usable next time, please).

by Mikos (not verified)

Nooo, please don't get rid of vertical text tabs! I like that concept very much!

by Timmeh (not verified)

nice preview. I really like how things are coming along. The vector demo looks really nice. there is also some qt4 preview stuff at the digitalfanatics qt4 website, but it's geared more towards programmers.

kinda off topic, but I'm just curious, what distro are you using?

by Timmeh (not verified)

Sorry im an idiot. its right in the article

"KDE 3.5 was built on my machine from the main trunk of KDE's subversion tree on a machine running Gentoo stable, using KDE's CDE/Solaris/Motif themeset."

somehow missed it.

by ac (not verified)

Timmeh!!

by Daelin the Cruel (not verified)

While attempting to port a medium-sized program to Qt4, I noticed a SEVERE drop in performance. To diagnose this droppage, I wrote a very small, simple program that depicts two rectangles bouncing around on the screen, and reports the framerate (which is calculated as an average over 5 seconds).

Under both versions of Qt, the program used a QTimer widget to control the movement of the rectangles. The Qt3 version can simply draw the rectangles directly from the QTimer handler, while the Qt4 version must generate a paintEvent, which I tried both with the "update()" method (which supposedly waits until Qt's main loop to call paintEvent normally), and with the "repaint()" method (which supposedly calls paintEvent immediately, which is supposed to be faster but more likely to flicker).

On my machine (A 1-GHz Celeron with a low-end Radeon, resolution 1400x1050, 16bpp), both versions run fast when the window is at its default size (49 FPS-- the target framerate).

When the window is maximized, however, Qt4 takes a 39% performance hit (19 FPS), while Qt3 takes no hit at all!

In larger programs with lots of widgets (such as the program I was porting when I first noticed the problem), I notice that any use of a timer-updated widget drags the program to a near halt.

I have attached the program, so you can see for yourself that Qt4 really is inferior. It must be built with the $QTDIR environment variable set appropriately. Two Makefiles are required because MOC doesn't pay attention to #ifdef directives. You must run 'make clean' between building the demo with Qt4 and Qt3.