fullmoon wrote:
What about the ability to define a block as "For all sprites" or "For this sprite only"?
bbbeb wrote:
IMO it should be like
[ [block here] as [ v]]
whereas the dropdown says:
private (or for this sprite)
public (or global)
That would fit well.
Offline
bbbeb wrote:
fullmoon wrote:
What about the ability to define a block as "For all sprites" or "For this sprite only"?
bbbeb wrote:
IMO it should be like
[ [block here] as [ v]]
whereas the dropdown says:
private (or for this sprite)
public (or global)
That would fit well.
Yeah, I figured someone had probably suggested it already! But your post makes it look like you're proposing some sort of block. I think that block scope should be chosen the same way you choose variable scope, in a dialog. But now I'm thinking in terms of BYOB; it doesn't look like there will be a block dialog in 2.0.
Offline
In the prototype that Lightnin described, a user-defined block is constructed in the scripting area of a specific sprite. There are three good things about this approach.
First, it supports a bottom-up approach to building a block: the user first creates a useful stack, then turns it into a block. One can also define blocks in a top-down manner (i.e. start with block definition hat and add blocks to it), but the bottom up approach provides a natural learning path: one first learns about individual command blocks, then how to make stacks of blocks, and finally how to turn a stack into a user-defined block. The final step -- adding a procedure definition hat to an existing stack of blocks -- is done in the familiar context of the scripts pane.
Second, defining a block in the context of a specific sprite allows it to be incrementally tested and debugged. One can click on the block definition to run it, just like any other stack of blocks, and observe what the sprite does as a result.
Third, defining blocks in the context of a sprite means that all the sprite blocks are available in the palettes. In contrast, if blocks were defined in the context of the stage, the stage's command palette lacks sprite-specific blocks such as the motion blocks. One might worry that defining blocks in the context of a sprite means that stage-specific blocks could not be used. Fortunately, all the stage commands are available in the sprite palettes, although a few operations have different names (e.g. "next costume" vs "next background").
So, there are many good things about the process of defining a block in the context of a specific sprite. However, once defined, a (global) block can be used by *any* sprite. When viewing an unfamiliar project, where should a user look to find block definitions? That's the question we've been puzzling over, and for which many of you have offered excellent suggestions (thanks!). Your suggestions include the stage, a "definitions" area just for user-defined block definitions with a thumbnail below the stage, and an additional tab in addition to scripts/costumes/sounds. My own current favorite is a sort of "drawer" that opens up from the bottom (footer) of the scripts pane, first suggested by webstermath. This would allow blocks to be dragged between the scripts pane and the procedure definitions drawer. But that's just my opinion; the Scratch team will continue to think about (and debate) this issue.
Thanks again all the great ideas!
Offline
headfones wrote:
Wow that's awesome
I could make my whole huge timer system into one block
Wait --- don't! It actually adds more data to the project. The project needs the code to run custom blocks and it's scripts!
Offline
Lightnin wrote:
For one thing, it's nice to be able to see the custom block and its definition scripts on the same screen.
Hi, Lightnin! Sorry I've been busy for a while and got three pages behind on this thread.
I'm not really sure why you and John put so much emphasis on seeing the block in the palette and seeing the definition at the same time. First, you can do that with a separate block editor window; it doesn't hide the palette. Second, the whole idea of putting the block prototype in the hat block is that it looks like the block! (I think that should be even more true than it currently is in BYOB; when we next have time for UI details I think we should have the orange formal parameter blobs be rectangular, rounded, hexagonal, etc., to match the input type. We already show the default value, if there is one, along with the formal parameter.) So when you're looking at the definition you already see the block.
One related question we discussed with you guys a long time ago is whether a custom block in the palette should be marked as custom. I lean toward not marking them; the pedagogic point is that custom blocks, once made, can be used exactly like a primitive block. But if you want to mark them (as John did in that conversation iirc), you can mark them with a button that brings up the definition.
But this brings up questions - like: Should custom blocks be "global" (i.e. all "Jump" blocks are the same across the entire project. If you change one, you've changed them all) or "local" to the sprite (each sprite can have their own unique "jump" block). And of course: where should the script definition live?
i.e. If I make a scratch project with gobo and Scratch cat in which both use "jump" but the definition of jump lives in the cat, what happens when I export the gobo sprite? Does it just get a copy of the jump definition? What happens if I make changes to the jump definition in Gobo and then import it back to the same project - then you have a conflict between the definitions of Jump on Gobo and on the Jump on Scratch Cat (assuming everything is global). Actually, that's making me think we should have the concept of global / local: It's better to try to explain that concept than to have people try to merge different definitions for custom blocks when importing sprites. Does BYOB have a way of addressing that kind of conflict?
We do distinguish "for all sprites" and "for this sprite only," the same as for variables. It's an idea that Scratchers already understand. However, we export global as well as local custom blocks when exporting sprites. (This is useful because we can use an exported sprite as the carrier of a block package, like the ToolSprite we include with BYOB.) I'm afraid that in case of a conflict, the one loaded second wins silently. Probably we should give some kind of warning -- but as I understand it, part of the Scratch design philosophy is to avoid error/warning messages as much as possible.
If we invented a different way to export block packages, maybe it would make sense for an exported sprite to include only its local blocks. But then you have the opposite problem; what if a sprite uses a global custom block, and is imported into a project that doesn't have such a block?
This gets even more interesting when you can clone sprites.
Offline
johnm wrote:
But you can do a surprising amount with only command blocks, including recursion and even functions (by using a global variable for the return
But that doesn't work for recursive functions! And anyway, it makes for ugly programs. Imho.
Offline
johnm wrote:
I should mention that user-defined reporters have impacts performance and the concurrency mechanism, so there are some technical reasons to not include that feature in Scratch 2.0.
... as I discovered to my dismay in BYOB! But, John, other languages don't have this problem -- it's just a result of your (as Jens keeps telling me ) brilliant (but very unusual) design for the evaluator. When we rewrite BYOB this summer the evaluator will be independent of the GUI code and recursive reporters will be fast. And you're rewriting the evaluator, too, so you could address the speed problem.
Not trying to pick a fight; you also have pedagogic reasons not to want custom reporters in 2.0, and that's what's important. Just picking a nit.
Offline
bharvey wrote:
johnm wrote:
I should mention that user-defined reporters have impacts performance and the concurrency mechanism, so there are some technical reasons to not include that feature in Scratch 2.0.
... as I discovered to my dismay in BYOB! But, John, other languages don't have this problem -- it's just a result of your (as Jens keeps telling me ) brilliant (but very unusual) design for the evaluator. When we rewrite BYOB this summer the evaluator will be independent of the GUI code and recursive reporters will be fast. And you're rewriting the evaluator, too, so you could address the speed problem.
Just out of curiosity, what is it that makes reporters so expensive?
Offline
fullmoon wrote:
Just out of curiosity, what is it that makes reporters so expensive?
I should really leave this for Jens or John to answer, but I think the general answer is that one of the design principles of Scratch is that everything that happens should happen visibly. This works out okay for Scratch, in which scripts are very command-heavy, and many of the commands make something happen on the stage, so it's okay that their evaluation is closely tied to displaying. But when you start writing recursive reporters, you really want the evaluation to happen without being tied to the display of the blocks or the data. Jens singles out what Scratch misleading calls "single stepping" (really it's slow stepping) because every step in the evaluation lights up a different block, and the evaluator thinks about doing that even when you're not single stepping.
But eventually J or J will read this and give you an authoritative answer.
Offline
bbbeb wrote:
Perfect. Like defining a procedure in C++. Absolutely perfect for those who want to transition into real coding.
Scratch has been behind, no serious mid-high level language lacks functions, and from the looks of it they're not providing a way to make reporter blocks either. Maybe some lack of features is a way of kicking advanced users 'out of the nest' to go on to serious typed languages.
Last edited by 14God (2011-04-09 02:26:10)
Offline
I can't wait for 2.0!
I can imagine it right now...
Offline
I think you should have just the basic blocks in the Standard Scratch version and then have a block download page. But make it simple like when you download add-ins for Firefox or Google Chrome. Do you know what I mean? I would be great if you did [show list] and [hide list] blocks as well as [go to x(value) y(value] for variables. Also could you make interactions between sprites so sprites have children sprites that move in relation to the parent sprite (useful for wheels on cars and props on planes and stuff).
Hope this helps!
Offline
I hope there is a beta for this at scratchday. Also, do you think you will be sharing the sourcecode for it?? Lastly, will there be mesh??
Offline
What happens when other people open your project? Does the block split into its scripts?
Maybe there could be an option to add the block to a "Block Pile" Menu.
Lightnin wrote:
Here's the latest: HAD TO REMOVE
Check it out, and then join in the discussion about the best way to do 'Create your own block' in Scratch 2.0 here:Create your own block blog post wrote:
We’re still in the process of figuring out the best way for Scratchers to create their own blocks, and there are still many questions. For example, if you create a jump block in one sprite, would other sprites be able to use the jump block too? Should the definition script appear in only one sprite -- and, if so, how would people find it? Should you be able to define “jump” differently in different sprites? These are few of the questions we have to think through before we’re ready to put this cool feature in the next version of Scratch.
Offline
My Reaction:
-This seems much like BYOB, maybe you could create a feature to transport blocks to Scratch from BYOB or vice versa.
-There should be some way to get user-made blocks off the net.
-This would hugely up my efficiency, as I remake scripts often.
-Will Panther-esce features be added?
Offline
amcerbu wrote:
So this fleshes out the broadcast function? Great! Can't wait for the new release of 2.0!
The broadcast function is staying. If you don't like it, don't use it.
Offline
ihaveamac wrote:
amcerbu wrote:
So this fleshes out the broadcast function? Great! Can't wait for the new release of 2.0!
The broadcast function is staying. If you don't like it, don't use it.
The ability to create procedures will do everything that the broadcast function does already, and more. Maybe it will stay, but it is no longer needed. What I meant by "fleshes out" is "expands."
Offline
amcerbu wrote:
ihaveamac wrote:
amcerbu wrote:
So this fleshes out the broadcast function? Great! Can't wait for the new release of 2.0!
The broadcast function is staying. If you don't like it, don't use it.
The ability to create procedures will do everything that the broadcast function does already, and more. Maybe it will stay, but it is no longer needed. What I meant by "fleshes out" is "expands."
How?
Offline
scimonster wrote:
amcerbu wrote:
ihaveamac wrote:
The broadcast function is staying. If you don't like it, don't use it.
The ability to create procedures will do everything that the broadcast function does already, and more. Maybe it will stay, but it is no longer needed. What I meant by "fleshes out" is "expands."
How?
According to the progress report, procedures will be carried out by "custom blocks." The procedure itself is stored somewhere else in the code, and by running it, the program calls on that particular section of code. Not only can procedures be run from another place (like broadcasts), they can also take arguments. This completely eliminates the need for a broadcast block at all.
Offline