r3wp [groups: 83 posts: 189283]
  • Home
  • Script library
  • AltME Archive
  • Mailing list
  • Articles Index
  • Site search
 

World: r3wp

[View] discuss view related issues

Anton
22-Aug-2005
[2276x2]
That's a frustrating one. It would be so beautiful if that were implemented...
Robert, you can see http://www.rebol.com/docs/view-system.html#section-10
for more insight on how pane functions work.

An iterated face function is there to save memory, so it must be 
executed every time the display is refreshed. It creates the illusion 
of many faces by moving one face around very quickly.
It does not create and position new faces like LAYOUT.

What LAYOUT allows you to do is set up the pane function that will 
be used afterwards when SHOW is used or VIEW is used and events start 
flowing.
Geomol
22-Aug-2005
[2278x2]
Anton, maybe this is to way to do it? It seems to work:

change at image1 5x5 copy/part at image2 10x10 20x20
Using skip here seems to work aswell:

change at image1 5x5 copy/part skip image2 10x10 20x20
Anton
22-Aug-2005
[2280]
Yes, that is the way to do it.
Geomol
22-Aug-2005
[2281]
Makes me wonder about the difference between 'at' and 'skip'. Both 
are actions.
Volker
22-Aug-2005
[2282]
1.
Henrik
23-Aug-2005
[2283x2]
say I have: layout [a: tog true of 'panel b: tog of 'panel c: tog 
of 'panel]


what's the correct way for setting b to true so that a, b and c still 
behave as part of 'panel?
b to true = b/state to true
Gabriele
23-Aug-2005
[2285x3]
Henrik, this is the engage function for toggles:
engage: func [face action event][
    if find [down alt-down] action [
        if face/related [
            foreach item face/parent-face/pane [

                if all [flag-face? item toggle item/related item/related = face/related 
                item/data] [item/data: item/
state: false show item]
            ]
        ]
        face/data: face/state: not face/state

        either action = 'down [do-face face face/data] [do-face-alt face 
        face/data]
        show face
    ]
]
you should basically do the same thing (the foreach above)
[unknown: 5]
23-Aug-2005
[2288]
Someone had contacted me a month or so ago and asked for my modified 
text-list and was looking to make some updates.  I don't recall who 
it was but if your here - can you tell me if you improved such.
Henrik
24-Aug-2005
[2289x3]
paul, was that the one which supported custom colors per line?
I remember such a discussion, but that was 3-4 months ago. I didn't 
get anything done with it.
I'm working on a different implementation with a more advanced list 
system instead
Henrik
25-Aug-2005
[2292x2]
pekr, have you any private solution to the face accessor problem 
you mention so often?
gabriele, thanks. it works now :-)
Pekr
25-Aug-2005
[2294x2]
Henrik - no, I don't have any ....
I am more busy implementing some solutions so I only think loud from 
time to time :-)
Henrik
25-Aug-2005
[2296x2]
ok, but I'm anxious for a patch solution right here, mostly so that 
I can access numerous face/text's through a single object
it would be nice to find a working equivalent to:
>>a: make object! [b: 1]
>>c: a/b
>>c: 2
>>a/b
== 2 ; but actually returns 1...
Ladislav
25-Aug-2005
[2298]
c: in a 'b
set c 2
Henrik
25-Aug-2005
[2299x2]
ah, wonderful
not so wonderful:
>>layout [a: field "rebol" b: field "rules"]


>>fields: make object! [atext: in a 'text btext: in a 'text] ; how 
to bind a/text and b/text correctly?
>>fields/atext
== text ; word! incorrect

or:

>> fields: make object! compose [atext: (in a 'text)  btext: (in 
b 'text)]
>> fields/atext
== "rebol"

but then:
>>set in fields 'atext "test" ; incorrect way, apparently
>>fields/atext
== "test" ; good

>>a/text
=="rebol" ; but it didn't propagate back to the face....
Ladislav
25-Aug-2005
[2301]
layout [a: field "rebol" b: field "rules"]

fields: make object! [atext: in a 'text btext: in a 'text]

get fields/atext
Henrik
25-Aug-2005
[2302]
ok, that works, and if I would want to traverse all textfields in 
one go I started with:

>> set fields/atext "test" ; which works for one field

for multiple fields, I want to set each fields from an object:

>> inserts: make object! [atext: "rebol" btext: "rocks!"]

>> foreach i next first fields [attempt [set get in fields i get 
in inserts i]]
>> show [a b]


Fields are now changed properly in one go. Now I need to show the 
values in the foreach loop. I also need to allow the elements in 
the inserts object to be of arbitrary order.
Gabriele
25-Aug-2005
[2303]
>> view/new layout [a: text "Hello" b: text "World"]
>> fields: reduce [in a 'text in b 'text]
== [text text]
>> set fields "New" show [a b]
Henrik
25-Aug-2005
[2304x4]
Gabriele, interesting, but if I run
set fields "New" show [a b]
and do it multiple times with different strings, only the last one 
is set
hm... something with string lengths and the size of the textfield. 
:-) forget it.
Anton
25-Aug-2005
[2308x2]
set [a b c d] 1  ; this sets all of A B C and D to the same value, 
1.
set [a b c d] [1 2 3]   ; this sets A == 1, B == 2, C == 3, D == 
none.
Henrik
25-Aug-2005
[2310]
ok, not thoroghly tested but:

set-faces: func [faces data] [
  set

    reduce foreach var faces [insert tail [] compose [in (var) 'text]]
    get data
  show faces
]

view layout [a: field b: field c: field d: field]
faces: copy [a b c d] ; generate this from the layout?

data: make object! [a: "Eeny" b: "Meeny" c: "Miney" d: "Mo"]

set-faces data faces ; whammo!
Gabriele
25-Aug-2005
[2311x3]
hmm, i think what your are trying to do is what the panel accessors 
do by default (warning: a bit bugged, but easily fixable)
>> layout [pan: panel [a: field "something" b: field "else"]]
>> print mold get-face pan
[a: "something" b: "else"]
>> set-face pan ["Hello" "World"]
>> print mold get-face pan
[a: "Hello" b: "World"]
set-face does not allow [a: ...] while it should. I have a fix for 
it if you are interested.
Henrik
25-Aug-2005
[2314x2]
ok, I have to read up on 'panel first :-)
if it's documented...
Gabriele
25-Aug-2005
[2316x2]
you could set the window accessor object to the default panel accessor 
objects, so that you can do the above with the window directly too.
using panel is useful if you have more than one panel in the window.
Henrik
25-Aug-2005
[2318x2]
hmm... it actually does exactly what I need
basically I'm interested in taking the contents of an object and 
put it in various faces in a layout in one go
Gabriele
25-Aug-2005
[2320x2]
what i do exactly.
my-access: make ctx-access/panel [
    set-face*: func [face value /local val][
        if all [block? face/pane block? value][
            either set-word? value/1 [
                foreach [word val] value [
                    set-find-var face/pane to word! word val
                ]
            ] [
                foreach f face/pane [

                    if any [find f/flags 'input find f/flags 'panel] [
                        if not empty? value [
                            set-face f value/1
                            value: next value
                        ]
                    ]
                ]
            ]
        ]
    ]
]
JaimeVargas
25-Aug-2005
[2322]
Gabriele should your fix make it to the default distribution ?
Gabriele
25-Aug-2005
[2323x3]
then use Panel with [access: my-access]
Jaime: it should. as soon as I get the chance to work on mezz code 
again.
with that you can do:   set-face panel third object