Teach Your Kids Programming - The First Logo Interpreter (Turtle Graphics) in Chrome Extension!

in utopian-io •  7 years ago  (edited)

Introduction to Logo Turtle

I am teaching my 5-year-old son how to program. The language I pick is LOGO which is known as the turtle graphics.

There are some good implementations using Javascript, in the browser, some desktop logo interpreters, and also the one in PHP. However, these are not exactly what I want: a simple-but-powerful, safe (no need to download native software), be-able-to-run-offline and most importantly, the ads-free version.

The chrome webstore is the ideal place, but unfortunately, there is None for Logo Programming. Therefore, I decide to make one, and will bring more customized features in the next coming versions.

Chrome Webstore

It is available now so you can install it in Chrome webstore. This is platform-independent, meaning that with Chrome browser, you can just install the Logo Interpreter and have fun with it.

https://chrome.google.com/webstore/detail/logo-turtle/dcoeaobaokbccdcnadncifmconllpihp

Version 0.0.1

The very first version only supports the following keywords/features:

  1. FD, FORWARD
  2. BK, BACKWARD
  3. RT, RIGHT
  4. LT, LEFT
  5. HOME
  6. CS, CLEARSCREEN
  7. REPEAT
  8. PU, PENUP
  9. PD, PENDOWN

So you should be able to write this

cs repeat 8 [pu fd 20 pd repeat 5 [fd 20 rt 144] pu bk 20 rt 45]

and see how it goes:
image.png

The Log tab prints any errors and warnings:
image.png

Also, in Settings, you can choose a different UI language, currently simplified Chinese (will add more when the project is at beta version).
image.png

How it works?

logocanvas.js is the view-model that supports the basic turtle instructions and draw to a canvas.
logointerpreter.js parses the LOGO source code. The repeat loop is implemented via recursion.

case "repeat":
    if ((word_next == '') || (!isNumeric(word_next))) {
        this.pushErr(LOGO_ERR_MISSING_NUMBERS, word_next);
        return;
    }
    let find_left = getNextWord(s, y.next, U);
    if (find_left.word != '[') {
        this.pushErr(LOGO_ERR_MISSING_LEFT, find_left.word);
        return;
    }
    let repeat_left = find_left.next;
    let find_right = repeat_left + 1;
    let nested = 1;
    // need to match [ and ]
    while (find_right < U) {
        if (s[find_right] == '[') {
            nested ++;
        }                                               
        if (s[find_right] == ']') {
                nested --;
                if (nested == 0) {
                        break;
                }
        }
        find_right ++;
    }
    if (find_right >= U) {
        this.pushWarning(LOGO_ERR_MISSING_RIGHT);                       
    }
    for (let i = 0; i < word_next; ++ i) {
        // recursive call repeat body
        this.run(s, repeat_left, find_right);
    }
    i = find_right + 1;
    break;  

Roadmap of Chrome Extension: Logo Turtle

  1. Add Functions
  2. Add IF/THEN/ELSE
  3. Add Variables
  4. Add Colors
  5. Add MoveTo
  6. Add PrintText
  7. Add Circlee
  8. Add Arc
  9. Add Eraser
  10. Add Fill
  11. Save As Picture
  12. Save As Program
  13. etc. etc.

Technology Stack

If an App can be written in Javascript, eventually it will be written in Javascript.

Chrome Webstore

Install the Turtle Programming for Kids Now!

Contribution Welcome

Github: https://github.com/DoctorLai/LogoTurtle

  1. Fork it!
  2. Create your feature branch: git checkout -b my-new-feature
  3. Commit your changes: git commit -am 'Add some feature'
  4. Push to the branch: git push origin my-new-feature
  5. Submit a pull request.

Reposted to https://helloacm.com/teach-your-kids-programming-the-first-logo-interpreter-turtle-graphics-in-chrome-extension/



Posted on Utopian.io - Rewarding Open Source Contributors

Authors get paid when people like you upvote their post.
If you enjoyed what you read here, create your account today and start earning FREE STEEM!
Sort Order:  

Thank you for the contribution. It has been approved.

You can contact us on Discord.

[utopian-moderator]

Hey @ms10398, I just gave you a tip for your hard work on moderation. Upvote this comment to support the utopian moderators and increase your future rewards!

  ·  7 years ago (edited)

The thing I love about knowing how to program is that if I don't see something that I like, I can build it myself, just like you did. And you can make it just the way you want.

  ·  7 years ago 

programming is fun!

It's a good thing to grown children on all these package when they are still young like this. By the time they grow up. They will become a professional. Thanks for this wonderful post

  ·  7 years ago 

yes, as parents, we try our best to educate our kids.

程序员连表达爱都这么神奇。佩服!

Indeed a very helpful tips huh, programming is always be interesting,, keep sharing this kind of blog very helpful men/.

其他就不用赞了,赞教五岁娃programming 这句!

  ·  7 years ago 

5岁应该不算小了,可以开始教了。在玩的过程中学习是最好的。

I am greatly looking forward going into programming stuff. Would you advise me to go for a full college computer science study or take some random online course relating to different programming languages... Capital is also a consideration for me

好棒👍 行长启发孩子有一手啊 惊觉自己编程就输在了起跑线上

  ·  7 years ago 

孩子的潜力是无限的,只要孩子 不反感,我们大人就要让孩子学习学习再学习。

Hey @justyy I am @utopian-io. I have just upvoted you!

Achievements

  • WOW WOW WOW People loved what you did here. GREAT JOB!
  • Seems like you contribute quite often. AMAZING!

Community-Driven Witness!

I am the first and only Steem Community-Driven Witness. Participate on Discord. Lets GROW TOGETHER!

mooncryption-utopian-witness-gif

Up-vote this comment to grow my power and help Open Source contributions like this one. Want to chat? Join me on Discord https://discord.gg/Pc8HG9x

Wow, LOGO was my very first programming language around that age too. The next generation rises 😎 Haven't touched it in years. It didn't occour to me that there would or wouldn't be an interpreter in the chrome store. Thanks for a very educational contribution.