Как повернуть эллипс?

Используя это:

local W, H = 100, 50

function love.draw()
  love.graphics.translate(love.graphics.getWidth()/2,love.graphics.getHeight()/2)
  for i = 1, 360 do
    local I = math.rad(i)
    local x,y = math.cos(I)*W, math.sin(I)*H
    love.graphics.line(0, 0, x, y)
  end
end

Я могу соединить линию с центром эллипса (с длиной W и высотой H) и краем. Как «повернуть» эллипс вокруг его центра с параметром R? Я знаю, что вы можете сделать это с помощью love.graphics.ellipse и love.graphics.rotate, но есть ли способ получить координаты точек на повернутом эллипсе?


person EpichinoM2    schedule 31.10.2018    source источник


Ответы (1)


Это проблема тригонометрии, вот как работает базовое 2D-вращение. Представьте себе точку, расположенную в (x, y). Если вы хотите повернуть эту точку вокруг начала координат (в вашем случае 0,0) на угол θ, координаты новой точки будут расположены в (x1, y1) с помощью следующего преобразования

x1 = xcosθ − ysinθ
y1 = ycosθ + xsinθ

В вашем примере я добавил новый эллипс после поворотов

function love.draw()
    love.graphics.translate(love.graphics.getWidth()/2,love.graphics.getHeight()/2)
    for i = 1, 360, 5 do
        local I = math.rad(i)
        local x,y = math.cos(I)*W, math.sin(I)*H
        love.graphics.setColor(0xff, 0, 0) -- red
        love.graphics.line(0, 0, x, y)
    end

  -- rotate by angle r = 90 degree
    local r = math.rad(90)
    for i = 1, 360, 5 do
        local I  = math.rad(i)
        -- original coordinates
        local x  = math.cos(I) * W 
        local y  = math.sin(I) * H
        -- transform coordinates
        local x1 = x * math.cos(r) - y * math.sin(r) 
        local y1 = y * math.cos(r) + x * math.sin(r) 
        love.graphics.setColor(0, 0, 0xff) -- blue
        love.graphics.line(0, 0, x1, y1)
    end
end

введите здесь описание изображения

person wsha    schedule 01.11.2018