Discuss Scratch
- fezzinate
-
100+ posts
Special Comment Blocks
Just a simple suggestion today. I know that this isn't so exciting - they're just comments after all and functionally don't do anything. But I can't stand working with the current comment feature. It's finicky, and always gets in your way.
I propose two new comment blocks, a standard version and a c-block version, for writing comments and organizing your code
data:image/s3,"s3://crabby-images/a3a54/a3a548454b5f52d09eaed5649c36967a9680d5e6" alt=""
I wrote “REM” as the name of the block as a homage to the BASIC language - it stands for “remark”, but you can just as easily have a nameless version of the blocks:
data:image/s3,"s3://crabby-images/04b67/04b67f1bdbcd80854358835611190b0c840cc7fd" alt=""
I propose two new comment blocks, a standard version and a c-block version, for writing comments and organizing your code
data:image/s3,"s3://crabby-images/a3a54/a3a548454b5f52d09eaed5649c36967a9680d5e6" alt=""
I wrote “REM” as the name of the block as a homage to the BASIC language - it stands for “remark”, but you can just as easily have a nameless version of the blocks:
data:image/s3,"s3://crabby-images/04b67/04b67f1bdbcd80854358835611190b0c840cc7fd" alt=""
- GyroscopeBill
-
500+ posts
Special Comment Blocks
Support! I don't really use comments because I find them messy, but if this was implemented I would certainly use them, they are much neater. The C-Block comments are a brilliant idea!
How would you get the comments? Would you right-click as in the current system, or drag them from the block menu?
How would you get the comments? Would you right-click as in the current system, or drag them from the block menu?
- fezzinate
-
100+ posts
Special Comment Blocks
Yeah totally! I haven't been using comments much either because of the current implementation, and I've noticed by looking through quite a number of other projects that hardly anyone uses them. Which is a shame - scratch is completely about the idea of sharing code! What's the use of sharing code if it's a mess that other users can't understand? This would help a ton I think
I'd imagine you'd simply drag them down like any other block. No need for the right-click stuff.
I'd imagine you'd simply drag them down like any other block. No need for the right-click stuff.
- jontmy00
-
500+ posts
Special Comment Blocks
+1. The inline blocked comment used to in older versions of Scratch.
- savaka
-
1000+ posts
Special Comment Blocks
They won't do inline comments because new people were confused by them.
- TimothyLawyer
-
1000+ posts
Special Comment Blocks
Here is a way to comment inline:
Or if already using ‘think’ or ‘say’ then wrap like so.
And for C block:
Or use a custom block with no definition.
The color and the font in the Handle Physics definitions look really nice. Wish we had a way to replicate.
think (letter (0) of [comment here])
Or if already using ‘think’ or ‘say’ then wrap like so.
if <>
think [comment here]
end
And for C block:
if <> then
think [comment here]
else
... code ... ::grey
end
Or use a custom block with no definition.
note [ ] ::customOr
if <>
note [comment here]
else
... code ... ::grey
end
define note [ ]
define comment []
The color and the font in the Handle Physics definitions look really nice. Wish we had a way to replicate.
Last edited by TimothyLawyer (May 7, 2014 11:25:13)
- chabad360
-
20 posts
Special Comment Blocks
support C-Block!
Last edited by chabad360 (May 7, 2014 16:49:44)
- AonymousGuy
-
1000+ posts
Special Comment Blocks
They were removed because of confusion.
And, there is an easy workaround, so no support:
And, there is an easy workaround, so no support:
define REM (comment)
when gf clicked
REM [This is run when the program starts.]
go to x: (0) y: (0)
REM [This resets the sprite's position.]
if <not <[This is a C block comment. They aren't found in any other programming languages in existence.] = []>> then
forever
if <not <[This checks to see if the user is pressing space.] = []>> then
if <key [space v] pressed?> then
say [Hello!]
REM [This will say "Hello!" when the space key is pressed.]
else
say []
REM [This will say nothing when space isn't pressed.]
end
end
end
end
- fezzinate
-
100+ posts
Special Comment Blocks
They won't do inline comments because new people were confused by them.
here. There were inline comments in Scratch 1.2 beta, but new users got confused when the block did nothing and their sprite wasn't making a comment.So I totally appreciate that they were removed for a reason - that's good to know. I didn't know they existed before. But what's more important to me than knowing that they were confusing to users is knowing *why* they were confusing. In-line comments are great for a whole multitude of reasons, but I don't think it was the “in-line” part about the block that made it confusing. Look
It seems like the main reason they were confusing was because they weren't set apart enough from blocks that provide function - such as “say”. I think the main fault lies on naming the block. If you label the block “comment” users will think that the block actively, in the verb sense, comments. But if you label it with nothing then there's no room for confusion. There's nothing to suggest it does anything at all besides hold text. For this reason, I dont like my “REM” version anymore. I'd go with the completely blank one.
But it got me thinking. It could probably benefit from even more visual separation than that. I whipped up new mocks…
data:image/s3,"s3://crabby-images/1f3fc/1f3fc21812d348fa63055b81655d0200ba655a47" alt=""
This is the same idea as last time, but I removed the white box and changed the font. The white box gave the impression that it's contents could be interactive in the same way regular block's have text boxes that you can drop sensors or variables to. By removing it, we also remove the confusion in that regard. By changing the font to something that appears hand-written, it visually sets it apart as being a note rather than important data.
data:image/s3,"s3://crabby-images/ae531/ae53182494073618afd918bd4cc2340e0b3e54cd" alt=""
This idea pushes the concept even further. Instead of thinking of comments as blocks at all (which scratch claims was confusing), what if they were treated as extensions to any block. I think this was the line of thinking scratch was going for when they changed them, but in doing so they destroyed the friendliness and clarity of them remaining in-line. This idea solves both problems. Right click any block and click “add comment” like you normally do, but instead the note is added to the top of the block. This absolutely removes all ambiguity.
data:image/s3,"s3://crabby-images/ea9d3/ea9d32f714e0f0c94596fa13cd845c5d5cb77793" alt=""
This could also be coupled with the idea of free-standing line-blocks and c-blocks, but isn't too necessary. The only argument for them is sometimes you want comments that aren't associated with any particular block or you want them associated with chunks of blocks, and these can make that more clear.
Here is a way to comment inline…
They were removed because of confusion. And, there is an easy workaround, so no support:
Before I made this suggestion, I've been using the workaround of using a custom defined block called REM that does nothing. It's done the job for now, but it has a few major downsides compared to making it a dedicated option:
- Readability: Because they're the same color as custom blocks, it's hard to immediately spot which things are comments and which are not. the c-block hack is even worse in this regard because it starts to look like actual game logic
- Performance: I'm not entirely sure of any performance hits that are caused by the overhead of running empty code including custom blocks and if statements.
- Single-line only: Sometimes your comments need to be quite a bit of information. If you try this with the work around you'll end up with a super long string of text that you'll need to scroll to read. The only way to break it down into multiple lines is to do a new block for every line. It's pretty ugly.
At the end of the day, I believe my suggestion better fits the goals of scratch. It's easier to read and use, and addresses the issues that the first iteration of scratch had with them. The fact that nobody is using new comments as much as they should is pretty telling that it's not the best approach.
-Dan
Last edited by fezzinate (May 8, 2014 04:13:09)
- djdolphin
-
1000+ posts
Special Comment Blocks
I like the new design idea! To reduce clutter, maybe instead of having separate stack and c-shaped comment blocks, there could be a stack-shaped comment that opens into a c block when you drag blocks over it and closes again when you drag them out.
Edit: Or maybe keep the old comments, but they would snap into scripts and become block shaped, and then they would be able to do what I said above. There would need to be some degree of backwards compatability with the current comment system.
Edit: Or maybe keep the old comments, but they would snap into scripts and become block shaped, and then they would be able to do what I said above. There would need to be some degree of backwards compatability with the current comment system.
Last edited by djdolphin (May 8, 2014 11:22:26)
- seanbobe
-
500+ posts
Special Comment Blocks
support
REM already stands for rapid eye movement which is a state when you are asleep and dreaming.
warning: offtopic starts hear.although could you not name iit REM?
REM already stands for rapid eye movement which is a state when you are asleep and dreaming.
warning: offtopic ends herealso these were 1.2 comments but were scrapped due to new scratchers getting confused leading to syntax errors
Last edited by seanbobe (May 9, 2014 00:45:26)
- AonymousGuy
-
1000+ posts
Special Comment Blocks
Support for the new idea - less confusing for new scratchers.
I also have a few ideas for it - I might make some mock-ups if I want to.
I also have a few ideas for it - I might make some mock-ups if I want to.
- fezzinate
-
100+ posts
Special Comment Blocks
@djdolphin: I absolutely love that idea. Could work very well.
@seanbobe: REM is also commonly used in BASIC programming that means “Remark” Your other points are also addressed in the rest of this thread
@AonymousGuy: I'd love to see them!
Slight update:
data:image/s3,"s3://crabby-images/b8495/b8495455631cf697c9b4eccde8185c4fc06fa3ad" alt=""
just refined the colors of last image a bit more to better message that the c-block is a stand-alone note, but also keep the same visual language that it's a note attached to a block.
@seanbobe: REM is also commonly used in BASIC programming that means “Remark” Your other points are also addressed in the rest of this thread
@AonymousGuy: I'd love to see them!
Slight update:
data:image/s3,"s3://crabby-images/b8495/b8495455631cf697c9b4eccde8185c4fc06fa3ad" alt=""
just refined the colors of last image a bit more to better message that the c-block is a stand-alone note, but also keep the same visual language that it's a note attached to a block.
- chooper100
-
500+ posts
Special Comment Blocks
support :: controlIt'd be great for this to be implemented!
Only problem is that it would take a long time to create a completely new block type like that.
- Braeden5454
-
500+ posts
Special Comment Blocks
Sorry. No support. ^ Explains the workaround. They were removed because of confusion.
And, there is an easy workaround, so no support:define REM (comment)
when gf clicked
REM [This is run when the program starts.]
go to x: (0) y: (0)
REM [This resets the sprite's position.]
if <not <[This is a C block comment. They aren't found in any other programming languages in existence.] = []>> then
forever
if <not <[This checks to see if the user is pressing space.] = []>> then
if <key [space v] pressed?> then
say [Hello!]
REM [This will say "Hello!" when the space key is pressed.]
else
say []
REM [This will say nothing when space isn't pressed.]
end
end
end
end
I liked it until i realized that some new scratchers would think that the comment block actually does something and be confused when there sprite doesn't “Jump like crazy” or whatever they put in there.