Want to improve this question? Update the question so it focuses on one problem only by editing this post.
Closed 2 years ago.
I am fairly new to the domain of GUI design and development. I do have some prior experience but that is with Visual Basic.
I would like to develop a reasonably comprehensive (though not state-of-the-art) GUI application on linux based on a command line app. that I have. Having done some googling, I do find that there are mainly three good (or perhaps that is what I feel) ways to achieve this goal:
- GTK+ library with GLADE as the designer
- Qt library with Qtdesigner as the designer
- Java swing with Netbeans
In order to settle upon one of the above (or reject all of them), I would have to know the following aspects of each item in the above list. These aspects, in decreasing order of their priority are:
- Licensing: I would not be able to shell out too many bucks here...
- Programming language support: I know C/C++ and very little Java.
- Ease of learning / use
- Flexibility and power: It would be really nice if most (if not all) features that I need are available in the core library.
- (Lack of) additional dependencies: Reasoning same as point number 4
- Look and feel
- Platforms supported / Portability (effort required to switch platform)
Any ideas on the above topics would be worth their weight in gold (I wouldn't want to realize after one month that I chose the wrong tool for my job). Are there any other tools more fitting to my purpose that I am unaware of?
Point-blank answers would most help.
EDIT: Ok so I have finally gone with Qt. Simply because it is easier to learn and appears more portable than GTK+ (to me ofcourse).
To make the case for GTK:
- LGPL licensing.
- Written in C, but is usable with almost any programming language, including C++, Python, Javascript, Haskell, etc. Recently a new programming language, Vala, was developed which has native support for GTK's objects, signals, and properties. Its syntax is very similar to C# and its purpose is to allow very fast development of applications using GTK. (That's because using it in the original C does tend to produce very verbose code.)
- If you understand object-oriented principles (which is not necessarily everybody who's taken a Java course at university) then it's easy to learn.
- The library is divided into two main parts: GLib, the core library, and GTK, the GUI library. GLib has many features you will need for developing applications: all kinds of data structures, threads, regular expressions, key-value file parser, XML-like markup language parser (for full XML you need the libxml2 library though), ansynchronous I/O, networking. GTK contains everything graphical.
- It used to be that quite a lot of applications had the entire set of GNOME libraries as a dependency, but that's not the case anymore, since a lot of the useful functionality has been moved into GLib and GTK. You should be able to write a full-featured application without any extra dependencies.
- Look and feel depends on the platform. On GNOME, GTK basically defines the look and feel. On Windows, the native look and feel is emulated almost perfectly. On OS X, not so much.
- On Windows and OS X it takes some doing to get the libraries set up properly. OS X is especially a pain in the ass, where you have the choice between running an X11 server or using the harder-to-set-up Quartz backend. Qt is probably easier in that respect. However, your application's code is fully cross-platform and so should not require any porting to run on any of these systems.
I hope I've accurately represented the pros and cons for you.