Is it really that easy?

My last post may have started a trend… based on a conversation I had recently I’ve started thinking about more areas that could benefit from some forward progress.

My Whole Home Automation project is based in ASP Classic at present, with VBScript the language of choice on the backend.  This has necessarily meant some familiarity with (D)HTML, Javascript, and obviously VBScript itself – not to mention SQL for the DBMS interface.  I’ve never blinked an eyelash at the level of know-how required to get all of this stuff done.  If anything, I figured that it must be trivial in light of the move to ASP.Net and what I perceived to be a marked increase in code complexity to go along with the marked increase in features.

And perhaps I was half on the mark and half off of it.  Sure the code itself can be more complex than VBScript, what with inheritance and classes and all the other good stuff you get with an OO-capable language (C#).  But getting down and dirty to the point of making something functional?  Oh, that only requires that you’re good with a mouse.

It’s all down to the IDE, the Integrated Development Environment.  And I’m here watching an intro video on the asp.net site where it took something like 2-3 clicks to make a DBMS-linked table, complete with end-user editing functions.  It’s so easy, a monkey could do it.  So surely this code-warrior could too, right?

To be honest, I’m dismayed.  Though I shouldn’t be surprised.  A recent article in Wired talked about making programmers out of everybody – that having a good idea but no programming skills shouldn’t keep your idea from seeing the light of day.  The article seemed to suggest that the real innovation today is with the developers who are making these drop-dead-easy design tools a reality.

I suppose it’s just how this industry works.  What’s complex and out-of-reach for the masses today becomes a commodity in short order.  Just look at the Kinect and all of the functionality it has afforded, which was once the realm of big money and big brains.

It almost makes me reluctant to go the ASP.Net route, if only because it seems that it makes things *too* easy.  But it’s hard to argue with the notion of concentrating on ideas->reality rather than ideas->how?->reality.

Perhaps there’s hope for me in the Perl and/or PHP arena.  Ahh, LAMP, embrace me in your searing glow.

Fateful decisions

Fear not, there will be no dark foreboding here 🙂

I’ve made a couple of game-changing decisions recently.  One, is that Android is definitely in my smartphone future.  Two, is that UPnP is in my Home Automation future.

We’ll look at each decision in order.

Android

My PDA/Smartphone history started with Palm and has been mostly devoted to Windows Mobile.  Then, Microsoft decided that its mobile future lay in Windows Phone 7, thereby rendering Windows Mobile 6.x a parent-less drifter.  This isn’t entirely true, as they’ve pledged to support 6.x in the enterprise space; but for consumers, Windows Phone 7 rang the official death knell for WinMo 6.x.

I honestly can’t recall the timing, but around this time last year I decided that my TyTN wasn’t cutting it anymore and I sourced a used HTC Touch Pro, which I promptly upgraded with a WinMo 6.5 build.  It was never my intention to use this device for Many Years To Come(tm), but I think I was looking to get maybe two years out of the thing.

And, if push came to shove, I probably could deal with the software limitations.  But I’ve been getting increasingly frustrated of late over touch sensitivity, system lockups, speed… the gamut of issues that people typically cite when thumbing their noses at Windows Mobile.  Add to that the GPS that I’ve all but abandoned, since it seems almost impossible to get a lock these days.

It’s a crying shame, to be honest.  I don’t have money to be throwing around on phones, and I never want/wanted to be one of thoese people who buys a new phone every year.  I was either blindsided by Windows Phone 7, or didn’t take the threat seriously, but when that OS was announced and devices actually started shipping – well, my 2-year investment dead-ended rather quickly.

The larger problem is the dearth of development activity.  No reputable company is releasing WinMo apps anymore.  It goes without saying that iOS and Android are occupying the hearts and minds of mobile developers across the globe.  More accurately, Windows Mobile is on nary a developer’s lips.  So the gist is that I’m stuck with buggy/slow versions of mildly interesting software (Facebook, Twitter), and staples – like my software keyboard and UI shell – are frozen in time, bugs and all, and I’ve got to deal with said bugs every single day.

Don’t get me wrong.  When the software is running smoothly, it’s All Good(tm).  Unfortunately, I get hair-pullingly frustrated even after 2 or 3 soft resets in one day.  Nobody should have to reset their phone 2 or 3 times a day.  And then there’s the one thing, the most intrusive and dasterdly demon of them all – the resistive touchscreen.

Sure, pinch-to-zoom would be nice.  I can live without it – for now – but what I can’t live without is accurate touch response.  I’m sick and tired of trying to scroll but selecting an item instead, or trying to select an item but scrolling instead.  And this isn’t the sort of thing that happens, oh, once or twice a day.  It’s a regular occurence!  It’s so annoying that I toyed with the idea of writing a touch driver to smooth out inputs, but that’s a large undertaking whose value is severely lessened by the diminished attractiveness of the platform as a whole.

My recent foray into tablet research opened my eyes to the wondrous world that is a modern mobile OS.  Even Shelly’s Nokia E71 has outshined my Touch Pro since the moment her phone came into our house.  She has jokingly said to me – on more than one occasion – “It’s okay Deryk, you can have my phone”, as a result of my penchant for Getting Things Done(tm) on her phone quickly and easily.  The problem with her phone is that it’s not a touch device, and it’s not a slider.  Those things aside, she has nothing to be ashamed of for wielding that thing.

Although, she’s pined for an Android device herself.  I think she’s been starstruck by the touch experience in general, with all the whiz-bang animations and such.  But she’ll also put on her Practicality hat, and realize that nothing beats a hardware keyboard and numeric keypad when it comes to calling people and texting/emailing.  I can even navigate faster in Opera Mobile on her phone, with the D-Pad, than I can on my phone using touch or the D-Pad.

But I digress.  Being somebody who values functional technology, rather than having the latest and greatest (witness my T1i when the T2i was already out), I was rather impressed at how easy it is to get things done when using a modern mobile OS.  And there are two pieces to that particular puzzle: a capacitive screen and properly-tuned touch driver, and native apps that are constantly refined under the banner of getting things done easily and accurately.  My Touch Pro has neither of these things going for it, and it shows.

This culminated quite nicely (and shockingly) the other day when I realized that I don’t want to have to tweak my mobile phone anymore.  It should just do what I want, period.  I’ve never been big on custom wallpapers and ringtones – everything I’ve tweaked on my Touch Pro has been to make it useable, not to make it fancy.  I decided that I want my device to be useable from Day One(tm), and I want somebody out there working to make it useable throughout its useful life.

I also like a pure experience.  And it may surprise you to learn that, if I did get an Android phone, I’d either want to flash a stock, non-branded ROM – or install a credible custom ROM like CyanogenMod 6.1.  But really, that’s as far as I’d want to take it.  I thought I’d be able to do the same sort of thing with the Touch Pro and the Energy series of ROMs, but again – people are moving away from WinMo, certainly from the TouchPro.  Regardless, you can’t tweak away a resistive screen, or the other things that probably could be nailed down in time by the ROM developer but which won’t be nailed down by the ROM developer since nobody wants to develop for the platform anymore.

So why Android?  I played with a Windows Phone 7 device in the stores, but from the first set of leaked videos it was apparent to me that Windows Phone 7 would not be in my future.  I’m a developer at heart – and I have a very strong feeling that Android is the closest you can get to development/tinkering nirvana.  Windows Phone 7 is getting a very glossy treatment as a social, consumer device – just look at the supporting ads that are airing, citing the ability to get in and get out quickly.  But it’s a guided experience that I don’t care for.  I’m quite content to run a Facebook app when I want to see what’s going on on Facebook.  I would not be at all content to have Facebook’s crap smeared all over my phone in every nook and cranny.

And iPhone?  You should know how (un)impressed with the whole walled-garden approach in general.

Really, I probably would have skipped the Touch Pro and gone straight for a Milestone if not for a few reasons:

  • holding out for carrier promotional pricing (the Milestone never showed up on Rogers)
  • a preference for HTC hardware vs. Motorola hardware
  • wanting to see how dominant the Android platform became

Let’s face it though – what I’m really talking about is obsolescence.  And it’s true that every piece of consumer electronics out there is obsolete as soon as it hits the store shelves.  Wouldn’t it be the case that anything I got now – Android-based or otherwise – would suffer the same fate, and I’d find myself back here in a year?

I’m not entirely convinced of that.  I pride myself on having a particular set of criteria, and not compromising on that core set.  I’m not trying to chase the latest and greatest, I’m simply trying to get something that works for me.  I never believed that the Touch Pro would be my main phone for the forseeable future; rather, it is/was a stopgap since the TyTN couldn’t get my basic needs accomplished anymore.

Well as it happens, the Touch Pro now has certain limitations – some of which are inherent, like the finicky GPS and crappy camera – and others which only became apparent after trying to make the device do what I had envisioned it doing.  My expectation of the Touch Pro is that it’s finger-friendly, as this was one of the primary reasons why I sought to replace the TyTN.  And while the Touch Pro is more finger-friendly than the TyTN, it has become apparent – after a year of using it in a manner that the TyTN could not support – that a resistive touchscreen simply cannot get the job done.  This is not something I would have known implicitely from using the TyTN in this capacity, as the TyTN had other problems which restricted its finger-friendly usefulness.

Basically, the software and hardware of the Touch Pro was never designed for a seamless touch experience.  Even the latest versions of WinMo cannot make this claim, as the shell itself simply is not designed appropriately.  However, even a device like the HTC G1 – with a capacitive screen – has a leg up, despite its age.  And yes, you can flash CM6.1 to a G1 and have the latest Android kernel on your old device (well, the latest up to a few days ago, when 2.3 was released).  The hardware wouldn’t be as svelte as a G2, the camera not as nice, the processor not as speedy – but assuming you could live with those things, the fact of the matter is that you would not be left behind in the software world.

Yes, you have to consider things like available memory, and that’s something that you can never beat without investing in new hardware.  But for comparison, here it is that I’ve installed all my apps to the Touch Pro’s internal memory and I haven’t really had any memory issues to speak of.  I think it’s the case that most modern smartphones have way more memory available than you actually need – particularly somebody like me who is very adverse to storing media on my phone.

Ultimately, the undeniable truth here is that it’s time for me to switch platforms.  And I have to tell you, the prospect is exciting, if only because it means learning something new – and if you know me, you know that I like to learn.  I don’t often do an “out with the old, in with the new” paradigm shift, but when it happens it does make me quite giddy at the prospect of building a whole new suite of solutions that I simply could not do before.

Android is now mature, in my mind, and the hardware is at that point that I believe it could serve me adequately for the next three years.

UPnP

This is another doozy.  I’ve spent the last, what, 3-4 years (longer?) designing this Home Audio system and making incremental updates to the interface and backend. I had visions of a very dynamic interface with DHTML transitions galore and loads of AJAX.  And that’s admirable, but it’s time for more.

Again, this was partially spurred by my tablet research, and a major dislike of placing media – music, photos, videos – on any one particular device.  My belief is that those things should be “in the cloud” and accessed on demand.  Not the Google cloud, not the Amazon cloud – rather, my own personal cloud.

My approach has always been network-centric, where devices are simply clients to my network.  The Home Audio interface is an example of a project that encompasses both the network – the DBMS, the filesystem – and the client – the physical zones and SHOUTcast servers.  But it’s still closed in that you can’t take full advantage of the network unless you pass through the web interface first.

And for physical zones, this is fine.  For consuming media on tablets, not so fine.  But I don’t want to just throw a media server on my network and let it have at my filesystem.  One – that’s not very challenging.  Two – it sidesteps years of development work on my part, and it doesn’t allow any future development.

I realized the other day that my approach to my Home Audio setup may have been the Right One(tm).  It’s all HTTP-based.  It’s all database-driven.  A new media server would have to catalog my filesystem in its own native database in order to function.  Well, why reinvent the wheel?  Why throw away design and useability decisions that I’ve made?

In this modern age of standards, there’s no reason why I can’t take the work I’ve done and evolve it to support different types of clients.

That’s where UPnP comes in.

So my current design goals are to add UPnP support to my Home Audio system.  And by extension, this will actually allow my media to be consumed by a UPnP client device.  I can finally rip my movies to disk and play them on a wide array of devices.  I’m getting a little ahead of myself here, but even without a single UPnP client on my network today I can say that I firmly believe that this is the correct direction to go in.

Tablets – ready for (my) primetime? [updated 01/27/12]

I’ve heard a yearning for a tablet for a long time.  I made a (misguided) foray into the world of pen computers, scoring a used device on eBay some number of years ago.  Suffice it to say that that particular puppy hasn’t seen the light of day in some time.

The iPad is now all the rage.  And while I understand the allure of the device, and the particular niche it fulfills, the more I look at the iPad for my intended purpose the more I’m realizing that there are way too many shortcomings to even consider dropping $600+ on the thing.  And unfortunately, the same goes for the Samsung Galaxy Tab, the current champ in the non-Apple tablet world.

Here’s the thing.  I’m not looking for a device to carry around with me.  That’s what a smartphone is for.  Which isn’t to say that I wouldn’t want to travel with the tablet; rather, it would tend to “live” mostly at home.  So I’m not particularly adverse to the 10″ form factor; weight may be an issue, but if we’re talking solely about “portability” then there’s nothing wrong with 10″.

Now, I decided a long time ago that every portable device deserves a wireless connection.  I didn’t spend long with my Compaq iPAQ 3630 before an expansion sleeve and PCMCIA WiFi card were ordered.  Fortunately, any modern computing device worth its silicon has a myriad of wireless connectivity options – one of which is “3G”.  The carriers love to push this, as more 3G-toting users means more revenue.  But again, given that my intended use for a tablet is for home use, I’m pretty sure I can get by with WiFi – and tether to my smartphone whenever truly mobile connectivity is needed.

So what of these shortcomings?  I’m getting to that.  And in order to get to that, I have to talk about the fact that these devices are actually quite capable little devices.  The Tab, in particular, feels very powerful to me.  It screams “computer” much more than the iPad, and that’s not a bad thing.  It does its job so well, in fact, that I’m chomping at the bit to cram an Android smartphone into a pant pocket.  As a mobile platform, I must say that Android is getting it done quite nicely.

The iPad, on the other hand, still comes off as a large toy.  I just can’t shake the feeling.  Sure, you can run cool apps, but I’m not looking to run cool apps at home.  My home needs for a tablet are quite modest – surf the web, control my home automation systems, check email.  It really doesn’t have to get more complex than that.

And in that vein, the Tab also falls short.  Every time I pick up a Tab I feel like I should be putting it in my pocket and carrying it around with me for the entire day.  This is not a feeling I want to get from a device that’s supposed to live on the living room table.  I think that Samsung is intending the tab to be a mobile, portable device – but that’s not the niche that I want it to fill.

Then there are more tangible shortcomings – like the complete and utter lack of multi-user support.  Some of the coolest things you can do with the iPad and Tab come from using the native apps, which are the most pure reflections of what the manufacturer intended you to use the device for.  And some apps, like email, are very personal in nature – do I want some house guest to pick up my tablet and start reading my email?

And so… I’m conflicted.  On a few fronts.  I don’t like Apple’s walled garden, but I think I do like the 10″ form factor.  I like Android’s utility, but I don’t want/need my tablet to be that powerful.  So what am I saying, really?

One, is that none of the tablets on the market now are going to get the job done for me.  I mean, I’d take either one if I won it (though I’d probably sell the iPad), but there’s no way I’m paying $600+.

Two, is that I know what I need:

  • multi-touch interface
  • capacitive touchscreen
  • tabbed browser with Flash support

I think I’d like a capable built-in media player, but I do not want to store media on the device.  Not even pictures.  Any media should be streamed over the network  – perhaps using UPnP or DLNA.  And while I’m not adverse to accessing a marketplace and running other native/3rd-party apps, I think that this capability must go hand-in-hand with the some sort of fast-user-switching ala Windows XP Home.

Until these criteria are met, I may find myself sitting on the sidelines of the tablet game.

[update 2011/08/30]

Interesting article from Engadget, questioning the tablet’s position as a productivity device and the real necessity for a “third device”.  At this point I really wish I had scored a $99 TouchPad – not quite “taking one if I won it” that I mentioned above, but close enough.  Oh well, so it goes.  I figured I could move run an Android port on it as soon as that technical feat was accomplished.  Surely it wouldn’t be long, right?  But something strange happened when I played with a TouchPad in-store for 30 minutes or so, followed by a couple of Honeycomb tablets – I was far more impressed with WebOS than Honeycomb.  In fact, Honeycomb felt like the cross between a media device and a mobile computer that I alluded to earlier in this post, to the point that the promised functionality belied the limitations of the device (reported so well in that Engadget article).  I suppose that experience reaffirmed an earlier tweet I had made that WebOS on a tablet would be killer.  It’s unfortunate that software support will be lacking though; I did note some issues with the native web browser, and it’s very questionable how timely updates would come out (if at all) to address such issues.  If a port of Honeycomb or even Gingerbread ever surfaced for TouchPad, then certainly updates would be frequent – but again, Honeycomb felt like an entirely different beast, with WebOS wearing the tablet pants much better than Honeycomb.

So it seems that not much has changed.  My requirements still remain the same – multitouch with tabbed browsing and Flash support.  If anything, I’m now more convinced of the things that I don’t want – ie, a tablet with a complex interface.  Keep It Simple Stupid.

Even the multi-user conundrum has a workable solution on WebOS.  Firstly, I imagine that the only player who will solve this problem outright is Microsoft with Windows 8.  And I already know that such a tablet will be insanely expensive and too powerful for the light duty I’d want it to perform.  Secondly, a tablet’s increased real-estate means that visiting webpages is a very practical alternative to running the dedicated app (think Facebook, Gmail, etc).  Thirdly, I’m not of the mind that – even at $99 – it makes sense for a household to have multiple tablets for the sole purpose of casual usage; quite simply, it’s an unnecessary indulgence and a real distraction.

So how is the conundrum solved?  Whether through fast-user switching (ala Windows) or actively logging in/out, the fact is that a multi-user system requires a user to reauthenticate and “unlock” the device.  Now, if you’re working on a tablet that’s little more than a casual media consumption device, I can imagine that it’s enough to do this un/lock dance on a per-“app” basis.  And the ability to login and logout is something that every website application presents as a matter of course, but no native tablet app presents as a matter of course.  Many people are probably used to doing so within their web browsers.  So right there, the “requirement” to run the web version of your “productivity” apps – and crucially, the ability to do so on a generously-sized screen – means that you don’t have to worry about somebody sticking their nose into your private data.

But here’s where WebOS shines.  If I’ve got a video open on the family tablet, or a series of webpages – neither of which are “private” – then somebody else can pick up the tablet, stack my open apps, and open their own apps and webpages.  And so you end up with a shared user space, where each user’s resources are sitting in their own stack.  When I want to use the tablet and restore the state of my “apps”, I stack all other apps and unstack mine.  And finally, since we’re talking about a simple tablet here, I can imagine that each stack would only be a handful of cards deep – ie, very manageable for both user and system.  I certainly wouldn’t have 10-15 apps open simultaneously like I tend to do on a desktop computer.

I’ll say it – it’s unfortunate that TouchPad went from overpriced at $500 to unsupported at $100.  A happy medium may very well have been $150-200.  Here’s to hoping that WebOs lives on and that somebody picks up the hardware mantle.  Certainly everybody has seen that there’s demand for a non-iPad tablet at a lower price point?  It doesn’t have to compete with iPad; rather it just needs to fill the niche that the $99 fire-sale flushed out.

[update 2012/01/27]

Well well well

That may change things.