You can diff JavaFX components like that?

--
Jason Zwolak

On Thu, Mar 17, 2016 at 12:51 PM, Timothy Baldridge <tbaldri...@gmail.com>
wrote:

> >> If the app-state has changed then it starts re-rendering the UI.
>
> That's pretty much exactly what fn-fx does in the latest version, with two
> caveats: 1) there's no timer, just a watch on an atom. 2) If you properly
> diff components you don't need to re-create them every time, just change
> the properties that changed. So if you have a text box 5 components deep in
> your app, and you change the background color, only the background color
> property of that single component will be changed, the rest of the app will
> remain unmodified.
>
> On Thu, Mar 17, 2016 at 10:37 AM, Jason Zwolak <jzwo...@gmail.com> wrote:
>
>> Paul, yeap, Seesaw is definitely something worth considering. Dave Ray
>> hasn't abandoned the project, but I sent a personal email to him asking
>> about the state of the project and it does seem the Seesaw is in more of a
>> maintenance phase than a continue to move forward and improve phase. Dave
>> Ray, if you're on this list, would you chime in?
>>
>> Also, I was at the talk you mentioned and was very impressed with their
>> methods. What wasn't mentioned in the talk was the fundamental structure of
>> the interface between Clojure and JavaFX. One point that _really_ struck me
>> is that they have a reoccurring timer running in the background and each
>> time it wakes up it checks for changes on the app-state (presumably an
>> atom, but I do not remember). If the app-state has changed then it starts
>> re-rendering the UI. If I remember correctly it recreates the UI components
>> that rely on any part of the app state that has changed. It sounds a little
>> similar to Facebook React. I questioned them on this approach as it sounded
>> strange to me... and they convinced me it's a good approach for their
>> project and inspired me to try something similar on my own... which I'm
>> secretly working on ;-)
>>
>> One thing that makes this work so well for their approach is that they
>> have animations that depend on the app state. So their reoccurring timer is
>> almost like a video algorithm redrawing the on screen image at the
>> specified frame rate.
>>
>> --
>> Jason Zwolak
>>
>> On Thu, Mar 17, 2016 at 11:06 AM, Paul L. Snyder <
>> p...@pataprogramming.com> wrote:
>>
>>> Yow, old indeed!
>>>
>>> In 2011, Dave Ray released Seesaw, which is a very nice wrapper for
>>> Swing.
>>> I've used it for a bunch of projects, and it works great. Of course, it
>>> does look like Swing, but it's plenty usable. (It's also still being
>>> maintained, so if you're looking for a toolkit that you can use right
>>> now,
>>> it's a good way to go.)
>>>
>>>   https://github.com/daveray/seesaw
>>>
>>> That said, I'd also love to see a JavaFX wrapper. At the Conj in Philly,
>>> Cognitect talked about a project where they'd used it extensively:
>>>
>>>   https://www.youtube.com/watch?v=ajX09xQ_UEg
>>>
>>> It's definitely piqued my interest.
>>>
>>> Paul
>>>
>>> On Sat, 12 Mar 2016, Jason Zwolak wrote:
>>>
>>> > +1 JavaFX.
>>> >
>>> > I know this is an old thread... but in case anyone comes across it
>>> (like I
>>> > did just now) and wants to see where things are, they should know that
>>> > JavaFX has come a long way and seems to be Oracle's replacement for
>>> Swing.
>>> > Now JavaFX is no longer only in JavaFXscript... in fact, I believe
>>> > JavaFXscript is deprecated in favor of the JavaFX Java classes.
>>> >
>>> > I've seen some major projects done with Clojure and JavaFX... even
>>> from the
>>> > guys at Cognitect.
>>> >
>>> > On Thursday, May 27, 2010 at 11:18:41 AM UTC-4, Luke VanderHart wrote:
>>> > >
>>> > > My side project is a fairly complex GUI application written in
>>> > > Clojure. Recently, I've become irritated with using Java interop for
>>> > > everything. It's not that Clojure doesn't have nice java interop - it
>>> > > does. It's just that when interacting with a GUI framework, which is
>>> a
>>> > > large part of my app, I have to be back in mutable object-oriented
>>> > > land, worrying about class hierarchies, mutable state, locks, etc.
>>> > > Yucky.
>>> > >
>>> > > So, with a perhaps dangerous lack of sanity and without any guarantee
>>> > > of success, I've decided to try my hand at writing an idiomatic
>>> > > Clojure GUI library. If I have success (which I doubt) I will of
>>> > > course make it available as open source.
>>> > >
>>> > > I intend for it to be mostly declarative, with a nice DSL for
>>> defining
>>> > > GUI elements. Each component will also implement map, and use one of
>>> > > Clojure's reference types as an interface for inspecting / updating
>>> > > its state. I may also implement some aspects of Functional Reactive
>>> > > Programming wherever it's convenient to do so.
>>> > >
>>> > > What you all must help me decide is what GUI framework to use as the
>>> > > underpinnings of it. It's genuinely hard to decide. I have at least
>>> > > some experience with all of them, so I have no strong preference, but
>>> > > I'd like to get your input. I did consider trying to make it abstract
>>> > > enough that you could plug in *any* of them under the hood, but
>>> > > there's enough differences between the frameworks that that would get
>>> > > very ugly very fast.
>>> > >
>>> > > Possibilities are:
>>> > >
>>> > > AWT
>>> > > Pros: native widgets, bundled with Java, low-level
>>> > > Cons: few widgets, considered somewhat obselete
>>> > >
>>> > > Swing
>>> > > Pros: bundled with Java, good widget selection
>>> > > Cons: non-native widgets
>>> > >
>>> > > SWT
>>> > > Pros: native widgets, widely used
>>> > > Cons: requires platform-specific libs
>>> > >
>>> > > QT Jambi
>>> > > Pros: native widgets, huge widget selection, highly-regarded
>>> framework
>>> > > Cons: requires platform-specific libs, writing custom widgets is
>>> > > hairy, momentum and support seem to be lagging since Nokia dropped
>>> > > official support.
>>> > >
>>> > > Remember, the actual API won't matter - that will be completely
>>> > > abstracted away. So try to focus on the framework's look and feel.
>>> > > Also let me know if I've missed any of the framework's key
>>> > > characteristics.
>>> > >
>>> > > Thanks!
>>> > >
>>> > > -Luke
>>> > >
>>> > >
>>> >
>>> > --
>>> > You received this message because you are subscribed to the Google
>>> > Groups "Clojure" group.
>>> > To post to this group, send email to clojure@googlegroups.com
>>> > Note that posts from new members are moderated - please be patient
>>> with your first post.
>>> > To unsubscribe from this group, send email to
>>> > clojure+unsubscr...@googlegroups.com
>>> > For more options, visit this group at
>>> > http://groups.google.com/group/clojure?hl=en
>>> > ---
>>> > You received this message because you are subscribed to the Google
>>> Groups "Clojure" group.
>>> > To unsubscribe from this group and stop receiving emails from it, send
>>> an email to clojure+unsubscr...@googlegroups.com.
>>> > For more options, visit https://groups.google.com/d/optout.
>>>
>>> --
>>> You received this message because you are subscribed to the Google
>>> Groups "Clojure" group.
>>> To post to this group, send email to clojure@googlegroups.com
>>> Note that posts from new members are moderated - please be patient with
>>> your first post.
>>> To unsubscribe from this group, send email to
>>> clojure+unsubscr...@googlegroups.com
>>> For more options, visit this group at
>>> http://groups.google.com/group/clojure?hl=en
>>> ---
>>> You received this message because you are subscribed to a topic in the
>>> Google Groups "Clojure" group.
>>> To unsubscribe from this topic, visit
>>> https://groups.google.com/d/topic/clojure/NkLXh8KYXqk/unsubscribe.
>>> To unsubscribe from this group and all its topics, send an email to
>>> clojure+unsubscr...@googlegroups.com.
>>> For more options, visit https://groups.google.com/d/optout.
>>>
>>
>> --
>> You received this message because you are subscribed to the Google
>> Groups "Clojure" group.
>> To post to this group, send email to clojure@googlegroups.com
>> Note that posts from new members are moderated - please be patient with
>> your first post.
>> To unsubscribe from this group, send email to
>> clojure+unsubscr...@googlegroups.com
>> For more options, visit this group at
>> http://groups.google.com/group/clojure?hl=en
>> ---
>> You received this message because you are subscribed to the Google Groups
>> "Clojure" group.
>> To unsubscribe from this group and stop receiving emails from it, send an
>> email to clojure+unsubscr...@googlegroups.com.
>> For more options, visit https://groups.google.com/d/optout.
>>
>
>
>
> --
> “One of the main causes of the fall of the Roman Empire was that–lacking
> zero–they had no way to indicate successful termination of their C
> programs.”
> (Robert Firth)
>
> --
> You received this message because you are subscribed to the Google
> Groups "Clojure" group.
> To post to this group, send email to clojure@googlegroups.com
> Note that posts from new members are moderated - please be patient with
> your first post.
> To unsubscribe from this group, send email to
> clojure+unsubscr...@googlegroups.com
> For more options, visit this group at
> http://groups.google.com/group/clojure?hl=en
> ---
> You received this message because you are subscribed to a topic in the
> Google Groups "Clojure" group.
> To unsubscribe from this topic, visit
> https://groups.google.com/d/topic/clojure/NkLXh8KYXqk/unsubscribe.
> To unsubscribe from this group and all its topics, send an email to
> clojure+unsubscr...@googlegroups.com.
> For more options, visit https://groups.google.com/d/optout.
>

-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en
--- 
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to clojure+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to