{"id":280307,"date":"2016-11-01T18:15:03","date_gmt":"2016-11-01T15:15:03","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=280307"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=280307","title":{"rendered":"\u0414\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u0430\u0432\u0430\u0442\u0430\u0440\u0430, \u043e\u0431\u0440\u0435\u0437\u043a\u0430 \u0444\u043e\u0442\u043e \u043d\u0430 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u043c \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0435 \u0438 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435 \u043d\u0430 JavaScript \u0438 PHP"},"content":{"rendered":"<p>\u0414\u043e\u0431\u0440\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0441\u0443\u0442\u043e\u043a! \u0420\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044f \u0441\u0430\u0439\u0442 \u044f \u043f\u043e\u0434\u043e\u0448\u0435\u043b \u043a \u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u043c\u043d\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0430\u0432\u0430\u0442\u0430\u0440\u0430 \u0434\u043b\u044f \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435 \u0438 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430\u0445. \u0414\u043e\u043b\u0433\u043e \u0438\u0441\u043a\u0430\u043b \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u044b, \u0434\u0430\u0436\u0435 \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0440\u0435\u0448\u0438\u043b \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0441 \u0433\u043e\u0442\u043e\u0432\u044b\u043c\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u043c\u0438, \u0443\u0436\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u0443\u044e \u043a\u0435\u043c-\u0442\u043e (\u043d\u0435 \u043f\u043e\u043c\u043d\u044e \u043a\u0430\u043a \u043d\u0430\u0437\u044b\u0432\u0430\u043b\u0430\u0441\u044c \u0441\u0442\u0430\u0442\u044c\u044f, \u043d\u043e \u043e\u043d\u0430 \u0442\u043e\u0447\u043d\u043e \u0431\u044b\u043b\u0430 \u043d\u0430 \u0445\u0430\u0431\u0440\u0435 \u0438 \u0442\u0430\u043c \u0431\u044b\u043b\u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u044b \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438). \u041f\u043e\u0441\u043b\u0435 \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u044d\u0442\u0438\u0445 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a \u044f \u0440\u0435\u0448\u0438\u043b \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0432\u0441\u0435 \u043d\u0430 JavaScript \u0438 PHP (\u0437\u0430 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f ajax \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 php) \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 HTML5. \u0414\u043b\u044f \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u044f \u0441\u043e\u0437\u0434\u0430\u043b \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0434\u043b\u044f \u0445\u0430\u0431\u0440\u0430: <a href=\"https:\/\/youorg.ru\/test\/croper.php\">\u0434\u0435\u043c\u043e \u0434\u043b\u044f habrahabr<\/a>.<br \/>  <a name=\"habracut\"><\/a><br \/>   \u041d\u0430\u0447\u043d\u0435\u043c \u0441 \u043e\u0431\u0449\u0435\u0439 \u0447\u0430\u0441\u0442\u0438. \u0420\u0430\u0437\u043c\u0435\u0442\u043a\u0430.<\/p>\n<p>  \u0422\u0443\u0442 \u0432\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e. \u0412\u043d\u0443\u0442\u0440\u0438 \u0433\u043b\u0430\u0432\u043d\u043e\u0433\u043e \u0431\u043b\u043e\u043a\u0430 (\u0432 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 400x400px) \u044f \u0441\u043e\u0437\u0434\u0430\u043b \u0431\u043b\u043e\u043a \u0441 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435\u043c, \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0439 \u0431\u043b\u043e\u043a \u0434\u043b\u044f \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u043e\u0431\u0440\u0435\u0437\u043a\u0438 (200\u0445200px) \u0438 \u0442\u0430\u043a \u0436\u0435 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0439 \u0431\u043b\u043e\u043a \u043d\u0430 \u0432\u0441\u044e \u0448\u0438\u0440\u0438\u043d\u0443 \u0440\u0430\u0431\u043e\u0447\u0435\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044f \u043d\u0430\u0437\u0432\u0430\u043b \u0442\u0430\u0447\u043f\u0430\u0434\u043e\u043c (400\u0445400px). \u0414\u043b\u044f \u0431\u043e\u043b\u044c\u0448\u0435\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u044f \u0434\u043e\u0431\u0430\u0432\u0438\u043b \u043a\u043d\u043e\u043f\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u0442 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u043d\u0430 90 \u0433\u0440\u0430\u0434\u0443\u0441\u043e\u0432. \u0421\u0440\u0430\u0437\u0443 \u043e\u0431\u0440\u0430\u0449\u0430\u044e \u0412\u0430\u0448\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u0447\u0442\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u044d\u0442\u0438\u0445 \u0431\u043b\u043e\u043a\u043e\u0432 \u0441\u0443\u0433\u0443\u0431\u043e \u0438\u043d\u0434\u0438\u0432\u0438\u0434\u0443\u0430\u043b\u044c\u043d\u044b\u0435.<\/p>\n<p>  \u0424\u0443\u043d\u043a\u0446\u0438\u0438 \u0434\u043b\u044f \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0430.<\/p>\n<p>  \u0412\u0441\u0435 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u0441 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 onmousedown. \u041f\u0435\u0440\u0432\u043e\u0435 \u0447\u0442\u043e \u044f \u0432 \u043d\u0435\u0435 \u0434\u043e\u0431\u0430\u0432\u0438\u043b \u044d\u0442\u043e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043d\u0430\u0436\u0430\u0442\u0438\u0435\u043c \u043b\u0435\u0432\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u043c\u044b\u0448\u0438 \u0441 \u0437\u0430\u0436\u0430\u0442\u043e\u0439 \u043a\u043b\u0430\u0432\u0438\u0448\u0435\u0439 shift. \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u043c \u0441 \u0442\u0430\u0447\u043f\u0430\u0434\u043e\u043c. \u0414\u043b\u044f \u043f\u0435\u0440\u0435\u0434\u0430\u0447\u0438 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 php \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0443 \u044f \u0441\u043e\u0437\u0434\u0430\u043b 4 input type=\u00abhidden\u00bb \u0441\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 id \u043a\u0430\u043a x1 \u2014 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u0430 \u0441\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u043e\u0431\u0440\u0435\u0437\u043a\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043f\u043e \u043e\u0441\u0438 x, y1 \u2014 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043f\u043e \u043e\u0441\u0438 y, w \u2014 \u0448\u0438\u0440\u0438\u043d\u0430 \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, h \u2014 \u0432\u044b\u0441\u043e\u0442\u0430 \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f.<\/p>\n<pre><code class=\"javascript\">\/\/\u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 var image = document.getElementById('image'); \/\/\u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0442\u0430\u0447\u043f\u0430\u0434 var a = document.getElementById('touch_pad'); \/\/\u0438 input-\u044b \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u0438 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432\t var x1 = document.getElementById('x1'); var y1 = document.getElementById('y1'); var w = document.getElementById('w'); var h = document.getElementById('h'); \/\/\u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u043e\u0441\u043b\u0435 \u043d\u0430\u0436\u0430\u0442\u0438\u044f \u043b\u0435\u0432\u043e\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u043c\u044b\u0448\u0438 a.onmousedown = function(e){ \/\/\u0435\u0441\u043b\u0438 \u043d\u0430\u0436\u0430\u0442 shift, \u0442\u043e \u043e\u0431\u044a\u044f\u0432\u043b\u044f\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \tif(e.shiftKey){ \/\/\u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043a\u0443\u0440\u0441\u043e\u0440\u0430                  var koefx = e.clientX + e.clientY; \/\/\u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0448\u0438\u0440\u0438\u043d\u0443 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \t\tvar d = image.offsetWidth; \/\/\u043f\u043e\u0441\u043b\u0435 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f \u043c\u044b\u0448\u044c\u044e \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f  \t\ta.onmousemove = function(e){ \/\/\u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043a\u0443\u0440\u0441\u043e\u0440\u0430, \u0447\u0442\u043e\u0431 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0440\u0430\u0437\u043d\u0438\u0446\u0443 \u043e\u0442 koefx \t\tvar reli = e.clientX + e.clientY; \/\/\u0438 \u0437\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044e \u043f\u043e \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u043e\u043c\u0443 \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442\u0443 \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 \t\timage.style.width = d + reli*2 - koefx*2 + 'px'; \t\tvar wid = image.width; \t\tvar heig = image.height; \/\/\u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0448\u0438\u0440\u0438\u043d\u0430 \u0438 \u0432\u044b\u0441\u043e\u0442\u0430 \u0442\u0430\u0447\u043f\u0430\u0434\u0430 400px, \u0430 \u0431\u043b\u043e\u043a\u0430 \u043e\u0431\u0440\u0435\u0437\u043a\u0438 200px \u0438 \u043e\u043d \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0432 \u0446\u0435\u043d\u0442\u0440\u0435 - \/\/\u043c\u044b \u0441\u043c\u0435\u0449\u0430\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043d\u0430 100px \u043f\u043e x \u0438 y \t\tvar ll = 100 - image.offsetLeft; \t\tvar tt = 100 - image.offsetTop; \/\/\u0438 \u0432\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u0432 \u0444\u043e\u0440\u043c\u0443 \u043d\u043e\u0432\u044b\u0435 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b x \u0438 y \u0438 \u0437\u0430\u0434\u0430\u0435\u043c \u043d\u043e\u0432\u0443\u044e \u0432\u044b\u0441\u043e\u0442\u0443 \u0438 \u0448\u0438\u0440\u0438\u043d\u0443 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \t\tx1.setAttribute('value', ll); \t\ty1.setAttribute('value', tt); \t\tw.setAttribute('value', wid); \t\th.setAttribute('value', heig); \t\t} \t} <\/code><\/pre>\n<p>  \u041a\u0430\u043a \u0432\u0438\u0434\u0438\u0442\u0435 \u0437\u0434\u0435\u0441\u044c \u0432\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e, \u0447\u0443\u0442\u044c \u043f\u043e\u0437\u0436\u0435 \u043c\u044b \u043e\u0431\u044a\u044f\u0432\u0438\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043b\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438 \u043a\u043e\u043b\u0435\u0441\u0430 \u043c\u044b\u0448\u0438, \u0447\u0442\u043e \u0434\u0430\u0441\u0442 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e.<\/p>\n<p>  \u0414\u0430\u043b\u0435\u0435 \u043d\u0430\u0447\u043d\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u0435\u0441\u043b\u0438 shift \u043d\u0435 \u0437\u0430\u0436\u0430\u043b\u0438:<\/p>\n<pre><code class=\"javascript\">else { \/\/\u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0442\u0435\u043a\u0443\u0449\u0438\u0435 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u043a\u0443\u0440\u0441\u043e\u0440\u0430 \tvar x = e.pageX; \tvar y = e.pageY; \/\/\u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \tvar lleft = image.offsetLeft; \tvar ttop = image.offsetTop; \/\/\u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442\u044b \u043f\u043e \u043e\u0441\u044f\u043c x \u0438 y  \tvar lleft = x - lleft; \tvar ttop = y - ttop; \/\/\u043f\u043e\u0441\u043b\u0435 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f \u043c\u044b\u0448\u044c\u044e \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \ta.onmousemove = function(e){ \/\/\u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u043d\u043e\u0432\u044b\u0435 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u043a\u0443\u0440\u0441\u043e\u0440\u0430 \t\tx = e.pageX; \t\ty = e.pageY; \/\/\u0438 \u0437\u0430\u043d\u043e\u0432\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \t\tvar l = image.offsetLeft; \t\tvar t = image.offsetTop; \/\/\u0437\u0434\u0435\u0441\u044c \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u0440\u0430\u0437\u043d\u0438\u0446\u044b \u043c\u0435\u0436\u0434\u0443 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435\u043c \u0438 \u0431\u043b\u043e\u043a\u043e\u043c \u043e\u0431\u0440\u0435\u0437\u043a\u0438  \t\tvar ll = 100 - Number(l); \t\tvar tt = 100 - Number(t); \/\/\u0438 \u043d\u0430\u043a\u043e\u043d\u0435\u0446 \u0437\u0430\u0434\u0430\u0435\u043c \u0441\u0442\u0438\u043b\u0438 \u0438 \u0432\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u0432 \u0444\u043e\u0440\u043c\u0443 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435\t\t \t\timage.style.marginLeft = x - lleft; \t\timage.style.marginTop = y - ttop;\t\t \t\tvar wid = image.width; \t\tvar heig = image.height; \t\tx1.setAttribute('value', ll); \t\ty1.setAttribute('value', tt); \t\tw.setAttribute('value', wid); \t\th.setAttribute('value', heig); \t} \t}  \/\/\u043f\u0440\u0438 \u0441\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043d\u0438\u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u044f mouseup \u043e\u0447\u0438\u0449\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e mousemove \ta.onmouseup = function(){ \ta.onmousemove = function(){} \t} return\t } <\/code><\/pre>\n<p>   \u041a\u0430\u043a \u0432\u0438\u0434\u0438\u0442\u0435 \u0437\u0434\u0435\u0441\u044c \u0432\u0441\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e, \u0447\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u043e\u0431\u0440\u0435\u0437\u043a\u0438 \u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430.<br \/>   \u0414\u0430\u043b\u0435\u0435 \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u0441\u0435 \u0442\u043e \u0436\u0435, \u043d\u043e \u0443\u0436\u0435 \u0441 \u043c\u0435\u0442\u043e\u0434\u0430\u043c\u0438 touchstart \u0438 touchmove \u0434\u043b\u044f \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432:<\/p>\n<pre><code class=\"javascript\">a.ontouchstart = function(e){\t \/\/\u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0435\u0441\u043b\u0438 \u043f\u0430\u043b\u044c\u0435\u0446 \u0438\u043b\u0438 \u043f\u0430\u043b\u044c\u0446\u044b \u043a\u043e\u0441\u043d\u0443\u043b\u0438\u0441\u044c \u0441\u0435\u043d\u0441\u043e\u0440\u0430 \/\/\u0435\u0441\u043b\u0438 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043a\u0430\u0441\u0430\u043d\u0438\u0439 \u0440\u0430\u0432\u043d\u044f\u0435\u0442\u0441\u044f \u0434\u0432\u0443\u043c, \u0442\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 scal(), \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043f\u043e\u0437\u0436\u0435 \tif(e.targetTouches.length == 2){ \t\tscal(e); \t} \/\/\u0435\u0441\u043b\u0438 \u043a\u0430\u0441\u0430\u043d\u0438\u0435 \u043e\u0434\u043d\u043e, \u0442\u043e \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043f\u0435\u0440\u0435\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f\t \tif(e.targetTouches.length == 1){ \/\/\u043a\u0430\u0436\u0434\u043e\u0435 \u043a\u0430\u0441\u0430\u043d\u0438\u0435 \u0437\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0432 \u043c\u0430\u0441\u0441\u0438\u0432 targetTouches \u0438 \u0442\u0430\u043a, \u043a\u0430\u043a \u0443 \u043d\u0430\u0441 \u043a\u0430\u0441\u0430\u043d\u0438\u0435 \u043e\u0434\u043d\u043e \/\/\u043c\u044b \u0431\u0435\u0440\u0435\u043c \u043f\u0435\u0440\u0432\u043e\u0435 \u043a\u0430\u0441\u0430\u043d\u0438\u0435, \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u044f [0], \u0442\u043e \u0435\u0441\u0442\u044c \u043a\u0430\u043a \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u0441 \u043a\u0443\u0440\u0441\u043e\u0440\u043e\u043c (\u043e\u043d \u0432\u0441\u0435\u0433\u043e \u043e\u0434\u0438\u043d) \/\/\u043c\u044b \u0432\u043c\u0435\u0441\u0442\u043e e (\u0432 \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u0445 mousedown \u0438 mousemowe \u043d\u0430\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0431\u044b\u043b\u043e \u043e\u0434\u043d\u043e\u0439 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439) \/\/\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c e \u0441 \u043c\u0435\u0442\u043e\u0434\u043e\u043c targetTouches \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043a\u0430\u0441\u0430\u043d\u0438\u044f [0] \u0438 \u043f\u0440\u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u044d\u0442\u043e \u0432\u0441\u0435 \/\/\u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e handl \tvar handl = e.targetTouches[0]; \tvar x = handl.pageX; \tvar y = handl.pageY; \tvar lleft = image.offsetLeft; \tvar ttop = image.offsetTop; \tvar lleft = x - lleft; \tvar ttop = y - ttop;     a.ontouchmove = function(e) { \t\tvar handle = e.targetTouches[0] \t    x = handle.pageX; \t\ty = handle.pageY; \t\tvar l = image.offsetLeft; \t\tvar t = image.offsetTop; \t\tvar ll = 100 - Number(l); \t\tvar tt = 100 - Number(t); \t\t \t\timage.style.marginLeft = x - lleft; \t\timage.style.marginTop = y - ttop; \t\ta.ontouchend = function(){ \t\tvar wid = image.width; \t\tvar heig = image.height; \t\tx1.setAttribute('value', ll); \t\ty1.setAttribute('value', tt); \t\tw.setAttribute('value', wid); \t\th.setAttribute('value', heig); \t\t} \t\t}\t\t \t} \treturn } <\/code><\/pre>\n<p>  \u0422\u043e \u0435\u0441\u0442\u044c, \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435, \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u044b, \u0437\u0430 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u0447\u0442\u043e \u043f\u0440\u0438 \u0440\u0430\u0431\u043e\u0442\u0435 \u0441 \u0441\u0435\u043d\u0441\u043e\u0440\u043e\u043c \u043d\u0430\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0431\u043e\u043b\u0435\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u00ab\u043a\u0443\u0440\u0441\u043e\u0440\u0430\u00bb.<\/p>\n<p>  \u0414\u0430\u043b\u044c\u0448\u0435 \u0447\u0443\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u0435\u0439. \u0415\u0441\u043b\u0438 \u043a\u0430\u0441\u0430\u043d\u0438\u0439 \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 2, \u0442\u043e \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430, \u0430 \u0442\u0430\u043c \u0435\u0441\u0442\u044c \u0441\u0432\u043e\u0438 \u043f\u043e\u0434\u0432\u043e\u0434\u043d\u044b\u0435 \u043a\u0430\u043c\u043d\u0438. \u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445 \u043f\u0440\u0438 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0438\/\u0443\u043c\u0435\u043d\u044c\u0448\u0435\u043d\u0438\u0438 \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a, \u0447\u0442\u043e\u0431 \u043c\u0435\u043d\u044f\u043b\u0441\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043d\u0435 \u043e\u0442 \u043b\u0435\u0432\u043e\u0433\u043e \u0432\u0435\u0440\u0445\u043d\u0435\u0433\u043e \u0443\u0433\u043b\u0430, \u0430 \u043e\u0442 \u0446\u0435\u043d\u0442\u0440\u0430. \u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u0432\u0441\u0435\u0433\u0434\u0430 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u043f\u043e\u043b\u043e\u0436\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u0447\u0438\u0441\u043b\u043e\u043c \u0438 \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0442\u044c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u00ab\u043d\u043e\u043b\u044c\u00bb \u043f\u0440\u0438 \u0441\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043d\u0438\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f. \u0418 \u0442\u0430\u043a \u043f\u043e\u0435\u0445\u0430\u043b\u0438:<\/p>\n<pre><code class=\"javascript\">\/\/\u043e\u0431\u044a\u044f\u0432\u043b\u044f\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431 \u043d\u0430 \u0442\u0430\u0447-\u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430\u0445 function scal(e){\t \/\/\u043f\u0440\u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e touc \u043c\u0430\u0441\u0441\u0438\u0432 \u0441 \u043a\u0430\u0441\u0430\u043d\u0438\u044f\u043c\u0438\t \t\tvar touc = e.targetTouches; \t\tvar cur_w = image.offsetWidth; \/\/\u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u043f\u0435\u0440\u0432\u044b\u0439 \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c\t \t\tvar koef = Math.sqrt(Math.pow((touc[0].clientX - touc[1].clientX), 2) + Math.pow((touc[0].clientY - touc[1].clientY), 2)); \/\/\u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043f\u043e\u0441\u043b\u0435 \u0441\u043e\u0431\u044b\u0442\u0438\u044f touchmove \u0438 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0442\u044c \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442 \t\t\ta.ontouchmove = function(e){ \t\t\t\tvar tou = e.targetTouches; \t\t\t\tvar relis = Math.sqrt(Math.pow((tou[0].clientX - tou[1].clientX), 2) + Math.pow((tou[0].clientY - tou[1].clientY), 2));\t\t\t\t\t\t \t\t\t\tvar im = image.offsetWidth; \/\/\u0437\u0430\u0434\u0430\u0435\u043c \u0440\u0430\u0437\u043c\u0435\u0440 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0440\u0430\u0437\u043d\u0438\u0446\u0443 \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0438\u0435\u043d\u0442\u043e\u0432 \t\t\t\timage.style.width = cur_w + relis*2 - koef*2  + 'px'; \t\t\t} \/\/\u043f\u0440\u0438 \u0441\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043d\u0438\u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u044f touchend \u043f\u0440\u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \t\t\ta.ontouchend = function(e){\t\t \t\tvar wid = image.width; \t\tvar heig = image.height; \t\tvar ll = 100 - image.offsetLeft; \t\tvar tt = 100 - image.offsetTop; \t\tx1.setAttribute('value', ll); \t\ty1.setAttribute('value', tt); \t\tw.setAttribute('value', wid); \t\th.setAttribute('value', heig); \t\t\t} \t\t } <\/code><\/pre>\n<p>   \u041e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0430 \u043f\u0440\u0438 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0435 \u043a\u043e\u043b\u0435\u0441\u0430 \u043c\u044b\u0448\u0438 \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435:<\/p>\n<pre><code class=\"javascript\">\/\/\u0437\u0434\u0435\u0441\u044c \u0432\u0441\u0435 \u043f\u0440\u0435\u0434\u0435\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e a.onwheel = function(e){ \tvar t = e.deltaY\/5; \tvar d = image.offsetWidth;\t \timage.style.width = d-t; \t\tvar wid = image.width; \t\tvar heig = image.height; \t\tvar ll = 100 - image.offsetLeft; \t\tvar tt = 100 - image.offsetTop; \t\tx1.setAttribute('value', ll); \t\ty1.setAttribute('value', tt); \t\tw.setAttribute('value', wid); \t\th.setAttribute('value', heig); \treturn } <\/code><\/pre>\n<p>   \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043c\u044b \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043d\u0430 \u043a\u043d\u043e\u043f\u043a\u0443 \u0432\u0440\u0430\u0449\u0435\u043d\u0438\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f. \u041f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u043e\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u043e\u0439 jquery \u043c\u0435\u0442\u043e\u0434\u043e\u043c ajax. \u0412 \u043c\u043e\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u043d\u0430\u0437\u0432\u0430\u043b leftSide(), \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u0432\u0440\u0430\u0449\u0435\u043d\u0438\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043e\u0434\u043d\u0443 \u0441\u0442\u043e\u0440\u043e\u043d\u0443:<\/p>\n<pre><code class=\"javascript\">function  leftSide(){\t \t\tvar ug = '90'; \t\t$.ajax({ \t\t\turl: 'rotate.php', \t\t\tmethod: 'GET', \t\t\tdata: {&quot;deg&quot; : ug, &quot;filename&quot; : &quot;img.jpg&quot;}\t\t\t\t\t\t \t\t}).done(function(data){\t \/\/\u0438\u0437\u0431\u0430\u0432\u043b\u044f\u0435\u043c\u0441\u044f \u043e\u0442 \u043a\u0435\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f\t\t\t\t \t\t\timage.src = 'img.jpg?'+ Math.random(); \t\t\timage.onload = function(){ \t\t\tvar ll = 100 - image.offsetLeft; \t\t\tvar tt = 100 - image.offsetTop; \t\t\tvar wid = image.width; \t\t\tvar heig = image.height; \t\t\tx1.setAttribute('value', ll); \t\t\ty1.setAttribute('value', tt); \t\t\tw.setAttribute('value', wid); \t\t\th.setAttribute('value', heig); \t\t\t} \t\t})\t \t } <\/code><\/pre>\n<p>   \u0421\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0441\u043a\u0440\u0438\u043f\u0442 \u0444\u0430\u0439\u043b\u0430 rotate.php \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442:<\/p>\n<pre><code class=\"php\">&lt;?php \t$filename = $_GET['filename']; \t$degrees = (int)$_GET['deg']; \t$source = imagecreatefromjpeg($filename); \t$rotate = imagerotate($source, $degrees, 0); \timagejpeg($rotate,$filename, 100); \timagedestroy($source); \timagedestroy($rotate); ?&gt; <\/code><\/pre>\n<p>   \u041e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u043e\u0433\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043a\u0430\u0436\u0434\u044b\u0439 \u0432\u044b\u0431\u0438\u0440\u0430\u0435\u0442 \u0441\u0430\u043c, \u043b\u0438\u0447\u043d\u043e \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043a\u0440\u0438\u043f\u0442:<\/p>\n<pre><code class=\"php\">&lt;? if(isset($_POST['crop'])){ $filename = 'img.jpg'; $new_filen = 'ava\/img.jpg'; list($current_width, $current_height) = getimagesize($filename);  $x1 = $_POST['x'];  $y1 = $_POST['y'];  $w = $_POST['w'];  $h = $_POST['h'];    $new = imagecreatetruecolor($w, $h); $current_image = imagecreatefromjpeg($filename); imagecopyresampled($new, $current_image, 0, 0, 0, 0, $w, $h, $current_width, $current_height); $final = imagecreatetruecolor(200, 200); imagecopy($final, $new, 0, 0, $x1, $y1, 200, 200); $fin_creat = imagejpeg($final, $new_filen, 100); $handle = fopen($new_filen, &quot;r&quot;); unlink($filename ); }  ?&gt; <\/code><\/pre>\n<p>  \u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0437\u0430 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435!<br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habrahabr.ru\/post\/314180\/\"> https:\/\/habrahabr.ru\/post\/314180\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0414\u043e\u0431\u0440\u043e\u0433\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0441\u0443\u0442\u043e\u043a! \u0420\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044f \u0441\u0430\u0439\u0442 \u044f \u043f\u043e\u0434\u043e\u0448\u0435\u043b \u043a \u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u043c\u043d\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0430\u0432\u0430\u0442\u0430\u0440\u0430 \u0434\u043b\u044f \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u0439 \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u0435 \u0438 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430\u0445. \u0414\u043e\u043b\u0433\u043e \u0438\u0441\u043a\u0430\u043b \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u044b, \u0434\u0430\u0436\u0435 \u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u0440\u0435\u0448\u0438\u043b \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0441 \u0433\u043e\u0442\u043e\u0432\u044b\u043c\u0438 \u0444\u0443\u043d\u043a\u0446\u0438\u044f\u043c\u0438, \u0443\u0436\u0435 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u0443\u044e \u043a\u0435\u043c-\u0442\u043e (\u043d\u0435 \u043f\u043e\u043c\u043d\u044e \u043a\u0430\u043a \u043d\u0430\u0437\u044b\u0432\u0430\u043b\u0430\u0441\u044c \u0441\u0442\u0430\u0442\u044c\u044f, \u043d\u043e \u043e\u043d\u0430 \u0442\u043e\u0447\u043d\u043e \u0431\u044b\u043b\u0430 \u043d\u0430 \u0445\u0430\u0431\u0440\u0435 \u0438 \u0442\u0430\u043c \u0431\u044b\u043b\u0438 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u044b \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438). \u041f\u043e\u0441\u043b\u0435 \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u044d\u0442\u0438\u0445 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a \u044f \u0440\u0435\u0448\u0438\u043b \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0432\u0441\u0435 \u043d\u0430 JavaScript \u0438 PHP (\u0437\u0430 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f ajax \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 php) \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 HTML5. \u0414\u043b\u044f \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u044f \u0441\u043e\u0437\u0434\u0430\u043b \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0434\u043b\u044f \u0445\u0430\u0431\u0440\u0430: <a href=\"https:\/\/youorg.ru\/test\/croper.php\">\u0434\u0435\u043c\u043e \u0434\u043b\u044f habrahabr<\/a>.  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-280307","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/280307","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=280307"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/280307\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=280307"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=280307"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=280307"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}