Sunday, August 31, 2008

Branding 101

A while ago there was a big effort to make all the various "official" GNOME web sites consistent in some minimal way.  The reason for this was the reconition that "branding" is important.

So, imagine you are a potential new user or reporter trying to figure out what GNOME is all about by checking out the GNOME info-web.

Currently, if you Google for "GNOME", you get the correct result (for us): the first hit is http://www.gnome.org, check.

On this page the top line navbar elements are
  1. News (news.gnome.org), didn't load for me today
  2. Projects (www.gnome.org/projects)
  3. Art (art.gnome.org)
  4. Support (www.gnome.org/support)
  5. Development (developer.gnome.org)
  6. Community (www.gnome.org/community)
From a cursory top-level examination the potential convert or evangelist will find that
  1. There is no news (OK, maybe that's a transient error)
  2. There are a mixture of headers navigational elements in the "official" GNOME web (art, developer)
  3. The developer docs are extremely out of data
So far not good, but maybe not too bad.

But what if you Google for "GNOME support"?  Currently the first hit is http://gnomesupport.org.  Seems reasonable.  But you get to a site that at first glance looks nothing like the "official" GNOME sites.  Maybe this is a third part ("Community") site?  Who knows?  You certainly can't tell from the page itself.  The "About" link doesn't tell you about gnomesupport.org, it takes you to http://gnome.org/about; probably not what you'd expect.


All in all, not a good first impression.  And it seems so easy to fix.  We tried to fix this in the past.  Why couldn't we?

Why am I led to the conclusion that the people in control of those sites just don't care about the user-facing side of their efforts?  I'm not saying that's a bad thing, but rather there seems to be a disconnect about what we say and what we do.  If we really care about the users, why do we make life harder than it needs to be for them?

Did I say "them"?  Sorry, I meant "us".

Update:

The first comment on this post shows exactly the problem with many open source and Free software developers attitude to users:

"Why do you switch from 'why couldn't we' to above accusation?

Everyone having SVN can improve. Instead of asking who does it, do it already or quit complaining, too easy."

I rest my case.  Developers don't care about users.  If a user offers constructive and actionable feedback, the guaranteed reply is "do it yourself".  Is it any wonder we haven't acheived Word Domination, or at least 10x10 by now?

But I'm not bitter.  I will stick with GNOME until I die, and weather the flames generated from trying to help.

Peace and love,

John

Sunday, August 03, 2008

Visions of GNOME 3.0

Introduction

I've been silently digesting all the GNOME 3.0 thoughts for a while now. Then, yesterday, I installed KDE 4.1 and all of a sudden things kinda crystallised in my mind. I'm a marketing person, so I tend to think in terms of users; and user needs and wants.

In what follows, I will assume that in any GNOME 3.0 release the GNOME 2.x values (Powerful, Simple) will be incorporated. I would like to see GNOME's next major release add to that list and I've got a tag-line all ready: GNOME 3.0: Helpful. In what follows I will try to explain what this means and why I think it's a good idea.

What do you mean, "Helpful"?

I mean that GNOME (the development platform and the bunch of officially blessed applications that comprise a release set) is a set of enabling technologies that enable developers and users to get stuff done using computers without putting barriers in the way. In other words, user experience.

What, then, are the barriers that get in the way of getting stuff done? What would produce a qualitatively different release of GNOME, one that makes using it feel different?

Uninterrupted workflow

Has it worked?

Why, why, why does it take the simplest of applications (a text editor or a terminal) more than a second to start up? At least there's a little animation to tell me that my request is being considered, but why is it taking so long? Should I be worried? And if the animation happens for requests (commands) that take a long time, why doesn't it happen for all of them? Many times I've clicked on the update manager icon in the panel twice (with a delay of a second or two between clicks) because nothing seems to be happening. And then, of course, I get two instances of the application running (eventually).

This behaviour interrupts work-flow and train-of-thought. Application startup time is a seemingly small issue, but consider how it would feel to use a computer when there was more-or-less instant reaction to user input. It would become a qualitatively different experience.

With the work on GNOME-Mobile underway, can we get that work for re-jigging GNOME to work well on resource-constrained machines back into "mainstream" GNOME? Please? That would be really helpful.

Has it crashed?

Why, oh why, do applications fail to repaint the screen or respond to user input (mouse clicks, for example) while they are waiting on disk or network I/O? Has the application crashed (and do I need to kill it?) or is it actually working "normally"? Do I have do interrupt what I'm doing to attend to it, or shall I just wait?

It has crashed! Why?

OK, so a GNOME application has crashed. What do I do now? Start it again and hope it doesn't crash again? And if I got an error message, does it actually give me (a non-programmer) a clue about what to do in order to prevent it crashing again? If it's a problem that others have faced and solved, can I get their solutions quickly and easily? (Reverse Bugzilla?)

Helpful summary

So, priorities for GNOME 3.0 from the user-experience point of view. In summary we need to increase responsiveness:
  1. Reduce application startup time

  2. Eliminate blocking UI on I/O

  3. Automatic bug reporting

  4. Automatic bug solution/work-around suggestion
That would be helpful.

Mutual Help

All the above is about developers helping users. But how can users help developers? By writing documentation, of course! But it be "user" we mean "non-programmer", how easy is it for a user to "contribute" to the community rather than just taking?

User-contributed Documentation

It seems to be a truism that programmers hate to write documentation. Well, maybe not hate: probably they've just got better (more interesting) things to do. So let's harness the type of goodwill that gets people posting to user-to-user help forums and writing Wikipedia articles. But let's not start another "social networking" web site. Let's put the good stuff into the documentation that comes with the software.

Currently in order to do that a user must learn a markup language, and hence a write-compile-test cycle of working. Probably a (D)RVCS system too. Can't we create a tool that would make it easy for a user to submit an edit to existing documentation (including tool tips) or create an entirely new chunk of documentation? People would actually use it.

Then we'd need an editorial layer. The maintainer(s) and their trusted lieutenants need to do that. But "trusted lieutenants" need not be other coders. They could be simply particularly clueful users. But they'd need easy-to-use tools.

That would be very helpful.

Summary

I've written about things that bug me when I'm using my computers: things that get in my way, make me focus on the software rather than what I'm trying to do. Addressing these issues is not trivial, but it would produce a quantum leap in user experience compared to any other GUI that I've ever used (including various versions of Windows and OS/2).

Why should you care? GNOME will never, ever, gain significant market share if it's at least as good as the alternatives, with the additional benefit of being Free. Only if it's obviously, immediately, better than the alternatives will it grow, What is "better"? Well, "not so annoying" would be a good start.

I've written about helpfulness from the user's point of view. Perhaps someone who knows could write about it from the developers (ISVs?) point of view?