Это j.src = event.target.result; зачем?
Да и зачем
img.src = event.target.result;
и
i.src = event.target.result;
Есть источник, рассчитали параметры увеличения/уменьшения (у вас этого не видно и близко, если конечно наплевать на искажения), с этими параметрами берем из исходного в canvas. Зачем плодить лишнее.
|