• Есть апп, задающий ребёнку развивающие задачки, а в случае успешного решения задачки ставящий мультик с ютуба?

    Adamos
    @Adamos
    Ваш "компромисс" не решает проблему, а обостряет ее. Решая задачки ради мультиков, ребенок их возненавидит (задачи, а не мультики). Вы ее просто превращаете в крысу, которой нужно давить на рычажок, чтобы стимулировать центр удовольствия в мозгу.

    Оттаскивайте ребенка от телевизора и планшета не запретами и ограничениями, а предлагая другие интересные занятия. В том числе развивающие. И занимайтесь с ним сами так много, как можете. Иначе дальше будет только хуже.

    Моей сейчас семь, мультики любит, но без фанатизма. Мы успешно прошли все подшивки "Школы семи гномов", рекомендую. Из развивающих игрушек использовали разве что GComprix, и то очень умеренно. Зато настольных игр у нее полный шкаф. Для вашего возраста уже кое-что можно брать - "Доббль", например.

    В четыре года мы взяли букварь, и дочь читала по странице каждый вечер. Потом - мы читаем сказку на ночь. До сих пор последний час перед сном - час чтения. Сначала дочь, потом мы. К семи годам читает бегло, с выражением, а главное - с удовольствием. Школьные уроки - в охотку и с интересом.

    Нельзя приставить к ребенку автомат и рассчитывать, что он будет развиваться. Ничего так не выйдет. Воспитание такого ребенка, каким хочешь его видеть - это труд, ежедневный и упорный. Если же вам всего лишь хочется, чтобы ребенок не мешал - ну, это-то устроить несложно. Сложности будут потом.
    Ответ написан
    6 комментариев
  • Какие вопросы на собеседовании ожидать по JS?

    @mletov
    "Ну признайтесь уже — джаваскрипт алертами дебажили?"(c)
    Ответ написан
    8 комментариев
  • Как без плагинов на Jquery запилить форматирование числа?

    Rsa97
    @Rsa97
    Для правильного вопроса надо знать половину ответа
    string = Intl.NumberFormat('ru-ru').format(1500000);
    Ответ написан
    Комментировать
  • Почему появляется обводка при клике на div на Android?

    Bowen
    @Bowen
    Японский бог
    Комментировать
  • Как выровнять inline-block вертикально по центру?

    @Neyury
    Советую прочитать эту статью, там описаны все варианты центрирования по горизонтали и вертикали для строчных (включая inline-block) и блочных элементов.
    Ответ написан
    6 комментариев
  • Где находится скрипты которые в теге Head??

    Rou1997
    @Rou1997
    Если у вас Винда OS X El Capitan, то спрашивайте на форумах вашей планеты!
    А на наших земных операционных системах "ассеты" на сервере ищут поиском по файлам, для ускорения имеет смысл посмотреть .htaccess и маршрутизаторы, или для начала найти index.php и относительно него попробовать выстроить пути, как в HTML-коде, ну и Гугл + документация по "движку", конечно.
    Ответ написан
    Комментировать
  • Зачем в ES6 get и set?

    mannaro
    @mannaro Куратор тега JavaScript
    Умею профессионально гуглить
    Потому что аксессоры в JS предназначены для того, чтобы задать какую-то логику на геттер или сеттер. Таким образом можно, например, реализовать счетчик того, сколько раз какое-то свойство было изменено и т.п.
    Да и с помощью них можно реализовать такую штуку как:

    var Test;
    (function() {
      var super_priv = 1;
      Test = class {
        get priv() {
          return super_priv;
        }
        set priv(val) {
          super_priv = val;
          return priv;
        }
      };
    })();
    Ответ написан
    2 комментария
  • С каким уровнем знаний у вас получилось устроиться начинающим верстальщиком в веб студию?

    @DenJel
    Есть веб студии которые пишут сайтики на wordpress, а есть которые таким же штатом стартапы успешные пилят. И все зависит от того, куда ты хочешь попасть. Если в первый тип студий, то там много знаний не надо - верстка + вешать обработчики на jquery и ты готов работать, посмотрел минимальный гайд на ютубе и пили шаблоны + ПЫХ выучишь, но ты можешь очень сильно просесть по времени, ничего так и не выучив на такой работе, если во второй, то надо изучить хорошо JS, view библиотеку + какую нибудь архитектуру потока данных ( react + flux ( redux, alt ), vue + vuex ) либо JS фреймворк ( angular, ember или что там сейчас популярно ). Сделать что нибудь посложнее TODOшки и можно пробывать устраиваться. У меня так получилось, что я попал в первый тип студий и потерял там год. О чем потом сильно жалел. Уволившись оттуда, мне очень сложно было найти нормальную работу. Я выучил React.js до того уровня, чтобы без проблем верстать на нем и делать компоненты. И устроился стажером в один стартап. Там знания потекли рекой, хоть и зарплата была даже меньше чем на первой работе. Но с ростом знаний пошел и рост зарплаты. Через 3 месяца я уже получал в 2 раза больше. Как то так. P.S junior
    Ответ написан
    Комментировать
  • Как уйти с распутья технологий?

    @0x131315
    Стратегию уже подсказали: найти любую работу, чтобы кушать, и тем самым выиграть время на изучение чего-то, что поможет зарабатывать больше, и тем самым выиграть еще больше времени, и в конце концов изучить то, благодаря чему будешь работать не на зарплату, а на удовлетворение.

    Что касается языка - на первое время следует сосредоточится на чем-то популярном, попсовом, где больше всего вакансий, где проще найти работу. На зарплаты пока внимания обращать смысла нет - это лишь первый шаг, потом все-равно зарплаты станут больше, и скорее всего сменишь сферу деятельности, в соответствии со своими вкусами и желаниями.
    Но чтобы получить время на изучение языка, требуется источник дохода - любая работа, которая позволит кушать, платить за квартиру, одежду, оборудование и услуги.

    А так по моему важнее не инструмент, а умение им пользоваться. Начинать следует с алгоритмов, а язык использовать как инструмент.
    Хотя откладывать изучение языка тоже нельзя - практика важнее теории. Так что в комплексе - постигай алгоритмы на практике, по мере необходимости, и запоминай их.

    Т.е. глобально нет смысла учить конкретный язык ради изучения языка - выучить любой язык не проблема, и это можно сделать прямо по ходу решения задачи. Я за свою жизнь пользовался целой кучей языков, и все они так или иначе, но похожи друг на друга, проблем с их изучением никогда не было. Так что выучить новый язык - не проблема.

    Конкретный язык нужен кодерам - это те, кто воплощает чужие идеи в коде, т.е. конечные винтики в процессе разработки софта, исполнители. От кодеров требуется только перенести уже готовый алгоритм на требуемый язык, максимально быстро, и по возможности без ошибок.
    Изучив конкретный язык ты можешь стать кодером, но это черновая работа, и по хорошему - временная, просто ступенька на пути становления программиста. Нужно двигаться к архитектору, инженеру, непосредственно программисту в широком смысле.

    Программисту важнее знать как именно решать задачи, т.е. иметь представление об алгоритмах и навык формализации всего и вся. Т.е. уметь непосредственно разрабатывать алгоритмы, умение кодить - второстепенно.
    Т.е. программист - это лишь инженер сетей обработки информации.

    Также упрощает задачу стандартизация подходов к решению задач, парадигм - большинство из них уже формализованы, и описаны. Например всем известное ООП, модульное программирование, конечные автоматы, и т.п. Описано более двух десятков таких моделей, их следует по возможности освоить. И не стесняться комбинировать.

    Дополнительно упрощает задачу то, что большинство алгоритмов стандартные, и почти все известные алгоритмы уже кем-то реализованы в библиотеках или исходниках, так что вместо написания с нуля достаточно просто подключить нужную библиотеку или скопипастить кусок из исходников. Но для этого нужно знать, что такой алгоритм вообще существует, в какой именно библиотеке реализован, когда и как его можно и стоит применять.
    Во вторых давно доступен гугль, который всегда подскажет как решать ту или иную задачу, какие для этого есть алгоритмы, в каких библиотеках, когда и как их применять.

    Т.е. современный разработчик может выехать чисто за счет умения гуглить.
    И это не плохо на самом деле - преподы в институтах говорят примерно тоже самое: хороший инженер - не тот, кто все знает, а тот, кто может решить любую задачу. И помогают в этом вовсе не знания, а умение искать нужную информацию, ибо все знать все-равно не получится.

    Но все-равно, даже программисту нужен опыт. Не важно что он отвязан от языков - он все-таки привязан к одному языку, информации, и должен уметь с ней обращаться.
    Опыт экономит время и усилия - там, где сперва требовалось неделю гуглить и пробовать, потом, с опытом, все делаешь за час, просто уже понимая что, как, когда и зачем.

    Опыт нарабатывается практикой - тут нет ничего нового: просто берешь себе задачу по вкусу, и решаешь.
    Не можешь сам генерировать задачи - ищешь годный внешний генератор: форумы проблемных пользователей, имиджборды, конкурсы, аукционы программистов (это где работают фрилансеры). Также хорошо идет создание своего проекта или участие в разработке чужого - развитие любого проекта всегда порождает множество задач, которые нужно кому-то решать, а это отличный генератор.
    В общем ищешь реальных заказчиков, или берешься за незначительные заказы, или работаешь ради альтруизма, решая то, что тебя не просили - есть всякие гитхабы и багтрекеры.

    Главное найти задачу и решить ее. Начинаешь с простых, и постепенно усложняешь. Параллельно, прямо по ходу решения, изучаешь алгоритмы, и нарабатываешь опыт. Со временем начнешь щелкать задачи быстро и между делом, как семечки, те, которые по первости у тебя отнимали недели, а то и месяцы.

    Недоведение решений до конца - следствие неверного подхода: либо берешь задачи, к которым еще не готов, слишком сложные, либо не имеешь возможности работать - у тебя нет условий для решения задачи: времени, места и внимания. Либо просто тебе это реально не нужно - тебя и так все устраивает, и планов на будущее нет.

    С третьим - придешь, когда поймешь, что тебе это нужно. Из-под палки не учатся.

    Со вторым все понятно: надо либо создать условия, либо отказаться от этой деятельности, и перейти к другой.
    Кто-то отказывается, уходит на другие работы, в основном физические, неквалифицированные, просто чтобы не думать. И как правило остается там до конца, уже не в силах выбраться из болота рутины.
    Кто-то приспосабливается - отгораживает себе уголок, меняет работу на ту, что дает больше свободного времени, начинает работать по ночам, забивает шум наушниками, и т.п. костыли.
    Кто-то кардинально меняет свою жизнь - переезжает в сьемные квартиры, выделяет себе комнату, изолирует ее или устанавливает в доме режим тишины, в общем создает себе полноценные комфортные условия для творчества. Это если удаленка - многие именно из-за невозможности работать дома, предпочитают офисы, или специальные кафе или клубы для работы.

    С первым все просто: не можешь что-то решить - отложи, и спустись на ступеньку ниже по шкале сложности.
    Есть такой психологический феномен: от решенных задач ты получаешь удовлетворение, силы и мотивацию двигаться вперед, от нерешенных - негатив, апатию, потерю воли и мотивации.
    Причем мозг устроен так, что запоминается лишь негатив. Поэтому крайне важно решать задачи, и не допускать незавершенных задач. Отложи, но не забрасывай.
    Нерешенная задача - это как психологический запой, нечто вроде депрессии: одна нерешенная задача тянет за собой другую нерешенную задачу, и так быстро уходишь на дно, теряя мотивацию и веру в себя. Замкнутый круг. Ты находишься именно в нем.

    Разрывать такие круги можно лишь одним способом - рутиной: медленным, последовательным и целенаправленным натиском, движением в одну сторону. Грубо говоря перестаешь жить эмоциями и импульсами, вырабатываешь продуманную программу развития, и действуешь по ней, строго, как робот, до тех пор, пока не начнешь получать положительный отклик от работы, пока не придет желание двигаться дальше - это вернулись воля, мотивация и вера в себя.

    Чтобы вернуть веру в себя, нужно стать победителем. Победители всегда побеждают - в этом и суть. Необходимо начать побеждать, любой ценой: нужно брать такие задачи, которые точно сможешь решить, какими бы простыми они не были. Можешь вернуться к азам, началу, детскому уровню сложности, если потребуется - главное чтобы задачи начали решаться, не важно какие и как. Пока не уверен, что готов двигаться дальше - удерживаешь уровень, каким бы низким и зазорным он не был. Важно обмануть мозг, а не показать класс всему миру, иначе обратно утонешь.

    Сложность задачи не особо влияет на мотивацию, а вот факт решения/нерешения - влияет сильно. Не решил - значит не осилил, не осилил - значит не достоин, не достоин - значит иди ко дну и не рыпайся. Это как импотенция: импотент - значит не мужик, не мужик - значит никто, ничего не достоин и об тебя можно ноги вытирать. Подсознание портит всю малину, так что не следует давать ему шанса - лучше решить задачу попроще, чем не решить по сложнее.
    Ответ написан
    7 комментариев
  • Какой редактор будет наиболее подходящим в качестве "песочницы"?

    Fahrenhe17
    @Fahrenhe17
    Ruby on Rails developer
    В Atom есть плагин, чтобы запускать код - script.
    Для браузера есть cloud9. - по мне так очень хороший вариант, лучший для обучения.

    P. S. VIM наше все.
    Ответ написан
    4 комментария
  • Только начал учить javascript как понять?

    EreminD
    @EreminD
    Кое-что умею
    //javascript такой: хоба! Функция, которая принимает на вход один параметр 
    //и возвращает результат в виде х*х.
    //Пожалуй, я ее запомню, потом, может, пригодится
    var square = function(x) { return x*x; }; 
    
    //потом javascript такой: ага, надо че т в консоль вывести (то, что в скобках). 
    //А че в скобках? Итить-мадрить, это ж та самая функция, котораю я прост запомнил. 
    //Надо ее вызвать и на вход подать 12. Тогда мне вернется 12*12 и это я выведу в консоль.
    console.log(square(12));
    
    //огонь


    А если понятнее, то вот
    Ответ написан
    7 комментариев
  • Как найти наибольшую последовательность символов что повторяется в тексте более одного раза?

    Решение:

    Класс LongestSubstringFinder, производящий эту операцию:

    import java.util.Arrays;
    
    public final class LongestSubstringFinder {
    
        private LongestSubstringFinder() {}
    
        public static String findLongestSubstringAtString(String string) {
    
            string = string.replaceAll("\\s+", " ");
    
            int quantityOfSuffixes = string.length();
            String[] suffixes = new String[quantityOfSuffixes];
    
            for (int i = 0; i < quantityOfSuffixes; i++) {
                suffixes[i] = string.substring(i, quantityOfSuffixes);
            }
    
            Arrays.sort(suffixes);
    
            String longestRepeatedSubstring = "";
            for (int i = 0; i < quantityOfSuffixes - 1; i++) {
                String x = findLongestCommonPrefixOfTwoStrings(suffixes[i], suffixes[i + 1]);
    
                if (x.length() > longestRepeatedSubstring.length()) {
                    longestRepeatedSubstring = x;
                }
            }
            return longestRepeatedSubstring;
        }
    
        private static String findLongestCommonPrefixOfTwoStrings(String first, String second) {
            int quantity = Math.min(first.length(), second.length());
            for (int i = 0; i < quantity; i++) {
                if (first.charAt(i) != second.charAt(i))
                    return first.substring(0, i);
            }
            return first.substring(0, quantity);
        }
    }

    Тесты(пройдены):

    @Test
        public void testFindLongestSubstringAtStringFirst() throws Exception {
            String testString = "Сайт toster, бла бла бла Сайт toster";
            String neededResult = "Сайт toster";
            String longestSubstring = LongestSubstringFinder
                    .findLongestSubstringAtString(testString);
            assertEquals(longestSubstring, neededResult);
        }
    
        @Test
        public void testFindLongestSubstringAtStringSecond() throws Exception {
            String testString = "aboibooolsabbooolsadf";
            String neededResult = "booolsa";
            String longestSubstring = LongestSubstringFinder
                    .findLongestSubstringAtString(testString);
            assertEquals(longestSubstring, neededResult);
        }


    Об алгоритме: здесь и здесь.
    Ответ написан
    1 комментарий
  • Сколько шрифтов можно использовать на странице сайта?

    EreminD
    @EreminD
    Кое-что умею
    два - вполне себе нормально и естественно. Вот тут хороший лонгрид про то, как подбирать шрифтовые пары
    Ответ написан
    Комментировать
  • Как менять css-стили в зависимости от размера окна, но без использования медиа-запросов?

    paulradzkov
    @paulradzkov
    Дизайнер, верстальщик, начальник отдела UI
    Есть техника эмуляции одного брейкпоинта через min-width, max-width и calc.
    Этот «брейкпоинт» зависит от размеров контейнера, а не от ширины окна — идеально для виждетов.

    codepen.io/paulradzkov/pen/NNgVEO — вот пример.
    https://medium.freecodecamp.com/the-fab-four-techn... — вот статья с описанием принципа работы.
    Ответ написан
    Комментировать
  • Смена картинки при наведении курсора?

    @Cyber_bober
    берете такую конструкцию

    <div class="form-container">
      <div class="form" style="display:none;">
        тут форма
    </div>
    <div class="image">
    тут пикча
    </div>
    </div>


    .form-container:hover .image{
    display:none
    }
    
    .form-container .form{
    display:block;}


    но по итогу вы получаете интерфейсный баг связанный с hover событием. получается что при наведении появится форма, но если убрать мышку с области контейнера - форма пропадет, это моветон. Решение тут может быть такое, если пользователь заполнит какое-нибудь поле в форме, то манипуляции с картинкой больше не проводить, либо более разумной, скрывать изображение и показывать форму по клику на изображение.
    Для этого можно написать небольшой js

    $('.image').click(function(){
       $(this).hide();
       $('.form').show();
    });
    Ответ написан
    Комментировать
  • Что делать, если запутался в css?

    Elwen
    @Elwen
    1) Адаптивная - это, грубо говоря, фиксированная верстка, которая использует медиа запросы для того, что бы подстроится под устройство просмотра. Отзывчивая - это резиновая верстка с использованием тех же медиа запросов для того же. В свое время именно такое объяснение показалось мне самым простым и понятным. Но большинство заказчиков все равно воспринимает это как одно и тоже, так что объяснять будет дольше.
    Есть замечательный сайт liquidapsive.com, который очень наглядно показывает разницу между разными типами верстки (адаптивная, отзывчивая, фиксированная и резиновая) на примере одного макета. К нему же есть отличная статья на frontender.info, где довольно доходчиво рассказано о разных подходах, их плюсах и минусах.
    2) Как бы то ни было, это все же зависит от проекта. Резиновая верстка отлично подходит для большинства сайтов, но есть проекты, где целесообразней все же сделать отдельно мобильную версию. Например, соц. сети.
    3) Нет.
    4) К сожалению, есть много вопросов относительно возможностей и развития css.
    5) Единственного верного способа решить поставленную задачу в программировании нет. В большинстве случаев есть несколько способов. Бывает что одно решение выигрывает по тем или иным параметрам у другого. И каждый программист иногда чувствует, что его творение больше походит на монстра, чем на чистый код. Это вовсе не означает, что это так (хотя случается и такое, чего таить). В любом случае, взглянув на свой код, который сейчас вам кажется хорошим, через несколько лет, скорее всего, вы схватитесь за голову) Стремитесь совершенствоваться, но не зацикливайтесь на этом.
    Ответ написан
    2 комментария
  • Как кроссбраузерно получить блок такой формы?

    попробуй oferflow: hidden и два песвдоэлемента с transform: rotate(45deg) и нужными позициями
    только картинку специально подготовить нужно будет, скорей всего
    Ответ написан
    5 комментариев
  • Как сверстать такое меню?

    Padreramnt
    @Padreramnt
    Padreramnt
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .tab-controls {
                display: flex;
                flex-direction: row;
            }
    
            .tab-control {
                flex: 0 0 100px;
                z-index: 0;
                height: 60px;
                width: 100px;
                margin-left: -5px;
                border-bottom: 1px solid rgb(12, 12, 12);
                -webkit-box-sizing: border-box;
                -moz-box-sizing: border-box;
                box-sizing: border-box;
            }
            .spacer {
                flex: 1 1 8000px;
                border-bottom: 1px solid rgb(12, 12, 12);
            }
    
            .tab-control:first-child {
                margin-left: 0;
            }
    
            .tab-panel {
                display: none;
            }
    
            #tab input:nth-of-type(1):checked ~ .tab-panels .tab-panel:nth-child(1),
            #tab input:nth-of-type(2):checked ~ .tab-panels .tab-panel:nth-child(2),
            #tab input:nth-of-type(3):checked ~ .tab-panels .tab-panel:nth-child(3),
            #tab input:nth-of-type(4):checked ~ .tab-panels .tab-panel:nth-child(4),
            #tab input:nth-of-type(5):checked ~ .tab-panels .tab-panel:nth-child(5) {
                display: block;
            }
    
            #tab input:nth-of-type(1):checked ~ .tab-controls .tab-control:nth-child(1),
            #tab input:nth-of-type(2):checked ~ .tab-controls .tab-control:nth-child(2),
            #tab input:nth-of-type(3):checked ~ .tab-controls .tab-control:nth-child(3),
            #tab input:nth-of-type(4):checked ~ .tab-controls .tab-control:nth-child(4),
            #tab input:nth-of-type(5):checked ~ .tab-controls .tab-control:nth-child(5) {
                z-index: 9;
                border-bottom: 1px solid rgba(0, 0, 0, 0);
            }
        </style>
    </head>
    <body>
    <div id="tab">
        <input id="tabInput1" type="radio" name="tabControlsNamespace">
        <input id="tabInput2" type="radio" name="tabControlsNamespace">
        <input id="tabInput3" type="radio" name="tabControlsNamespace">
        <input id="tabInput4" type="radio" name="tabControlsNamespace">
        <input id="tabInput5" type="radio" name="tabControlsNamespace">
    
        <div class="tab-controls">
            <label id="tabControl1" for="tabInput1" class="tab-control">
                <svg width="100" height="60">
                    <path d="M100,60 C80,0 80,0 70,0 L0,0 L0,60" fill="black" stroke-width="2" stroke="black"
                          shape-rendering="geometricPrecision"></path>
                </svg>
            </label>
            <label id="tabControl2" for="tabInput2" class="tab-control">
                <svg width="100" height="60">
                    <path d="M100,60 C80,0 80,0 70,0 L5,0 L0,60" fill="red" stroke-width="2" stroke="black"
                          shape-rendering="geometricPrecision"></path>
                </svg>
            </label>
            <label id="tabControl3" for="tabInput3" class="tab-control">
                <svg width="100" height="60">
                    <path d="M100,60 C80,0 80,0 70,0 L5,0 L0,60" fill="green" stroke-width="2" stroke="black"
                          shape-rendering="geometricPrecision"></path>
                </svg>
            </label>
            <label id="tabControl4" for="tabInput4" class="tab-control">
                <svg width="100" height="60">
                    <path d="M100,60 C80,0 80,0 70,0 L5,0 L0,60" fill="blue" stroke-width="2" stroke="black"
                          shape-rendering="geometricPrecision"></path>
                </svg>
            </label>
            <label id="tabControl5" for="tabInput5" class="tab-control">
                <svg width="100" height="60">
                    <path d="M100,60 C80,0 80,0 70,0 L5,0 L0,60" fill="steel" stroke-width="2" stroke="black"
                          shape-rendering="geometricPrecision"></path>
                </svg>
            </label>
            <div class="spacer"></div>
        </div>
        <div class="tab-panels">
            <div id="tabPanel1" class="tab-panel">
                это первая панелька
            </div>
            <div id="tabPanel2" class="tab-panel">
                это вторая панелька
            </div>
            <div id="tabPanel3" class="tab-panel">
                третья панелька
            </div>
            <div id="tabPanel4" class="tab-panel">
                третья панелька
            </div>
            <div id="tabPanel5" class="tab-panel">
                четвертая панелька
            </div>
        </div>
    </div>
    </body>
    </html>

    прошу прощения за "дивную" верстку
    как пользоваться:
    1. создайте обертку для будущего виджета с закладками tab-widget
    2. добавьте нужное кл-во радио-кнопок (не забудьте про пространство имен этих кнопок, если желаете использовать несколько таб-виджетов на странице)
    3. добавьте блок-контейнер для кнопок control-box
    4. добавьте в control-box необходимое кол-во лейблов control-label (не забудьте связать их с инпутами for="{{tabInputId}}")
    5. добавьте в tab-widget блок-контейнер panel-box
    6. добавьте в panel-box необходимое кол-во панелей


    для интересного дизайна использовались svg (Scalable Vector Graphics)
    принцип работы svg path:
    коодринаты холста: 0, 0 - верхний левый угол; 100, 60 - нижний правый
    M - абсолютное перемещение кисти в точку x, y
    C - кубическая кривая Безье, стартует из текущей точки кисти, через управляющие точки x1, y1; x2, y2 в точку x, y
    L - рисование прямой в абсолютную точку x, y
    baedc35203794df08fdef38df71a9043.png
    что такое svg, читайте в интернете
    Основной принцип я изложил; стили, цвета и размеры кнопок и панелей подбирайте сами
    как работают кривые Безье можно посмотреть здесь: jquerymy.com/#CW-bzier-curv
    удачи =З
    Ответ написан
    Комментировать