Ответы пользователя по тегу Canvas
  • Как создать перегруженный конструктор класса в JS?

    Stdit
    @Stdit
    [мимо]
    Ответ написан
    Комментировать
  • Как создать перегруженный конструктор класса в JS?

    Stdit
    @Stdit
    А зачем вам объект «окружность»? Что вы с ним потом собираетесь делать, ради чего здесь он создаётся? Может проще написать просто какой-нибудь «хелпер»:
    helpers.circle = function (context, x, y, radius, color) {
        context.arc(x, y, radius, startDegrees, endDegrees, counterClockwise);
        context.fillStyle = color;
        context.fill();
    }
    

    Ну или завести объект «рисовальщик», хранящий ссылку на графический контекст и настройки рисования, и имеющий необходимые методы (вроде приведённого выше) для работы с этим контекстом:
    function Painter(context, defaultColor) {
        this.context = context;
        this.defaultColor = defaultColor;
        this.circle = function (x, y, r, color) {
            if (color === undefined) {
                color = this.defaultColor;
            } 
            this.context.arc(x, .... // code
        }
    }
    

    Это если вам нужно наследование. Объекты по-моему имеет смысл создавать только для реально существующих инстансов (спрайты, например, от которых наследуются игровые объекты и персонажи). Если окружность — это динамический объект, тогда можно уже думать и крутить, в зависимости от архитектуры графики, например так:
    function Circle(x, y, r, color) {
        this.x = x;
        this.y = y;
        this.r = r;
        this.color = color;
        this.render = function (context) {
            context.arc(this.x, ... 
        }
    }
    
    Ответ написан
    6 комментариев
  • Создание анимированого логотипа

    Stdit
    @Stdit
    GIF идеально должен подойти. Если нужен труколор — тогда композиция из PNG + JS-анимация. Если на ИЕ8 пофиг — тогда Canvas.
    Ответ написан
    Комментировать
  • Обработка изображения, формирование выпуклости

    Stdit
    @Stdit
    Хотел объяснить алгоритм на пальцах, но пришел в выводу, что проще написать пример: jsfiddle.net/CDKXm/
    Смотрите, если что не понятно — в личку. Алгоритм топорный, без антиалиасинга и оптимизаций.
    Ответ написан
    3 комментария