In the first two parts of this quick and dirty series, you learned how to write a script to run a Croquet world, and how to execute that script within the Squeak environment. But selecting your code, doing an "accept" and "do it" every time you want to start a world can become tedious. Wouldn't it be great if you could just click a button to start your world?
That is precisely what we are going to learn how to do in this tutorial.
Learning Outcomes:
Upon completion of this lesson, the learner will be able to assign a script to a button in Squeak and change the name of the button.
Step by Step Guide:
1. Launch Squeak and open a new project.
data:image/s3,"s3://crabby-images/00814/00814c8240f3ffe348d649b497d25a1f65b09a7b" alt=""
data:image/s3,"s3://crabby-images/bbfe5/bbfe58e9ae82e490a41d72e1c7dfa101d9d7418b" alt=""
data:image/s3,"s3://crabby-images/ac5f8/ac5f8ad020c28ea5970c8e2796eb2c92f510dfd3" alt=""
3. Select "Basic" from the "Objects" window.
data:image/s3,"s3://crabby-images/2453d/2453dfeaedf83aa56474ad39437813ba2887130d" alt=""
4. Click and drag the "button" icon from the "Objects" window into your workspace.
data:image/s3,"s3://crabby-images/c4821/c48216aaf4b5269ab9ad6ec5a17da732b2ba9b20" alt=""
5. Command-click (or right-click) the button you just dragged into the workspace. You are presented with a halo.
data:image/s3,"s3://crabby-images/9976b/9976b18b9247893dc6cdee809bee5609416b7e24" alt=""
6. Select the green button towards the bottom-right of the halo. You are presented with a tile pane.
data:image/s3,"s3://crabby-images/1f1dc/1f1dcc60f0f9d209ae86ebe1901abfa0c3ca2edc" alt=""
data:image/s3,"s3://crabby-images/be0ad/be0ad75e74b309c56e1c36fd5e4ac1d881de7b9b" alt=""
7. Click on the "world" section of the tile pane. You are presented with a contextual menu.
data:image/s3,"s3://crabby-images/803ea/803ea1d1381751753b22af66b90031df79aaa5ae" alt=""
8. Select "show code textually" from the contextual menu. An editing space will appear.
data:image/s3,"s3://crabby-images/36293/36293df462db2adfef32c3d0a5e01bf1cd6bd1d1" alt=""
9. Delete all text in the editing space except for the word "button".
data:image/s3,"s3://crabby-images/c13c9/c13c95a7d69bc0e7e5aa608f993e53c55b69c044" alt=""
10. Copy and paste the following code into the editing space below the word "button":
| myVariable |
myVariable := CroquetMaster new.
myVariable position: 100@100.
myVariable extent: 640@480.
^myVariable openInWorld.
data:image/s3,"s3://crabby-images/4594d/4594dd7b93a021d10a2c5dc4c046a885617b51ae" alt=""
data:image/s3,"s3://crabby-images/fe736/fe7360fa59194b0e4ff3204f1e4c2dedc8334220" alt=""
12. Select the "O" button (second from the left) at the top of the tile pane. This will close the tile pane.
data:image/s3,"s3://crabby-images/409b4/409b4ad1591c8d771fedc8be35dafc777e25489f" alt=""
13. Since the title on the button ("press me") is not very descriptive, let's change the title. Command click (right-click) the button. You are presented with a halo. Select the "Menu" button. You are presented with a contextual menu.
data:image/s3,"s3://crabby-images/b1da0/b1da06f7e2c3e4251f3b3c11e4667b5155483b71" alt=""
14. Select "change label" from the contextual menu. You are presented with a dialogue to add a new label to your button.
data:image/s3,"s3://crabby-images/f061b/f061b999e83faa8c058b377a63064bf96496852d" alt=""
15. Provide a name for your button and select "Accept." I have chosen to name the button "My Croquet World."
data:image/s3,"s3://crabby-images/f3f47/f3f47a04b3b4cd11e189349830fffcdec135160e" alt=""
16. Success! You can now click on the button to run your script. You will be presented with a world based on the CroquetMaster subclass.
data:image/s3,"s3://crabby-images/b7a1e/b7a1e89b7d5bfbd6654488fe98ad9491c177fc67" alt=""
Advanced users:
Experiment with the various options using the halo and its contextual menus to create a more attractive button.
Challenge:
Can you create a button that looks like the following?
Summary:
In this lesson, the learner learned to assign a script to a button in Squeak and how to change the name of that button.
Conclusion
This concludes the quick and dirty series on getting a Croquet world running. In this series, the learner acquired the following abilities regarding the core concepts of the Croquet SDK:
1. How to create a new Squeak project.
2. How to open and use a workspace.
3. How to open and use a class browser in a fundamental manner.
4. How to execute scripts in the Squeak environment ("accept" and "do it")
5. How to understand basic scripting syntax in Squeak, from a fundamental and conceptual perspective.
6. How to work with the halo in a fundamental manner.
7. How to assign a script to a button.
I hope that you have enjoyed the Quick and Dirty tutorial series, and I also hope that you have been able to become more familiar with the Croquet SDK.
If you have feedback, questions or comments, please leave a comment in the comments section of this blog. I will do my best to answer your questions.
Thanks for the tutorial. I've recently picked up on Squeak/OpenCroquet and think they are mind-blowingly fantastic, however I'm having a hard time locating useful tutorials and info on the web (aside from the usual suspects, e.g. SBE), so I'll be keeping an eye open here too ;-)
ReplyDeleteGood one - keep it up!