Richard,

it wasn't that you over-wrote it - the problem was I over-thought it.

My excuse is that I have been thinking quite a bit this last week about whether there was a (simple enough) approach to layout that would allow "rows & columns" semi-flow layout to be nearly automatic, and be possible to provide a UI that would make it practical (and quick) to provide extra guidance to such a system.

You message just happened to fit into that thought exercise - causing me to over-complicate things.

So my apologies. I think what you wrote was perfectly clear, it just didn't happen to be the same as I was working on :-)

Alex.

On 28/04/2020 16:22, Richard Gaskin via use-livecode wrote:
Very good thoughts there, Alex.

The assumptions you list would be important to keep in mind if one were aiming to generalize basic layout handling, with libraries that have nicely-designed APIs, or even further with virtual props that would lend themselves well to reducing things further to simple point-and-click authoring.

But in this exercise I'm making no assumptions at all; I'm just looking at the UI and writing purpose-built code to make it do what I want.

And with only a dozen lines, why not?

There's good value in generalizing app development.  Data binding is ripe with unexplored opportunities, as are field entry validation, window management, menu management, exception handling and reporting, socket comms, and many other things we write.

Sometimes we make tools or libraries to reduce the scripting we would use to deliver those.

Sometimes we generalize far enough to reduce it further to assigning the desired behavior with property settings which would then lend themselves to a point-and-click development workflow.

But often we just write a few lines of script to do what we want to do for the case at hand and be done with it.

The draft Lesson I posted serves only as a reminder that placing objects where we want them isn't all that deep, and if we use groups well we can reduce that scripting even farther.

That this wasn't clear in the writing suggests the draft is possibly too long.  "Set the loc of <object> to <loc>" doesn't really require a whole page.

Different apps require different code. Layout is the least of it. LiveCode is a scripting language.  We script.

And when we look at the apps we use from others, regardless what tool they're written in, we see those authors do the same thing: they look at their layout, consider what they want to communicate to the user, and put things where they want them to support that.

What I had tried to convey was that putting things where you want them is neither mysterious nor difficult in a nice language like LC.  Clearly I overwrote.


_______________________________________________
use-livecode mailing list
use-livecode@lists.runrev.com
Please visit this url to subscribe, unsubscribe and manage your subscription 
preferences:
http://lists.runrev.com/mailman/listinfo/use-livecode

Reply via email to