{"id":155447,"date":"2012-10-24T22:08:04","date_gmt":"2012-10-24T18:08:04","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=155447"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=155447","title":{"rendered":"<span class=\"post_title\">\u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u0432 CSS<\/span>"},"content":{"rendered":"<div class=\"content html_format\">\n<h4>\u041f\u0440\u0438\u0441\u0442\u0443\u043f\u0430\u044f \u043a \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u043c \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u043c \u043d\u0430 CSS (<b>C<\/b>ustom <b>C<\/b>ascading<b> S<\/b>tyle<b> S<\/b>heets<b> F<\/b>ilters)<\/h4>\n<h4>\u0412\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435<\/h4>\n<p>  \u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b (\u0434\u0430\u043b\u0435\u0435 CCSSF)(\u0440\u0430\u043d\u0435\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0435 \u043a\u0430\u043a CSS \u0448\u0435\u0439\u0434\u0435\u0440\u044b) \u2014 \u044d\u0442\u043e \u043d\u043e\u0432\u0430\u044f \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u0430\u044f \u0444\u0438\u0447\u0430, \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0449\u0430\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0435 \u0440\u0443\u043a\u0430\u043c\u0438 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b HTML \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430.<br \/>  \u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0447\u0430\u0441\u0442\u044c\u044e <a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html\">Filter Effects 1.0 specification<\/a>. \u041e\u043d\u0438 \u0434\u043e\u043f\u043e\u043b\u043d\u044f\u044e\u0442 \u0434\u0440\u0443\u0433\u0443\u044e \u0447\u0430\u0441\u0442\u044c \u044d\u0442\u043e\u0439 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438, \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044e\u0449\u0443\u044e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u0431\u0449\u0438\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b, \u0443\u0436\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u044b (blur, sepia, contrast, grayscale). <br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h5>\u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b<\/h5>\n<p>  \u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u044e\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b, \u0441\u0445\u043e\u0436\u0438\u0439 \u0441 \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u043c\u0438 \u0432 \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440\u0430\u0445 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439 \u2014 \u0443 \u0432\u0430\u0441 \u0441\u0435\u0442 \u043f\u0440\u0435\u0434\u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0445, \u043f\u043e\u0432\u0441\u0435\u043c\u0435\u0441\u0442\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0442\u043e\u043b\u044c\u043a\u043e <a href=\"http:\/\/html5-demos.appspot.com\/static\/css\/filters\/index.html\">\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b<\/a>.<br \/>  \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u044d\u0442\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0431\u044b\u043b\u043e \u0441\u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043e \u0432 grayscale \u0430 \u0437\u0430\u0442\u0435\u043c \u0431\u044b\u043b \u043f\u0440\u0438\u043c\u0435\u043d\u0451\u043d blur:<\/p>\n<p>  <a href=\"http:\/\/html5-demos.appspot.com\/static\/css\/filters\/index.html\"><img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/jupiter-original.jpg\" alt=\"image\"\/><img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/jupiter-filter.jpg\"\/><\/a><\/p>\n<p>  (\u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0436\u0430\u0442\u044c \u043d\u0430 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u0438 <a href=\"http:\/\/html5-demos.appspot.com\/static\/css\/filters\/index.html\">\u0443\u0431\u0435\u0434\u0438\u0442\u044c\u0441\u044f \u0441\u0430\u043c\u043e\u043c\u0443<\/a>, \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 Chrome)<\/p>\n<h5>\u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b<\/h5>\n<p>  \u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b, \u0441 \u0434\u0440\u0443\u0433\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043d\u043e\u0432\u044b\u0435 \u0442\u0438\u043f\u044b \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0441\u0430\u043c\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430, \u043d\u043e \u0435\u0449\u0435 \u0438 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c \u0441\u0430\u043c\u0443 \u0441\u0443\u0442\u044c \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f <a href=\"#shaders\">\u0448\u0435\u0439\u0434\u0435\u0440\u044b<\/a>.<br \/>  \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u044d\u0442\u0430 \u043a\u0430\u0440\u0442\u0430, \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u0430\u044f \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442, \u0431\u044b\u043b\u0430 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0430 \u0432 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0443\u044e \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0443\u044e \u0441\u0444\u0435\u0440\u0443:<\/p>\n<p>  <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere2.html\"><img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/img_filter_custom_source.jpg\" alt=\"image\"\/><br \/>  <img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/img_filter_custom_result.jpg\" alt=\"image\"\/><\/a><\/p>\n<p>  (\u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0436\u0430\u0442\u044c \u043d\u0430 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438 \u0438 <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere2.html\">\u0443\u0431\u0435\u0434\u0438\u0442\u044c\u0441\u044f \u0441\u0430\u043c\u043e\u043c\u0443<\/a>, \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u0432 \u043f\u0443\u043d\u043a\u0442\u0435 <a href=\"#compatibility\">\u041a\u0430\u043a \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u0438<\/a>)<\/p>\n<p>  \u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u0438\u043c\u0435\u044e\u0442 \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u0443, \u043d\u0435\u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u043c\u0443 \u0434\u043b\u044f \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445. \u041e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442 \u0434\u043e\u0441\u0442\u0438\u0447\u044c \u0431\u043e\u043b\u044c\u0448\u0435\u0433\u043e, \u0447\u0435\u043c \u0431\u044b\u043b\u043e \u0437\u0430\u0434\u0443\u043c\u0430\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u0435\u043b\u044f\u043c\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043e\u0432 \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e.<br \/>  \u0421\u0430\u043c\u044b\u0435 \u0437\u0430\u043c\u0435\u0442\u043d\u044b\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u043c\u043e\u0433\u0443\u0442 \u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c \u043f\u0438\u043a\u0441\u0435\u043b\u0438 \u0441 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0433\u043e DOM \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430, \u0447\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u043e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442 \u0441\u0434\u0435\u043b\u0430\u0442\u044c, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, blur (\u0421\u043c\u043e\u0442\u0440\u0438\u0442\u0435 \u0432 \u043f\u0443\u043d\u043a\u0442\u0435 <a href=\"#limitations\">\u041e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432<\/a>).<\/p>\n<p>  <a name=\"shaders\"><\/a><\/p>\n<h4>\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b?<\/h4>\n<p>  \u042d\u0444\u0444\u0435\u043a\u0442\u044b \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432 \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0438\u043c\u0438 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0430\u043c\u0438, \u043d\u0430\u0437\u0432\u044b\u0432\u0430\u0435\u043c\u044b\u043c\u0438 \u0448\u0435\u0439\u0434\u0435\u0440\u044b (shaders).<br \/>  \u0428\u0435\u0439\u0434\u0435\u0440\u044b \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044e\u0442 3D \u0444\u043e\u0440\u043c\u0443 \u0438 \u0432\u0438\u0434 \u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 (\u0448\u0435\u0439\u0434\u0435\u0440\u044b \u043e\u043f\u0435\u0440\u0438\u0440\u0443\u044e\u0442 <a href=\"http:\/\/en.wikipedia.org\/wiki\/Polygon_mesh\">\u043f\u043e\u043b\u0438\u0433\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u0441\u0435\u0442\u043a\u0430\u043c\u0438<\/a>).<br \/>  \u0428\u0435\u0439\u0434\u0435\u0440\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043d\u0430 \u0436\u0435\u043b\u0435\u0437\u0435 \u0432\u0438\u0434\u0435\u043e\u043a\u0430\u0440\u0442\u044b. \u041e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0434\u0430\u043d\u043d\u044b\u0445, \u0447\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e \u043e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u044b\u043c\u0438, \u043d\u043e \u0447\u0430\u0441\u0442\u043e \u0438 \u043b\u0438\u0448\u043d\u0438\u043c\u0438 \u043f\u043e \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044e \u0441 \u0442\u0438\u043f\u0438\u0447\u043d\u044b\u043c \u0446\u0438\u043a\u043b\u043e\u043c \u0440\u0430\u0431\u043e\u0442\u044b \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c, \u043a\u0440\u0443\u0442\u044f\u0449\u0438\u0445\u0441\u044f \u043d\u0430 CPU.<br \/>  CCSSF \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 <a href=\"http:\/\/en.wikipedia.org\/wiki\/GLSL\">GLSL<\/a> \u043a\u0430\u043a \u044f\u0437\u044b\u043a \u0434\u043b\u044f \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432.<br \/>  \u0415\u0441\u043b\u0438 \u0432\u044b \u0437\u043d\u0430\u043a\u043e\u043c\u044b \u0441 <a href=\"http:\/\/en.wikipedia.org\/wiki\/Shader\">\u0448\u0435\u0439\u0434\u0435\u0440\u0430\u043c\u0438<\/a> \u043f\u043e \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e \u0433\u0440\u0430\u0444\u0438\u043a\u0438, \u0437\u0430\u0434\u0435\u0439\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u043c\u0443 \u0448\u0435\u0439\u0434\u0435\u0440\u043d\u044b\u0435 \u044f\u0437\u044b\u043a\u0438 (<a href=\"http:\/\/en.wikipedia.org\/wiki\/OpenGL\">OpenGL<\/a>, <a href=\"http:\/\/en.wikipedia.org\/wiki\/Opengl_es\">OpenGL ES<\/a>, <a href=\"http:\/\/www.khronos.org\/webgl\/wiki\/Main_Page\">WebGL<\/a>, <a href=\"http:\/\/en.wikipedia.org\/wiki\/Directx\">DirectX<\/a>), \u0442\u043e \u0437\u0434\u0435\u0441\u044c \u0432\u0441\u0451 \u043f\u043e\u0445\u043e\u0436\u0435 \u2014 \u0448\u0435\u0439\u0434\u0435\u0440\u044b, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0432 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0445 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0442\u0430\u043a \u0436\u0435.<\/p>\n<h5>\u0422\u0438\u043f\u044b \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432<\/h5>\n<p>  \u0428\u0435\u0439\u0434\u0435\u0440\u044b, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0435 \u0432 CCSSF, \u0431\u044b\u0432\u0430\u044e\u0442 \u0434\u0432\u0443\u0445 \u0442\u0438\u043f\u043e\u0432: \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b (Vertex Shader)\u0438 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b (Fragment Shader)(\u0438\u0445 \u0435\u0449\u0435 \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442 \u043f\u0438\u043a\u0441\u0435\u043b\u044c\u043d\u044b\u0435).<br \/>  \u0412\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u0433\u043e\u0432\u043e\u0440\u044f\u0442, \u0433\u0434\u0435 \u0447\u0442\u043e \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f. \u041e\u043d\u0438 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u0434\u0432\u0438\u0433\u0430\u0442\u044c \u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0441\u0435\u0442\u043a\u0438 \u0432 3D \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435, \u0434\u0435\u0444\u043e\u0440\u043c\u0438\u0440\u0443\u044f \u0438 \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u0432\u043b\u044f\u044f \u043e\u0431\u044a\u0435\u043a\u0442\u044b.<br \/>  \u0424\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u0433\u043e\u0432\u043e\u0440\u044f\u0442 \u043a\u0430\u043a \u0432\u044b\u0433\u043b\u044f\u0434\u044f\u0442 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432. \u041e\u043d\u0438 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u043d\u0430 \u043e\u0431\u044a\u0435\u043a\u0442\u0430\u0445 \u0438\u043b\u0438 \u0438\u0437\u043c\u0435\u043d\u044f\u0442\u044c \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u043a \u0432\u043d\u0435\u0448\u043d\u043e\u0441\u0442\u0438 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432.<br \/>  \u0412 \u0446\u0435\u043b\u043e\u043c, \u0447\u0442\u043e\u0431\u044b \u0438\u043c\u0435\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0432\u0430\u043b\u0438\u0434\u043d\u0443\u044e GPU \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0443, \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u044b \u0438 \u0442\u0435, \u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b. \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u0434\u043b\u044f \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432 \u043d\u0443\u0436\u0435\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u0438\u0437 \u044d\u0442\u0438\u0445 \u0432\u0438\u0434\u043e\u0432, \u0430 \u0434\u043b\u044f \u043d\u0435\u0434\u043e\u0441\u0442\u0430\u044e\u0449\u0435\u0433\u043e \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 <a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#default-shaders\">default pass-through shader<\/a>.<\/p>\n<h4>\u041a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b?<\/h4>\n<p>  \u0421\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u044b \u043d\u044b\u043d\u0447\u0435 \u0441\u0430\u043c\u0438 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u044e\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f.<br \/>  HTML \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u043c\u0438 \u043a\u0430\u043a \u043a\u043e\u043b\u043b\u0435\u043a\u0446\u0438\u0438 \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 <a href=\"http:\/\/en.wikipedia.org\/wiki\/Document_Object_Model\">DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c<\/a>.<br \/>  \u0421 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u043c\u0438 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u043c\u0438 \u0432\u044b \u0446\u0435\u043f\u043b\u044f\u0435\u0442\u0435\u0441\u044c \u0437\u0430 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0439 \u0440\u0435\u043d\u0434\u0435\u0440\u043d\u044b\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u043e\u043d\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043a, \u043f\u043e\u043b\u0443\u0447\u0430\u044f \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043c\u0435\u043d\u044f\u0442\u044c \u0444\u043e\u0440\u043c\u0443 \u0438 \u0432\u0438\u0434 \u044d\u0442\u0438\u0445 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043e\u043d\u0438 \u043e\u0442\u0440\u0438\u0441\u0443\u044e\u0442\u0441\u044f \u043d\u0430 \u044d\u043a\u0440\u0430\u043d\u0435.<br \/>  \u042d\u0442\u043e \u043f\u043e\u0445\u043e\u0436\u0435 \u043d\u0430 \u0442\u043e, \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 <a href=\"http:\/\/www.w3.org\/TR\/2012\/WD-css3-transforms-20120911\/\">CSS 3D transforms<\/a>, \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u043c\u0435\u0441\u0442\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0438\u0433\u0440\u0430\u0442\u044c\u0441\u044f \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 \u0441 \u0443\u0436\u0435 \u0437\u0430\u0434\u0430\u043d\u043d\u044b\u043c \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u043e\u043c, \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u0441\u0432\u043e\u0439 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043a\u043e\u0434 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 DOM \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430.<\/p>\n<h5>\u041a\u043e\u043d\u0442\u0435\u043d\u0442\u043e\u0432\u0430\u044f \u0441\u0435\u0442\u043a\u0430<\/h5>\n<p>  \u041a\u0430\u0436\u0434\u044b\u0439 DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0441 CCSSF \u0431\u0443\u0434\u0435\u0442 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d \u0432 <a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#vertexMesh-attribute\">\u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0443\u044e \u0441\u0435\u0442\u043a\u0443 \u0441 \u043c\u043e\u0437\u0430\u0438\u043a\u043e\u0439, \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u043e\u0439 \u044e\u0437\u0435\u0440\u043e\u043c<\/a>:<br \/>  &lt;img sr\u0441=\u00ab<a href=\"http:\/\/cs317217.userapi.com\/v317217705\/37a5\/ghtCCVl9SeM.jpg\">cs317217.userapi.com\/v317217705\/37a5\/ghtCCVl9SeM.jpg<\/a>\u00bb alt=\u00abimage\u00bb\/&gt; <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b><\/p>\n<div class=\"spoiler_text\">\u041f\u0440\u0438\u043c. \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0447\u0438\u043a\u0430 \u2014 \u043d\u0435 \u043d\u0430\u0448\u0451\u043b \u0441\u043f\u043e\u0441\u043e\u0431 \u0432\u0441\u0442\u0430\u0432\u0438\u0442\u044c svg \u043e\u0431\u044a\u0435\u043a\u0442, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u0434\u0435\u043b\u0430\u043b \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442<\/div>\n<\/div>\n<p>  \u041f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u0441\u0435\u0442\u043a\u0430 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u0432\u0430 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430 (\u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0439 \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430).<br \/>  \u042d\u0442\u0430 \u0441\u0435\u0442\u043a\u0430 \u043f\u043e\u043b\u0443\u0447\u0438\u0442 \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0443, \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u0443\u044e \u0434\u043b\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 (\u0442\u043e, \u0447\u0442\u043e \u043e\u0431\u044b\u0447\u043d\u043e \u0438 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u044d\u043a\u0440\u0430\u043d\u0435), \u0430 \u043f\u043e\u0442\u043e\u043c \u043a \u043d\u0435\u0439 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0442\u0441\u044f \u0432\u0430\u0448\u0438 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b.<\/p>\n<h5>\u0421\u0432\u044f\u0437\u043d\u043e\u0441\u0442\u044c \u0441\u0435\u0442\u043e\u043a<\/h5>\n<p>  \u0421\u0435\u0442\u043a\u0430 \u0438\u0437 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u043d\u0430 \u0434\u0432\u0443\u043c\u044f \u043f\u0443\u0442\u044f\u043c\u0438 (\u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u0443\u0435\u043c\u044b\u043c\u0438 \u0438\u0437 CSS):  <\/p>\n<ol>\n<li>\u043f\u0440\u0438\u043a\u0440\u0435\u043f\u043b\u0451\u043d\u043d\u044b\u0435 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0438<\/li>\n<li>\u043e\u0442\u043a\u0440\u0435\u043f\u043b\u0451\u043d\u043d\u044b\u0435 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0438<\/li>\n<\/ol>\n<p>  \u0421\u0435\u0442\u043a\u0430 \u0441 <b>\u043f\u0440\u0438\u043a\u0440\u0435\u043f\u043b\u0451\u043d\u043d\u044b\u043c\u0438 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430\u043c\u0438<\/b> \u044d\u0442\u043e \u043e\u0434\u0438\u043d \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0451\u043d\u043d\u044b\u0439 \u043e\u0431\u044a\u0435\u043a\u0442, \u0433\u0434\u0435 \u0441\u043e\u0441\u0435\u0434\u043d\u0438\u0435 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0438 \u0438\u043c\u0435\u044e\u0442 \u043e\u0431\u0449\u0438\u0435 \u0432\u0435\u0440\u0448\u0438\u043d\u044b. \u0415\u0441\u043b\u0438 \u0432\u044b \u0441\u0434\u0432\u0438\u043d\u0435\u0442\u0435 \u0432\u0435\u0440\u0448\u0438\u043d\u0443, \u0432\u0441\u0435 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0435 \u0441 \u043d\u0435\u0439 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0438 \u0434\u0435\u0444\u043e\u0440\u043c\u0438\u0440\u0443\u044e\u0442\u0441\u044f (\u043a\u0430\u043a \u043b\u0438\u0441\u0442 \u0442\u043a\u0430\u043d\u0438). \u042d\u0442\u043e\u0442 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e.<br \/>  \u0421\u0435\u0442\u043a\u0430 \u0441 <b>\u043e\u0442\u043a\u0440\u0435\u043f\u043b\u0451\u043d\u043d\u044b\u043c\u0438 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430\u043c\u0438<\/b> \u0441\u043e\u0431\u0440\u0430\u043d\u0430 \u0438\u0437 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0430 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432. \u041a\u0430\u0436\u0434\u0430\u044f \u0432\u0435\u0440\u0448\u0438\u043d\u0430 \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u0438\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0443. \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c \u0441\u0435\u0442\u043a\u0443 \u043d\u0430 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b. \u0421\u0435\u0442\u043a\u0430 \u043c\u043e\u0436\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0434\u044b\u0440\u044b, \u0438\u043b\u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u0431\u044b\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043f\u0435\u0440\u0435\u043c\u043e\u0434\u0435\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u0430 \u0432 \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440.<br \/>  \u041c\u043e\u0437\u0430\u0438\u043a\u0430 \u0441\u0435\u0442\u043a\u0438 \u0438 \u0441\u0432\u044f\u0437\u043d\u043e\u0441\u0442\u044c \u0434\u043e\u043b\u0436\u043d\u044b \u043e\u0441\u0442\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u043e\u0434\u043d\u0438\u043c\u0438 \u0438 \u0442\u0435\u043c\u0438 \u0436\u0435 \u0432\u043e \u0432\u0441\u0435\u0445 CSS transitions.<\/p>\n<h5>\u0412\u0445\u043e\u0434\u043d\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432<\/h5>\n<p>  \u0412\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0435 \u0438 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043e\u0432\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u043c\u043e\u0433\u0443\u0442 \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0442\u044c \u043d\u0430 \u0432\u0445\u043e\u0434 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0442\u0440\u0451\u0445 \u0442\u0438\u043f\u043e\u0432:  <\/p>\n<ol>\n<li><i>\u0444\u043e\u0440\u043c\u044b<\/i> (uniforms)<\/li>\n<li><i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b<\/i> (attributes)<\/li>\n<li><i>\u043e\u0442\u043b\u0438\u0447\u0438\u044f<\/i> (varyings)<\/li>\n<\/ol>\n<p>  <b><i>\u0424\u043e\u0440\u043c\u044b<\/i><\/b> \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 \u0441 \u043e\u0434\u043d\u0438\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u0432\u0435\u0440\u0448\u0438\u043d \u0438 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u0441\u0435\u0442\u043a\u0438 (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0446\u0432\u0435\u0442 \u043e\u0431\u044a\u0435\u043a\u0442\u0430).<br \/>  <b><i>\u0410\u0442\u0440\u0438\u0431\u0443\u0442\u044b<\/i><\/b> \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0438\u043d\u0434\u0438\u0432\u0438\u0434\u0443\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 \u0432\u0435\u0440\u0448\u0438\u043d, \u043a\u0430\u0436\u0434\u0430\u044f \u0432\u0435\u0440\u0448\u0438\u043d\u0430 \u0441\u0435\u0442\u043a\u0438 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u0441\u0432\u043e\u0451 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430<\/i> (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043f\u043e\u0437\u0438\u0446\u0438\u044f \u0432\u0435\u0440\u0448\u0438\u043d\u044b). <br \/>  <b><i>\u041e\u0442\u043b\u0438\u0447\u0438\u044f<\/i><\/b> \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438, \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0435\u043c\u044b\u043c\u0438 \u0432\u0435\u0440\u0448\u0438\u043d\u0430\u043c\u0438 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u0430\u043c. \u041e\u043d\u0438 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430 \u0438 \u0438\u0445 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0434\u043b\u044f \u0442\u043e\u0447\u0435\u043a \u0432\u043d\u0443\u0442\u0440\u0438 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430 \u0438\u043d\u0442\u0435\u0440\u043f\u043e\u043b\u0438\u0440\u0443\u0435\u0442 GPU (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043e\u0441\u0432\u0435\u0449\u0435\u043d\u0438\u0435). <\/p>\n<p>  Filter Effects specification \u0442\u0430\u043a \u0436\u0435 \u0434\u043e\u043f\u0443\u0441\u043a\u0430\u044e\u0442 \u0434\u0440\u0443\u0433\u043e\u0439 \u0442\u0438\u043f \u0432\u0445\u043e\u0434\u043d\u044b\u0445 \u0434\u0430\u043d\u043d\u044b\u0445: <b>\u0442\u0435\u043a\u0441\u0442\u0443\u0440\u044b<\/b>. \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u043e\u043d\u0438 \u0435\u0449\u0435 \u043d\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b (\u0438 \u043f\u043e\u043f\u044b\u0442\u043a\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0438\u0445 \u0442\u0438\u0445\u043e \u0441\u043b\u043e\u043c\u0430\u044e\u0442 \u0448\u0435\u0439\u0434\u0435\u0440\u044b).<br \/>  \u0411\u0440\u0430\u0443\u0437\u0435\u0440\u044b \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0435 <b>\u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b<\/b>, \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0435 \u0438 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0434\u043b\u044f \u0432\u0441\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u043a \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b.  <\/p>\n<pre><code class=\"css\">attribute vec4 a_position; attribute vec2 a_texCoord; attribute vec2 a_meshCoord; attribute vec3 a_triangleCoord;<\/code><\/pre>\n<p>  \u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b<\/i> \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0442 \u0438\u0434\u0435\u043d\u0442\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0438 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0438 \u0432 \u0441\u0435\u0442\u043a\u0435.  <\/p>\n<pre><code class=\"css\"> uniform mat4 u_projectionMatrix; uniform vec2 u_textureSize; uniform vec4 u_meshBox; uniform vec2 u_tileSize; uniform vec2 u_meshSize;<\/code><\/pre>\n<p>  \u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 <i>\u0444\u043e\u0440\u043c\u044b<\/i> \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043f\u0440\u043e \u0434\u0430\u043d\u043d\u044b\u0435 DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u043e\u0431\u0449\u0438\u0435 \u0434\u043b\u044f \u0432\u0441\u0435\u0439 \u0441\u0435\u0442\u043a\u0438.  <\/p>\n<pre><code class=\"css\">varying vec2 v_texCoord;<\/code><\/pre>\n<p>  \u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 <i>\u043e\u0442\u043b\u0438\u0447\u0438\u044f<\/i> \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u044b \u0432 \u0441\u043b\u0443\u0447\u0430\u0435, \u0435\u0441\u043b\u0438 \u044d\u0444\u0444\u0435\u043a\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0434\u0435\u0444\u043e\u043b\u0442\u043d\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b.<br \/>  \u0422\u043e\u0447\u043d\u044b\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u044d\u0442\u0438\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0432 \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 Filter Effects (<a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#vertex-attribute-variables\">\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b<\/a>, <a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#shader-uniform-variables\">\u0444\u043e\u0440\u043c\u044b<\/a>, <a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#varyings\">\u043e\u0442\u043b\u0438\u0447\u0438\u044f<\/a>).<\/p>\n<p>  <b>\u041f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435<\/b>: \u043d\u0430 \u0434\u0430\u043d\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442, \u043d\u0435 \u0432\u0441\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0438\u0437 \u044d\u0442\u043e\u0439 \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b.<\/p>\n<p>  \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u044e\u0442 <i>\u0444\u043e\u0440\u043c\u044b<\/i> <b>u_textureSize<\/b> \u0438 <b>u_meshSize<\/b>. \u0412\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0440\u0435\u0448\u0438\u0442\u044c \u044d\u0442\u0443 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443, \u0441\u0430\u043c\u043e\u043b\u0438\u0447\u043d\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0432 \u0438\u0445 \u0432 CSS.<br \/>  \u0422\u0430\u043a \u0436\u0435, <i>\u043e\u0442\u043b\u0438\u0447\u0438\u0435<\/i> <b>v_texCoord<\/b> \u043f\u043e\u043a\u0430 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u0430\u043c \u043d\u0430\u0434\u043e \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u0432\u043e\u0451 <i>\u043e\u0442\u043b\u0438\u0447\u0438\u0435<\/i> \u0434\u043b\u044f \u043f\u0435\u0440\u0435\u0434\u0430\u0447\u0438 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u044b \u0438\u0437 <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430<\/i> <b>a_texCoord<\/b> \u0432 \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440.<br \/>  \u0421\u043b\u0435\u0434\u0438\u0442\u044c \u0437\u0430 \u043f\u0440\u043e\u0433\u0440\u0435\u0441\u0441\u043e\u043c \u0432\u043d\u0435\u0434\u0440\u0435\u043d\u0438\u044f \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432 \u043c\u043e\u0436\u043d\u043e \u0432 \u044d\u0442\u043e\u043c \u0438\u0437\u0434\u0430\u043d\u0438\u0438 <a href=\"https:\/\/bugs.webkit.org\/show_bug.cgi?id=71392\">WebKit \u00abmaster\u00bb issue<\/a>.<br \/>  \u0412 \u0434\u043e\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043a \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c \u0432\u044b \u0442\u0430\u043a \u0436\u0435 \u043c\u043e\u0436\u0435\u0442\u0435 \u043e\u043f\u0438\u0441\u0430\u0442\u044c \u0441\u0432\u043e\u0438 <i>\u0444\u043e\u0440\u043c\u044b<\/i> \u0434\u043b\u044f \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0447\u0435\u0440\u0435\u0437 <a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#other-uniform-variables-the-css-shaders-\">CSS \u0441\u0442\u0438\u043b\u0438<\/a>. <\/p>\n<pre><code class=\"css\"> .shaded {   -webkit-filter: custom(url(distort.vs) mix(url(tint.fs) normal source-atop),                           distortAmount 0.5, lightVector 1.0 1.0 0.0); }  <\/code><\/pre>\n<pre><code class=\"css\">\/\/ \u0428\u0435\u0439\u0434\u0435\u0440 (\u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0439 \u0438\u043b\u0438 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043e\u0432\u044b\u0439)  ...  uniform float distortAmount; uniform vec3 lightVector; ...<\/code><\/pre>\n<p>  \u0412\u0441\u0451 \u044d\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0432\u0430\u043c \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u0438\u0437\u0432\u043d\u0435. \u0412 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438, \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0434\u043b\u044f <i>\u0444\u043e\u0440\u043c<\/i>, \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0435 \u0432 CSS \u0431\u0443\u0434\u0443\u0442 \u0438\u043d\u0442\u0435\u0440\u043f\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u044b \u043f\u0440\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 <a href=\"http:\/\/www.w3.org\/TR\/css3-transitions\/\">CSS transitions<\/a>.<br \/>  <b>\u041f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435<\/b>: \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0445 \u0441\u043b\u043e\u0442\u043e\u0432 \u043f\u043e\u0434 <i>\u0444\u043e\u0440\u043c\u044b<\/i> \u0438 <i>\u043e\u0442\u043b\u0438\u0447\u0438\u044f \u043e\u0440\u0433\u0430\u043d\u0438\u0447\u0435\u043d\u043e \u0438 \u0437\u0430\u0432\u0438\u0441\u0438\u0442 \u043e\u0442 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u0445 GPU (\u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u0438 \u043a <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430\u043c<\/i>, \u043d\u043e \u0434\u043b\u044f CSS \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432 \u0438\u0445 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f).<\/p>\n<p>  <a href=\"http:\/\/alteredqualia.com\/tmp\/webgl-maxparams-test\/\">\u0417\u0434\u0435\u0441\u044c<\/a> \u043c\u043e\u0436\u043d\u043e \u0443\u0432\u0438\u0434\u0435\u0442\u044c, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e \u043d\u0430 \u0432\u0430\u0448\u0435\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0434\u043b\u044f WebGL (\u0443\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u0435 \u0447\u0438\u0441\u043b\u0430 \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u044b\u043c\u0438 \u0434\u043b\u044f CCSSF; \u0447\u0430\u0441\u0442\u044c \u0441\u043b\u043e\u0442\u043e\u0432 \u0437\u0430\u043a\u0440\u0435\u043f\u043b\u0435\u043d\u0430 \u0437\u0430 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u043c\u0438 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438). <\/p>\n<h4>\u041a\u0430\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u043d\u0430 \u043c\u043e\u0451\u043c \u0441\u0430\u0439\u0442\u0435?<\/h4>\n<p>  CCSSF \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u0442\u0430\u043a \u0436\u0435, \u043a\u0430\u043a \u0438 \u043f\u0440\u043e\u0447\u0438\u0435 CSS \u0441\u0442\u0438\u043b\u0438, \u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e\u043c <b>style<\/b>. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u044d\u0442\u043e \u0442\u0430\u043a:  <\/p>\n<pre><code class=\"html\">&lt;style&gt; .shader {     -webkit-filter:         custom(url(shaders\/crumple.vs) mix(url(shaders\/crumple.fs) normal source-atop),         50 50, amount 0, strength 0.2, lightIntensity 1.05); } &lt;\/style&gt;<\/code><\/pre>\n<p>  \u0418\u043b\u0438 \u0442\u0430\u043a, \u0435\u0441\u043b\u0438 \u0432\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043e\u0432\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440:  <\/p>\n<pre><code class=\"html\">&lt;style&gt; .shader {     -webkit-filter:         custom(none mix(url(shaders\/tint.fs) normal source-atop), amount 0); } &lt;\/style&gt;<\/code><\/pre>\n<p>  \u0410\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <b>none<\/b> \u0437\u0430\u043c\u0435\u0441\u0442\u043e \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u043e\u0433\u043e \u0448\u0435\u0439\u0434\u0435\u0440\u0430 \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f (\u043f\u043e\u043a\u0430). \u0412 \u0442\u0430\u043a\u043e\u0439 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u0435\u043c \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u043f\u0443\u0441\u0442\u043e\u0433\u043e \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u043e\u0433\u043e \u0448\u0435\u0439\u0434\u0435\u0440\u0430.<br \/>  \u0412\u044b \u0434\u0430\u0451\u0442\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0443 \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438 GLSL \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432 \u0438 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0435 \u0438\u0445 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0447\u0435\u0440\u0435\u0437 CSS \u0441\u0442\u0438\u043b\u0438. \u0411\u0440\u0430\u0443\u0437\u0435\u0440 \u043f\u043e\u0437\u0430\u0431\u043e\u0442\u0438\u0442\u0441\u044f \u043e \u0442\u043e\u043c, \u0447\u0442\u043e\u0431\u044b \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u0432 \u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a\u0438 \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0438\u0445 \u043a HTML \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0443.<\/p>\n<p>  \u041a\u043e\u0433\u0434\u0430 \u0443 \u0432\u0430\u0441 \u0443\u0436\u0435 \u0435\u0441\u0442\u044c \u0448\u0435\u0439\u0434\u0435\u0440\u044b, \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0438\u0445 \u043a HTML \u043b\u0435\u0433\u043a\u043e \u2014 \u0432\u044b \u043f\u0440\u043e\u0441\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442\u0435 \u0441 \u043d\u0438\u043c\u0438, \u043a\u0430\u043a \u0441 \u043e\u0431\u044b\u0447\u043d\u044b\u043c\u0438 CSS \u0441\u0442\u0438\u043b\u044f\u043c\u0438.  <\/p>\n<pre><code class=\"css\">&lt;div class=&quot;shader&quot;&gt;<\/code><\/pre>\n<p>  \u041c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <a href=\"http:\/\/www.w3.org\/TR\/css3-transitions\/\">CSS transitions<\/a> \u0441 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u043c\u0438 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u043c\u0438, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0447\u0442\u043e\u0431\u044b \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u0438 \u043c\u0435\u043d\u044f\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442 \u043f\u0440\u0438 \u043d\u0430\u0432\u0435\u0434\u0435\u043d\u0438\u0438\u0438 \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b.   <\/p>\n<pre><code class=\"css\">-webkit-transition: -webkit-filter ease-in-out 1s;<\/code><\/pre>\n<p>  CCSSF \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0431\u0443\u0434\u0443\u0442 \u0438\u043d\u0442\u0435\u0440\u043f\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u0430\u043a \u0436\u0435, \u043a\u0430\u043a \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 CSS \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430.<\/p>\n<p>  <a name=\"compatibility\"><\/a><\/p>\n<h4>\u041a\u0430\u043a \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0438\u0435 CCSSF?<\/h4>\n<p>  <b>\u041f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435<\/b>: \u044d\u0442\u0430 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u044f \u043e\u0447\u0435\u043d\u044c \u043d\u043e\u0432\u0430\u044f \u0438 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0433\u0440\u0443\u0431\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430. \u0414\u0435\u0442\u0430\u043b\u0438 \u043c\u043e\u0433\u0443\u0442 \u043c\u0435\u043d\u044f\u0442\u044c\u0441\u044f, \u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u0444\u0438\u0447\u0438 \u043c\u043e\u0433\u0443\u0442 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c, \u0430 \u0432 \u0438\u043c\u043f\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0431\u0430\u0433\u0438.<\/p>\n<p>  \u042d\u0442\u043e\u0442 \u043f\u043e\u0441\u0442 \u043e\u0442\u0440\u0430\u0436\u0430\u0435\u0442 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0434\u0435\u043b \u043d\u0430 \u0441\u0435\u043d\u0442\u044f\u0431\u0440\u044c 2012 \u0433\u043e\u0434\u0430. \u0415\u0441\u043b\u0438 \u0441 \u0442\u0435\u0445 \u043f\u043e\u0440 \u0447\u0442\u043e-\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0435 \u0442\u0430\u043a, \u043a\u0430\u043a \u043e\u043f\u0438\u0441\u0430\u043d\u043e, \u043f\u043e\u043b\u0435\u0437\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u0433\u0443\u0433\u043b\u0438\u0442\u044c, \u0447\u0442\u043e\u0431\u044b \u0431\u044b\u0442\u044c \u0432 \u043a\u0443\u0440\u0441\u0435 \u0442\u043e\u0447\u043d\u044b\u043e\u0433\u043e \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0441\u0430 \u0438 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u044f.<br \/>  \u041d\u0430 \u0434\u0430\u043d\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442, \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0432 \u0442\u0435\u043a\u0443\u0449\u0435\u043c \u0431\u0438\u043b\u0434\u0435 Chrome Canary (\u0442\u043e\u0447\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0438\u044f \u043d\u0430 \u043c\u043e\u043c\u0435\u043d\u0442 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0437\u0430\u043f\u0438\u0441\u0438 \u2014 24.0.1278.0).<br \/>  \u0421\u043a\u0430\u0447\u0430\u0442\u044c Chrome Canary \u043c\u043e\u0436\u043d\u043e \u0437\u0434\u0435\u0441\u044c: <br \/>  <a href=\"https:\/\/tools.google.com\/dlpage\/chromesxs\"><img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/chrome-canary.png\" alt=\"image\"\/><\/a><br \/>  <a href=\"https:\/\/tools.google.com\/dlpage\/chromesxs\">tools.google.com\/dlpage\/chromesxs<\/a><\/p>\n<p>  CCSSF \u0434\u043e\u043b\u0436\u043d\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0432 Windows \u0438 OSX (\u042f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e Windows 7).<\/p>\n<p>  \u0414\u0430\u0436\u0435 \u0435\u0441\u043b\u0438 \u0432\u0430\u0448\u0430 \u041e\u0421 \u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u044e\u0442 \u0438\u0445, \u0432\u0441\u0451 \u043c\u043e\u0436\u0435\u0442 \u0443\u043f\u0435\u0440\u0435\u0442\u044c\u0441\u044f \u0432 \u0441\u0442\u0430\u0440\u044b\u0439 \u0438\u043b\u0438 \u0441\u043b\u0430\u0431\u044b\u0439 GPU \u0438\u043b\u0438 \u0432 \u043d\u0435\u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 \u043a \u043d\u0435\u043c\u0443 \u0434\u0440\u0430\u0439\u0432\u0435\u0440\u0430 (\u0421\u0438\u0441\u0442\u0435\u043c\u043d\u044b\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0440\u0430\u0432\u043d\u044b \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u044b\u043c \u0437\u0434\u0435\u0441\u044c \u2014 <a href=\"http:\/\/get.webgl.org\/\">WebGL compatibility check<\/a>)<br \/>  \u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u043d\u0435 \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u044b \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 Chrome \u043d\u0430\u0434\u043e \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u0438\u0437 \u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u0441 \u0442\u0430\u043a\u0438\u043c \u043a\u043b\u044e\u0447\u043e\u043c:  <\/p>\n<pre><code class=\"css\">chrome --enable-css-shaders<\/code><\/pre>\n<p>  \u041f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044b\u0435 CSS \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u0432 Chrome \u043d\u0430 Windows \u2014 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u044f\u0440\u043b\u044b\u043a \u043d\u0430 Chrome Canary \u0438 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <b>&#8212;enable-css-shaders<\/b> \u0432 \u043f\u043e\u043b\u0435 \u00abtarget\u00bb. <br \/>  \u0410\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u0430 \u2014 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0431\u0430\u0442\u043d\u0438\u043a \u0441 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0439 \u0432\u044b\u0448\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439.<\/p>\n<p>  \u0412 \u043d\u043e\u0432\u044b\u0445 \u0432\u0435\u0440\u0441\u0438\u044f\u0445 Chrome Canary \u0432 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0435 \u0435\u0441\u0442\u044c \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u0444\u043b\u0430\u0433, \u0432 \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u043e\u0439 \u0432\u043a\u043b\u0430\u0434\u043a\u0435 \u00ab\u0444\u043b\u0430\u0433\u0438\u00bb (\u0418\u0441\u043a\u0430\u0442\u044c \u00abEnable CSS Shaders\u00bb):  <\/p>\n<pre><code class=\"bash\">chrome:\/\/flags\/ <\/code><\/pre>\n<h4>\u041a\u0430\u043a \u0443\u0431\u0435\u0434\u0438\u0442\u044c\u0441\u044f, \u0447\u0442\u043e CCSSF \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442?<\/h4>\n<p>  \u0421\u043c\u043e\u0442\u0440\u0438\u0442\u0435 <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere.html\">\u044d\u0442\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440<\/a>.<\/p>\n<p>  \u0415\u0441\u043b\u0438 \u0432\u044b \u0432\u0438\u0434\u0438\u0442\u0435 \u0441\u0444\u0435\u0440\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u043f\u043b\u0430\u043d\u0435\u0442\u044b, \u043f\u043e\u0437\u0434\u0440\u0430\u0432\u043b\u044f\u044e, \u043e\u043d\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 ;).<\/p>\n<p>  <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere.html\"><img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/img_sphere_ok.jpg\" alt=\"image\"\/><\/a><\/p>\n<p>  \u0415\u0441\u043b\u0438 \u0432\u044b \u0432\u0438\u0434\u0438\u0442\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u044b\u0435 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438, \u0437\u043d\u0430\u0447\u0438\u0442, \u0447\u0442\u043e-\u0442\u043e \u043f\u043e\u0448\u043b\u043e \u043d\u0435 \u0442\u0430\u043a ;S.<br \/>  <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere.html\"><img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/img_sphere_fail.jpg\" alt=\"image\"\/><\/a><\/p>\n<p>  \u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435, \u0447\u0442\u043e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u0437 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u043d\u0430\u0439\u0434\u0435\u043d\u044b \u0440\u0430\u043d\u0434\u043e\u043c\u043d\u043e \u0432 \u0438\u043d\u0442\u0435\u0440\u043d\u0435\u0442\u0435 \u0438 \u043c\u043e\u0433\u0443\u0442 \u0441\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0435\u043c \u0441\u043b\u043e\u043c\u0430\u0442\u044c\u0441\u044f. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u044d\u0444\u0444\u0435\u043a\u0442\u044b, \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0449\u0438\u0435 \u0432 \u0440\u0430\u043d\u043d\u0438\u0445 <a href=\"https:\/\/github.com\/adobe\/webkit\/downloads\">\u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 \u0431\u0438\u043b\u0434\u0430\u0445 Chromium \u043e\u0442 \u041c\u0430\u044f 2012 \u0433\u043e\u0434\u0430<\/a>, \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0432 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0445 Chrome Canary.<br \/>  <b>\u041f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435<\/b>: \u0441\u0435\u0439\u0447\u0430\u0441 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043f\u043e\u0447\u0435\u043c\u0443-\u0442\u043e \u043d\u0435 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u0430\u044f. \u041c\u043e\u0436\u0435\u0442 \u0441\u043b\u0443\u0447\u0438\u0442\u044c\u0441\u044f \u0442\u0430\u043a, \u0447\u0442\u043e \u0432 \u043e\u0434\u0438\u043d \u043c\u043e\u043c\u0435\u043d\u0442 CCSSF \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442, \u0430 \u0432 \u0434\u0440\u0443\u0433\u043e\u0439 \u2014 \u0443\u0436\u0435 \u043b\u043e\u043c\u0430\u044e\u0442\u0441\u044f, \u0434\u0430\u0436\u0435 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u0435\u0440\u0435\u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u0438\u043b\u0438 \u0446\u0438\u043a\u043b\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f transitions \u043d\u0430 \u043e\u0434\u043d\u043e\u0439 \u0438 \u0442\u043e\u0439 \u0436\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435.<\/p>\n<p>  \u0412 \u0442\u0430\u043a\u0438\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445:  <\/p>\n<ol>\n<li>\u043f\u0435\u0440\u0435\u0437\u0430\u0433\u0440\u0443\u0437\u0438\u0442\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443<\/li>\n<li>\u0437\u0430\u043a\u0440\u043e\u0439\u0442\u0435 \u0442\u0430\u0431 \u0438 \u043e\u0442\u043a\u0440\u043e\u0439\u0442\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0432 \u043d\u043e\u0432\u043e\u043c \u0442\u0430\u0431\u0435<\/li>\n<li>\u043f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u0435 \u0431\u0440\u0430\u0443\u0437\u0435\u0440<\/li>\n<\/ol>\n<p>  \u0428\u0435\u0439\u0434\u0435\u0440\u044b, \u0441\u043b\u043e\u043c\u0430\u0432\u0448\u0438\u0435\u0441\u044f \u0432 \u043e\u0434\u043d\u043e\u043c \u0442\u0430\u0431\u0435, \u043c\u043e\u0433\u0443\u0442 \u0443\u0431\u0438\u0442\u044c \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u0432\u043e \u0432\u0441\u0435\u0445 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0442\u0430\u0431\u0430\u0445 (\u0438 \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u0431\u0443\u0434\u0443\u0442 \u043e\u0441\u0442\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u0441\u043b\u043e\u043c\u0430\u043d\u043d\u044b\u043c\u0438, \u0434\u0430\u0436\u0435 \u0435\u0441\u043b\u0438 \u043f\u0435\u0440\u0435\u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0442\u044c \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b).<\/p>\n<p>  \u0412\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u0435\u0440\u0432\u043e\u0439 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u043c\u043e\u0433\u0443\u0442 \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0438 \u043d\u0430 \u0447\u0430\u0441\u0442\u0438\u0447\u043d\u043e \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0435\u043d\u043d\u044b\u0435 DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b. \u0412 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0437\u0430\u043a\u0440\u043e\u0439\u0442\u0435 \u0442\u0430\u0431 \u0438 \u043e\u0442\u043a\u0440\u043e\u0439\u0442\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0441\u043d\u043e\u0432\u0430, reload \u043d\u0435 \u043f\u043e\u043c\u043e\u0436\u0435\u0442.<\/p>\n<p>  <a name=\"limitations\"><\/a>  <\/p>\n<h4>\u041e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 \u0444\u0438\u043b\u044c\u0442\u0440\u043e\u0432<\/h4>\n<p>  <\/p>\n<h5>\u0414\u043e\u0441\u0442\u0443\u043f \u043a \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0443<\/h5>\n<p>  \u0428\u0435\u0439\u0434\u0435\u0440\u044b, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0435 \u0432 CCSSF <b> \u043d\u0438\u043a\u0430\u043a \u043d\u0435 \u043c\u043e\u0433\u0443\u0442 \u0447\u0438\u0442\u0430\u0442\u044c \u043f\u0438\u043a\u0441\u0435\u043b\u0438 \u0442\u0435\u043a\u0441\u0442\u0443\u0440 DOM \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430<\/b> \u0438 \u0435\u0449\u0435 \u043e\u043d\u0438 <b>\u043d\u0435 \u043c\u043e\u0433\u0443\u0442 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u043f\u0438\u043a\u0441\u0435\u043b\u0438 \u043d\u0430 \u044d\u043a\u0440\u0430\u043d\u0435<\/b>.<br \/>  \u042d\u0442\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u043f\u043e\u044f\u0432\u0438\u043b\u0438\u0441\u044c \u043a\u0430\u043a \u0440\u0435\u0430\u043a\u0446\u0438\u044f \u043d\u0430 <a href=\"http:\/\/en.wikipedia.org\/wiki\/Timing_attack\">timing attacks<\/a>, \u043a\u043e\u0433\u0434\u0430 \u0440\u0430\u0437\u0431\u043e\u0439\u043d\u0438\u0447\u0438\u0439 3rd party shader, \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0439 \u0432 \u0441\u0430\u0439\u0442, \u043c\u043e\u0433 \u0431\u044b\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d \u0434\u043b\u044f \u0441\u0447\u0438\u0442\u044b\u0432\u0430\u043d\u0438\u044f \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430 \u0441\u0430\u0439\u0442\u0430 (\u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430 \u0446\u0432\u0435\u0442\u0430 \u043f\u0438\u043a\u0441\u0435\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u043b\u0441\u044f \u0440\u0430\u0437\u043d\u044b\u0439 \u043a\u043e\u0434 \u0448\u0435\u0439\u0434\u0435\u0440\u0430).<br \/>  \u0415\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431, \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u043e\u0432\u0430\u0442\u044c \u0441 \u043f\u0438\u043a\u0441\u0435\u043b\u044f\u043c\u0438 DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u2014 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043a \u0432\u0430\u0448\u0438\u043c \u043f\u043e\u0434\u0441\u0447\u0438\u0442\u0430\u043d\u043d\u044b\u043c \u0446\u0432\u0435\u0442\u0430\u043c \u043e\u0442 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u044b\u0445, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0445 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432 <a href=\"https:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#feColorMatrixElement\">css_ColorMatrix<\/a>, <a href=\"https:\/\/dvcs.w3.org\/hg\/FXTF\/rawfile\/tip\/compositing\/index.html\">css_MixColor<\/a><br \/>  <img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/mix-fragment-shader.png\" alt=\"image\"\/><\/p>\n<p>  <b>\u041f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435<\/b>: \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0433\u043e\u0432\u043e\u0440\u0438\u0442, \u0447\u0442\u043e \u0432\u044b \u0442\u0430\u043a \u0436\u0435 \u043c\u043e\u0436\u0435\u0442\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <b>gl_FragColor<\/b> \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 \u0441\u043f\u043b\u043e\u0448\u043d\u044b\u0445 \u0446\u0432\u0435\u0442\u043e\u0432.<br \/>  \u041f\u043e\u043a\u0430 \u0447\u0442\u043e \u044d\u0442\u043e \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442.<br \/>  WebGL \u0440\u0435\u0448\u0430\u0435\u0442 \u044d\u0442\u0443 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 \u0434\u0440\u0443\u0433\u0438\u043c \u043f\u0443\u0442\u0451\u043c, \u0447\u0435\u0440\u0435\u0437 <a href=\"http:\/\/www.khronos.org\/registry\/webgl\/specs\/latest\/#4.2\">\u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432 \u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u043a \u00ab\u0447\u0438\u0441\u0442\u043e\u043c\u0443\u00bb \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0443<\/a> (\u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u043c\u0443 \u043d\u0430 \u0442\u043e\u043c \u0436\u0435 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 \u0438\u043b\u0438 \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u0440\u0430\u0437\u0440\u0435\u0448\u0451\u043d\u043d\u043e\u043c\u0443 \u043f\u043e <a href=\"http:\/\/en.wikipedia.org\/wiki\/Cross-Origin_Resource_Sharing\">cross-domain access<\/a> \u0434\u043b\u044f 3rd party \u0441\u0435\u0440\u0432\u0435\u0440\u043e\u0432).<\/p>\n<p>  \u041e\u0442\u0440\u0438\u0446\u0430\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u043e\u0440\u043e\u043d\u0430 \u0448\u0435\u0439\u0434\u0435\u0440\u043d\u043e\u0433\u043e \u043f\u043e\u0434\u0445\u043e\u0434\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d \u043d\u0435 \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c \u0441 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e\u043c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0445 \u0432\u0438\u0434\u043e\u0432 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439, \u0430 \u043f\u043e\u043b\u043e\u0436\u0438\u0442\u0435\u043b\u044c\u043d\u0430\u044f \u2014 \u0447\u0442\u043e CSS \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0442\u044c \u043a \u043b\u044e\u0431\u043e\u043c \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0443.<\/p>\n<h5>\u0420\u0430\u0437\u043c\u0435\u0440 \u0441\u0435\u0442\u043a\u0438<\/h5>\n<p>  \u0415\u0449\u0435 \u043e\u0434\u043d\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435, \u043f\u043e \u043a\u0440\u0430\u0439\u043d\u0435\u0439 \u043c\u0435\u0440\u0435, \u0432 \u0442\u0435\u043a\u0443\u0449\u0435\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0435\u0441\u0442\u044c \u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432 \u043d\u0430 \u043e\u0434\u043d\u0443 \u043c\u043e\u0437\u0430\u0438\u0447\u043d\u0443\u044e \u0441\u0435\u0442\u043a\u0443.<br \/>  \u0423 \u0432\u0430\u0441 \u043d\u0435 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0441\u0435\u0442\u043a\u0438 \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c \u043d\u0430 20.000 \u0441 \u043b\u0438\u0448\u043d\u0438\u043c \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u0440\u0435\u043a\u043e\u043c\u043c\u0435\u043d\u0434\u0443\u0435\u0442\u0441\u044f \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u0442\u044c, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0438\u043d\u0434\u0435\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0438, \u0441 16-\u0431\u0438\u0442\u043d\u044b\u043c\u0438 \u043d\u043e\u043c\u0435\u0440\u0430\u043c\u0438, \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044f \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0432\u0435\u0440\u0448\u0438\u043d \u0447\u0438\u0441\u043b\u043e\u043c 65.536.<\/p>\n<h4>\u041a\u0430\u043a \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435 CSS \u044d\u0444\u0444\u0435\u043a\u0442\u044b?<\/h4>\n<p>  \u0412\u0441\u0451, \u0447\u0442\u043e \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u2014 \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u0438 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u0439 \u0440\u0435\u0434\u0430\u043a\u0442\u043e\u0440. \u0428\u0435\u0439\u0434\u0435\u0440\u044b, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0432\u0430\u043d\u043d\u044b\u0435 \u0432 CCSSF \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043e\u0431\u044b\u0447\u043d\u044b\u043c\u0438 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u044b\u043c\u0438 \u0444\u0430\u0439\u043b\u0430\u043c\u0438.<\/p>\n<p>  \u0412\u043e\u0440\u043a\u0444\u043b\u043e\u0443 \u0442\u0430\u043a\u043e\u0439 \u0436\u0435, \u043a\u0430\u043a \u043f\u0440\u0438 \u0432\u0451\u0440\u0441\u0442\u043a\u0435 HTML + CSS: \u0434\u0435\u043b\u0430\u0435\u0442\u0435 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f, \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0443 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0435 \u0438 \u0441\u043c\u043e\u0442\u0440\u0438\u0442\u0435, \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c \u0438\u043b\u0438 \u043d\u0435\u0442.<br \/>  \u0415\u0441\u0442\u044c \u0442\u0443\u043b\u0437\u0430 \u043e\u0442 Adobe, \u043d\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <a href=\"http:\/\/html.adobe.com\/webstandards\/csscustomfilters\/cssfilterlab\/\">CSS FilterLab<\/a>, \u043e\u043d\u0430 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043f\u0440\u043e\u0449\u0435 \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432.<\/p>\n<p>  <b>\u041f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435<\/b>: \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u0448\u0435\u0439\u0434\u0435\u0440\u0430 \u0432 \u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0430\u044f \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f. \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u043c\u043d\u043e\u0433\u043e \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432, \u043e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442 \u0437\u0430\u043c\u0435\u0442\u043d\u043e \u0437\u0430\u043c\u0435\u0434\u043b\u0438\u0442\u044c \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0443 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b.<\/p>\n<p>  \u0414\u043b\u044f WebGL \u0432 Chrome \u0431\u044b\u043b\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043e <a href=\"http:\/\/code.google.com\/p\/chromium\/issues\/detail?id=88572\">\u043a\u044d\u0448\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0443\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u0431\u0438\u043d\u0430\u0440\u043d\u0438\u043a\u043e\u0432 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432<\/a>, \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u043c\u043e\u0447\u044c.<\/p>\n<h4>\u041a\u0430\u043a \u0432\u044b\u0433\u043b\u044f\u0434\u044f\u0442 \u0448\u0435\u0439\u0434\u0435\u0440\u044b, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0435 \u0432 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0445?<\/h4>\n<p>  \u041f\u0440\u043e\u0441\u0442\u043e\u0439 <b>\u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440<\/b> \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043f\u043e\u0445\u043e\u0436\u0438\u043c \u043d\u0430 \u044d\u0442\u043e:   <\/p>\n<pre><code class=\"css\">precision mediump float;  attribute vec4 a_position; uniform mat4 u_projectionMatrix;  void main() {      gl_Position = u_projectionMatrix * a_position;  }<\/code><\/pre>\n<p>  \u041f\u0440\u043e\u0441\u0442\u043e\u0439 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440 \u043f\u043e\u0445\u043e\u0436 \u043d\u0430 \u044d\u0442\u043e:   <\/p>\n<pre><code class=\"css\">precision mediump float;  void main() {      float r = 1.0;     float g = 1.0;     float b = 1.0;     float a = 1.0;      css_ColorMatrix = mat4( r, 0.0, 0.0, 0.0, \t\t\t0.0, g, 0.0, 0.0, \t\t\t0.0, 0.0, b, 0.0, \t\t\t0.0, 0.0, 0.0, a ); }<\/code><\/pre>\n<p>  \u0417\u0430\u043f\u0438\u0441\u044c precision <a href=\"http:\/\/www.opengl.org\/wiki\/GLSL_Type_Qualifiers#Precision_qualifiers\">\u043d\u0435 \u0438\u043c\u0435\u0435\u0442 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u043d\u0430 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u043d\u043e\u043c OpenGL<\/a>, \u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430\u0445, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0438\u0445 OpenGL ES. \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u043e\u043d\u0438 \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0443\u043a\u0430\u0437\u0430\u043d\u044b, \u0447\u0442\u043e\u0431\u044b \u0442\u0435\u043a\u0443\u0449\u0430\u044f \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u0430.<br \/>  \u041a HTML \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0443 \u0448\u0435\u0439\u0434\u0435\u0440\u044b \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u0442\u0430\u043a:  <\/p>\n<pre><code class=\"html\">&lt;style&gt; .shader {     -webkit-filter: custom(url(simple.vs) mix(url(simple.fs) normal source-atop), 1 1) } &lt;\/style&gt;  &lt;body&gt;     &lt;div class=&quot;shader&quot;&gt; Hello world! &lt;\/div&gt; &lt;body&gt;<\/code><\/pre>\n<p>  \u042d\u0442\u043e \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 CSS \u0441\u0442\u0438\u043b\u044c, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0438\u0439 \u0438 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0439 \u0438 \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440\u044b, \u043f\u0440\u0438\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0435 \u043d\u0430 \u0441\u0435\u0442\u043a\u0443 \u0441 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043c\u043e\u0437\u0430\u0438\u043a\u043e\u0439 \u0441 \u0434\u0432\u0443\u043c\u044f \u043f\u0440\u0438\u043a\u0440\u0435\u043f\u043b\u0451\u043d\u043d\u044b\u043c\u0438 \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430\u043c\u0438 (1 \u0441\u0442\u043e\u043b\u0431\u0435\u0446 x 1 \u0440\u044f\u0434).<\/p>\n<h4>\u041a\u0430\u043a \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442?<\/h4>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c \u043a\u0430\u043a \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0443\u043f\u0440\u043e\u0449\u0451\u043d\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e \u0441\u0444\u0435\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430, \u043f\u043e\u0445\u043e\u0436\u0443\u044e \u043d\u0430 <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere.html\">\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u043d\u0443\u044e \u0437\u0434\u0435\u0441\u044c<\/a>.<br \/>  \u041c\u044b \u043d\u0430\u0447\u043d\u0451\u043c \u0441 \u0440\u043e\u0432\u043d\u043e\u0439 \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u044b \u0441 DOM \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043e\u043c (\u043b\u0435\u0432\u0430\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430). \u041c\u044b \u0445\u043e\u0442\u0438\u043c \u043e\u0431\u0435\u0440\u043d\u0443\u0442\u044c \u0435\u0451 \u0432 \u0441\u0444\u0435\u0440\u0443 \u0438 \u043f\u0440\u0438\u043b\u043e\u0436\u0438\u0442\u044c \u0442\u0435\u043d\u0438, \u043a\u0430\u043a \u0435\u0441\u043b\u0438 \u0431\u044b \u044d\u0442\u043e \u0431\u044b\u043b 3D \u043e\u0431\u044a\u0435\u043a\u0442, \u043e\u0441\u0432\u0435\u0449\u0451\u043d\u043d\u044b\u0439 \u043f\u0440\u044f\u043c\u044b\u043c \u0441\u0432\u0435\u0442\u043e\u043c (\u043f\u0440\u0430\u0432\u0430\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430).<br \/>  <img decoding=\"async\" src=\"http:\/\/alteredqualia.com\/css-shaders\/article\/img\/grid.png\" alt=\"image\"\/><br \/>  \u0421\u043c\u043e\u0442\u0440\u0438\u0442\u0435 <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere_simple.html\">\u0437\u0434\u0435\u0441\u044c \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u043f\u0440\u0438\u043c\u0435\u0440<\/a>. <\/p>\n<h5>\u0414\u0435\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u0441\u0435\u0442\u043a\u0438<\/h5>\n<p>  \u0412\u0441\u0435 \u0434\u0435\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u0441\u0435\u0442\u043a\u0438 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u044f\u0442 \u0432 \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0445 \u0448\u0435\u0439\u0434\u0435\u0440\u0430\u0445.<br \/>  \u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0430\u043c \u043d\u0430\u0434\u043e \u043d\u0430\u0439\u0442\u0438 \u0441\u043f\u043e\u0441\u043e\u0431 \u043a\u0430\u043a \u043e\u0431\u0435\u0440\u043d\u0443\u0442\u044c \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0443\u044e \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u044c \u0432 \u0444\u043e\u0440\u043c\u0443 \u0441\u0444\u0435\u0440\u044b, \u0430 \u0442\u0435\u043d\u044c \u043d\u0430\u043b\u043e\u0436\u0438\u043c \u043f\u043e\u0442\u043e\u043c.<br \/>  \u041c\u044b \u043d\u0430\u0447\u043d\u0451\u043c \u0441 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u043e\u0439 \u0441\u0435\u0442\u043a\u0438, \u043b\u0435\u0436\u0430\u0449\u0435\u0439 \u0432 2D \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435, \u0441 \u0440\u0430\u0432\u043d\u043e\u043c\u0435\u0440\u043d\u043e \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u043c\u0438 \u043f\u043e\u0437\u0438\u0446\u0438\u044f\u043c\u0438 \u0432\u0435\u0440\u0448\u0438\u043d. \u041d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u043f\u043e\u0434\u043e\u0431\u0440\u0430\u0442\u044c \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043c\u0430\u043f\u043f\u0438\u043d\u0433 \u044d\u0442\u0438\u0445 2D \u043f\u043e\u0437\u0438\u0446\u0438\u0439 \u0432 3D \u0441\u0444\u0435\u0440\u0443.<br \/>  \u041c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u0432\u0435\u0440\u0448\u0438\u043d \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 \u0447\u0435\u0440\u0435\u0437 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043e\u043c \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0439 <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442<\/i> <b>a_position<\/b>. \u041d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0434\u0435\u043a\u043b\u0430\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e, \u043f\u0440\u0435\u0436\u0434\u0435, \u0447\u0435\u043c \u043c\u043e\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0451:  <\/p>\n<pre><code class=\"css\">attribute vec4 a_position;<\/code><\/pre>\n<p>  \u041c\u044b \u0437\u0430\u043f\u043e\u043c\u043d\u0438\u043c \u044d\u0442\u043e\u0442 <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442<\/i> \u0432 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u043e\u0439, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u0431\u0443\u0434\u0435\u043c \u043f\u043e\u0442\u043e\u043c \u043c\u043e\u0434\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u0442\u044c (\u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b<\/i> \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f read-only):  <\/p>\n<pre><code class=\"css\">vec4 position = a_position;<\/code><\/pre>\n<p>  \u0420\u0430\u0441\u043f\u043e\u0441\u0442\u0440\u0430\u043d\u0451\u043d\u043d\u043e\u0439 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0435\u0439 \u0432 \u043a\u043e\u043c\u043f\u044e\u0442\u0435\u0440\u043d\u043e\u0439 \u0433\u0440\u0430\u0444\u0438\u043a\u0430 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e\u043c a href=\u00ab<a href=\"http:\/\/en.wikipedia.org\/wiki\/UV_mapping\">en.wikipedia.org\/wiki\/UV_mapping<\/a>\u00bb&gt;UV mapping<\/i>, \u043a\u043e\u0433\u0434\u0430 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0430\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u0430 \u043e\u0431\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0432\u043e\u043a\u0440\u0443\u0433 \u0441\u0435\u0442\u043a\u0438, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f 2D \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u044b. \u0417\u0432\u0443\u0447\u0438\u0442 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u0445\u043e\u0436\u0435 \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e.<\/p>\n<p>  \u041e\u0434\u0438\u043d \u0438\u0437 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 <i>\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432<\/i> \u0441\u0435\u0442\u043a\u0438, \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043e\u043c \u2014 \u0434\u0432\u0443\u0445\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043d\u044b\u0439 \u0432\u0435\u043a\u0442\u043e\u0440 <b>a_texCoord<\/b> \u0441 \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u043d\u044b\u043c\u0438 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u0430\u043c\u0438 \u0432\u0435\u0440\u0448\u0438\u043d\u044b.  <\/p>\n<pre><code class=\"css\">attribute vec2 a_texCoord;<\/code><\/pre>\n<p>  \u0422\u0435\u043a\u0441\u0442\u0443\u0440\u043d\u044b\u0435 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442\u0441\u044f U \u0438 V, \u043e\u043d\u0438 \u043d\u0430\u0445\u043e\u0434\u044f\u0442\u0441\u044f \u0432 \u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043a\u0435 <b>0\u2026 1<\/b> \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u043e\u0441\u0438 \u0438 \u043c\u0430\u043f\u044f\u0442 \u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0441\u0435\u0442\u043a\u0438 \u043f\u043e \u0434\u043b\u0438\u043d\u0435 \u0438 \u0432\u044b\u0441\u043e\u0442\u0435 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0438.<\/p>\n<p>  \u0427\u0442\u043e\u0431\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b X, Y, Z, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0435 \u043d\u0430\u0448\u0438\u043c U \u0438 V \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u0430\u043c, \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043c\u0435\u0436\u0434\u0443 <a href=\"http:\/\/en.wikipedia.org\/wiki\/Spherical_coordinate_system\">\u0441\u0444\u0435\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u043e\u0439 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442<\/a> (\u0435\u0451 \u0435\u0449\u0451 \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442 \u043f\u043e\u043b\u044f\u0440\u043d\u043e\u0439) \u0438 <a href=\"http:\/\/en.wikipedia.org\/wiki\/Cartesian_coordinate_system\">\u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u043e\u0439 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442<\/a>:  <\/p>\n<pre><code class=\"css\">x = r * sin( \u03b8 ) * cos( \u03c6 ) y = r * sin( \u03b8 ) * sin( \u03c6 ) z = r * cos( \u03b8 )<\/code><\/pre>\n<p>  \u0421\u0444\u0435\u0440\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b:  <\/p>\n<ul>\n<li>\u0440\u0430\u0434\u0438\u0443\u0441 <b>r<\/b><\/li>\n<li>\u0437\u0435\u043d\u0438\u0442 (inclination) <b>\u03b8<\/b> (\u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u043a [0\u2026 \u03c0])<\/li>\n<li>\u0430\u0437\u0438\u043c\u0443\u0442 (azimuth) <b>\u03c6<\/b> (\u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u043a [0\u2026 2\u03c0])<\/li>\n<\/ul>\n<p>  \u041f\u043e\u0437\u0432\u043e\u043b\u0438\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c \u0440\u0430\u0434\u0438\u0443\u0441 \u0447\u0435\u0440\u0435\u0437 CSS <i>\u0444\u043e\u0440\u043c\u0443<\/i>:  <\/p>\n<pre><code class=\"css\">uniform float sphereRadius;<\/code><\/pre>\n<p>  \u0418 \u0431\u0443\u0434\u0435\u043c \u043c\u0430\u043f\u0438\u0442\u044c U \u0438 V \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b \u0432 \u0430\u0437\u0438\u043c\u0443\u0442 \u0438 \u0437\u0435\u043d\u0438\u0442:  <\/p>\n<pre><code class=\"css\">vec3 computeSpherePosition( vec2 uv, float r ) {      vec3 p;      float fi = uv.x * PI * 2.0;     float th = uv.y * PI;      p.x = r * sin( th ) * cos( fi );     p.y = r * sin( th ) * sin( fi );     p.z = r * cos( th );  }<\/code><\/pre>\n<pre><code class=\"css\">vec3 sphere = computeSpherePosition( a_texCoord, sphereRadius );<\/code><\/pre>\n<p>  \u0422\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043c\u0435\u0436\u0434\u0443 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u043b\u043e\u0441\u043a\u043e\u0439 \u043f\u043e\u0437\u0438\u0446\u0438\u0435\u0439 \u0438 \u043d\u043e\u0432\u043e\u0439 \u0441\u0444\u0435\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u043f\u043e\u0437\u0438\u0446\u0438\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u043c\u044b \u0442\u043e\u043b\u044c\u043a\u043e \u0447\u0442\u043e \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u043b\u0438, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u0443\u044e \u0432 GLSL \u0444\u0443\u043d\u043a\u0446\u0438\u044e (\u043b\u0438\u043d\u0435\u0439\u043d\u043e\u0439 \u0438\u043d\u0442\u0435\u0440\u043f\u043e\u043b\u044f\u0446\u0438\u0438 \u043c\u0435\u0436\u0434\u0443 \u0434\u0432\u0443\u043c\u044f \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438).  <\/p>\n<pre><code class=\"css\">uniform float amount;<\/code><\/pre>\n<p>  \u041c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b <i>\u0444\u043e\u0440\u043c\u044b<\/i> \u0447\u0442\u043e\u0431\u044b \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0445\u043e\u0434 (\u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <i>\u0444\u043e\u0440\u043c\u044b<\/i> \u0438\u0437 CSS \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0438\u043d\u0442\u0435\u0440\u043f\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043d \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043e\u043c, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f CSS transitions).  <\/p>\n<pre><code class=\"css\">position.xyz = mix( position.xyz, sphere, amount );<\/code><\/pre>\n<p>  \u041d\u0430\u043a\u043e\u043d\u0435\u0446, \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c \u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0441\u0435\u0442\u043a\u0438, \u0437\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u044f \u0432 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u0443\u044e GLSL \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e, \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0438\u0440\u0443\u044e\u0449\u0443\u044e \u043d\u0430\u0448\u0443 \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u043d\u043d\u0443\u044e \u043f\u043e\u0437\u0438\u0446\u0438\u044e \u043f\u043e \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043e\u043c \u043c\u0430\u0442\u0440\u0438\u0447\u043d\u043e\u0439 <i>\u0444\u043e\u0440\u043c\u0435<\/i> <a href=\"http:\/\/www.opengl.org\/sdk\/docs\/manglsl\/xhtml\/gl_Position.xml\">gl_Position<\/a>:  <\/p>\n<pre><code class=\"css\">gl_Position = u_projectionMatrix * position;<\/code><\/pre>\n<h5>\u0417\u0430\u0442\u0435\u043d\u0435\u043d\u0438\u0435 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438<\/h5>\n<p>  \u041f\u043e\u0434\u0441\u0447\u0451\u0442 \u0437\u0430\u0442\u0435\u043d\u0435\u043d\u0438\u044f \u0434\u0435\u043b\u0430\u0435\u0442\u0441\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u0435\u043c \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0445 \u0438 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0445 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432.<\/p>\n<h6>\u0417\u0430\u0442\u0435\u043d\u0435\u043d\u0438\u0435: \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u044b<\/h6>\n<p>  \u0412 \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u043e\u043c \u0448\u0435\u0439\u0434\u0435\u0440\u0435 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u043e\u0434\u0441\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c \u043e\u0441\u0432\u0435\u0449\u0435\u043d\u0438\u0435 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0432\u0435\u0440\u0448\u0438\u043d\u044b \u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u044d\u0442\u043e \u043a\u0430\u043a <i>\u043e\u0442\u043b\u0438\u0447\u0438\u0435<\/i> \u0432 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440, \u0433\u0434\u0435 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0435\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0446\u0432\u0435\u0442 DOM \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u044b.<\/p>\n<p>  \u0414\u043b\u044f \u0437\u0430\u0442\u0435\u043d\u0435\u043d\u0438\u044f \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0443\u044e <a href=\"http:\/\/en.wikipedia.org\/wiki\/Lambertian_reflectance\"> \u043c\u043e\u0434\u0435\u043b\u044c \u041b\u0430\u043c\u0431\u0435\u0440\u0442\u043e\u0432\u0441\u043a\u043e\u0433\u043e \u0440\u0430\u0441\u0441\u0435\u0438\u0432\u0430\u043d\u0438\u044f<\/a>.<br \/>  \u0421\u0432\u0435\u0442 \u043e\u0442\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u043a\u0430\u043a \u0441\u043a\u0430\u043b\u044f\u0440\u043d\u043e\u0435 \u043f\u0440\u043e\u0438\u0437\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0432\u0435\u043a\u0442\u043e\u0440\u0430 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u0438 \u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u0432\u0435\u043a\u0442\u043e\u0440\u0430 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u0441\u0432\u0435\u0442\u0430.<br \/>  \u041d\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f \u043f\u043e\u0437\u0438\u0446\u0438\u044f \u0441\u0432\u0435\u0442\u0430 \u0438 <a href=\"http:\/\/en.wikipedia.org\/wiki\/Surface_normal\">\u043d\u043e\u0440\u043c\u0430\u043b\u044c \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438<\/a> \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0432\u0435\u0440\u0448\u0438\u043d\u044b.<br \/>  \u041c\u044b \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c \u043f\u043e\u0437\u0438\u0446\u0438\u044e \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430 \u0441\u0432\u0435\u0442\u0430 \u043a\u0430\u043a \u0442\u0440\u0451\u0445\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043d\u0443\u044e \u0432\u0435\u043a\u0442\u043e\u0440\u043d\u0443\u044e <i>\u0444\u043e\u0440\u043c\u0443<\/i> <b>lightPosition<\/b>, \u043f\u0435\u0440\u0435\u0434\u043e\u0432\u0430\u0435\u043c\u0443\u044e \u0447\u0435\u0440\u0435\u0437 CSS:  <\/p>\n<pre><code class=\"css\">uniform vec3 lightPosition;<\/code><\/pre>\n<p>  \u041c\u044b \u0431\u0443\u0434\u0435\u043c \u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0430\u044f \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u0443\u044e \u0432 GLSL \u0444\u0443\u043d\u043a\u0446\u0438\u044e <a href=\"http:\/\/www.opengl.org\/sdk\/docs\/manglsl\/xhtml\/normalize.xml\">normalize<\/a>:  <\/p>\n<pre><code class=\"css\">vec3 lightPositionNormalized = normalize( lightPosition );<\/code><\/pre>\n<p>  \u0414\u0430\u043b\u0435\u0435 \u043d\u0430\u043c \u043d\u0430\u0434\u043e \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u0442\u044c \u043d\u043e\u0440\u043c\u0430\u043b\u044c \u0434\u043b\u044f \u043f\u043b\u043e\u0441\u043a\u043e\u0439 \u0438 \u0441\u0444\u0435\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438.<br \/>  \u041d\u043e\u0440\u043c\u0430\u043b\u044c \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u043e\u0431\u044b\u0447\u043d\u043e \u0441\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u043e\u043d\u0435 CPU, \u0442\u0430\u043a \u043a\u0430\u043a \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441\u043e \u0441\u0432\u044f\u0437\u043d\u043e\u0439 \u0441\u0435\u0442\u043a\u043e\u0439 \u0438 \u0438\u043c\u0435\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u043a\u043e \u0432\u0441\u0435\u043c \u0432\u0435\u0440\u0448\u0438\u043d\u0430\u043c \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e (\u0448\u0435\u0439\u0434\u0435\u0440 \u0432\u0438\u0434\u0438\u0442 \u0437\u0430 \u0440\u0430\u0437 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d \u0432\u0435\u0440\u0448\u0438\u043d\u0443).<br \/>  \u0422\u0435\u043c \u043d\u0435 \u043c\u0435\u043d\u0435\u0435, \u0437\u0434\u0435\u0441\u044c \u043c\u044b \u0438\u043c\u0435\u0435\u043c \u0434\u0435\u043b\u043e \u0441 \u043f\u0440\u043e\u0441\u0442\u044b\u043c\u0438 \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u0438\u043c\u0438 \u0444\u043e\u0440\u043c\u0430\u043c\u0438, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u0442\u044c \u043d\u043e\u0440\u043c\u0430\u043b\u0438 \u0430\u043d\u0430\u043b\u0438\u0442\u0438\u0447\u0435\u0441\u043a\u0438.<br \/>  \u0414\u043b\u044f \u043d\u043e\u0440\u043c\u0430\u043b\u0438 \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 \u043c\u044b \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0441\u0445\u0438\u0442\u0440\u0438\u043c: \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0430\u044f \u043d\u043e\u0440\u043c\u0430\u043b\u044c \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 \u0434\u043e\u043b\u0436\u043d\u0430 \u0431\u044b\u0442\u044c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0430 \u043e\u0442 \u043c\u043e\u043d\u0438\u0442\u043e\u0440\u0430, \u043f\u0435\u0440\u043f\u0435\u043d\u0434\u0438\u043a\u0443\u043b\u044f\u0440\u043d\u043e \u043a \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 XY.<br \/>  \u041d\u043e \u0442\u0430\u043a\u0430\u044f \u043d\u043e\u0440\u043c\u0430\u043b\u044c \u0434\u0430\u0441\u0442 \u043d\u0430\u043c \u043d\u0435\u0438\u0437\u043c\u0435\u043d\u0451\u043d\u043d\u044b\u0439 DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442, \u043c\u0435\u0441\u0442\u0430\u043c\u0438 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0437\u0430\u0442\u0435\u043d\u0451\u043d\u043d\u044b\u0439, \u0438 \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u043d\u0435\u0435\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043d\u0430 \u0444\u043e\u043d\u0435 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u0438\u043c\u0435\u044e\u0442 \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0445 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432.<br \/>  \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0432\u0435\u043a\u0442\u043e\u0440, \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u044b\u0439 \u043a \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0443 \u0441\u0432\u0435\u0442\u0430 \u043a\u0430\u043a \u043d\u043e\u0440\u043c\u0430\u043b\u044c \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438.  <\/p>\n<pre><code class=\"css\">vec3 planeNormal = lightPositionNormalized;<\/code><\/pre>\n<p>  \u042d\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u043d\u0435\u0434\u0435\u0444\u043e\u0440\u043c\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c\u0443 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0443 \u0432\u0441\u0435\u0433\u0434\u0430 \u0431\u044b\u0442\u044c \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043e\u0441\u0432\u0435\u0449\u0451\u043d\u043d\u044b\u043c.<\/p>\n<p>  \u0414\u043b\u044f \u043d\u043e\u0440\u043c\u0430\u043b\u0438 \u0441\u0444\u0435\u0440\u044b \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0443\u044e \u0430\u043d\u0430\u043b\u0438\u0442\u0438\u0447\u0435\u0441\u043a\u0443\u044e \u0444\u043e\u0440\u043c\u0443\u043b\u0443. \u041d\u043e\u0440\u043c\u0430\u043b\u044c \u0441\u0444\u0435\u0440\u044b \u043d\u0430 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438 \u2014 \u044d\u0442\u043e \u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0432\u0435\u043a\u0442\u043e\u0440\u044b \u0438\u0437 \u0446\u0435\u043d\u0442\u0440\u0430 \u0441\u0444\u0435\u0440\u044b \u043a \u0435\u0451 \u043f\u043e\u0432\u0435\u0440\u0445\u043d\u043e\u0441\u0442\u0438:  <\/p>\n<pre><code class=\"css\">vec3 sphereNormal = normalize( position.xyz );<\/code><\/pre>\n<p>  \u0427\u0442\u043e\u0431\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0430\u0434\u0435\u043a\u0432\u0430\u0442\u043d\u0443\u044e \u043d\u043e\u0440\u043c\u0430\u043b\u044c \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f, \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u0442\u044c \u043e\u0442 \u043d\u043e\u0440\u043c\u0430\u043b\u0438 \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 \u043a \u043d\u043e\u0440\u043c\u0430\u043b\u0438 \u0441\u0444\u0435\u0440\u044b \u0438 \u043d\u043e\u0440\u043c\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u0442\u043e\u0442 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u043d\u044b\u0439 \u0432\u0435\u043a\u0442\u043e\u0440:  <\/p>\n<pre><code class=\"css\">vec3 normal = normalize( mix( planeNormal, sphereNormal, amount ) );<\/code><\/pre>\n<p>  \u041d\u0430\u043a\u043e\u043d\u0435\u0446, \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u0441\u0447\u0438\u0442\u0430\u0442\u044c \u043e\u0441\u0432\u0435\u0449\u0435\u043d\u0438\u0435 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u041b\u0430\u043c\u0431\u0435\u0440\u0442\u043e\u0432\u0441\u043a\u043e\u0439 \u0444\u043e\u0440\u043c\u0443\u043b\u0435, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u0443\u044e \u0432 GLSL \u0444\u0443\u043d\u043a\u0446\u0438\u044e <a href=\"http:\/\/www.opengl.org\/sdk\/docs\/manglsl\/xhtml\/dot.xml\">dot<\/a>, \u0438 \u0437\u0430\u0444\u0438\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0442\u0440\u0438\u0446\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u0437\u0430\u043d\u0447\u0435\u043d\u0438\u044f \u0444\u043e\u0440\u043c\u0443\u043b\u043e\u0439 <a href=\"http:\/\/www.opengl.org\/sdk\/docs\/manglsl\/xhtml\/max.xml\">max<\/a>:  <\/p>\n<pre><code class=\"css\">float light = max( dot( normal, lightPositionNormalized ), 0.0 );<\/code><\/pre>\n<p>  \u041f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u043c \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435\u043c \u0432\u0435\u043a\u0442\u043e\u0440\u043d\u043e\u0433\u043e \u0448\u0435\u0439\u0434\u0435\u0440\u0430 \u043c\u044b \u043f\u0435\u0440\u0435\u0434\u0430\u0434\u0438\u043c \u0438\u043d\u0442\u0435\u043d\u0441\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u0441\u0432\u0435\u0442\u0430 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u043e\u043c\u0443 \u0448\u0435\u0439\u0434\u0435\u0440\u0443 \u0447\u0435\u0440\u0435\u0437 <i>\u043e\u0442\u043b\u0438\u0447\u0438\u0435<\/i>:  <\/p>\n<pre><code class=\"css\">varying float v_light;<\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"css\">v_light = light;<\/code><\/pre>\n<h6>\u0417\u0430\u0442\u0435\u043d\u0435\u043d\u0438\u0435: \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440<\/h6>\n<p>  \u0424\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440 \u0431\u0443\u0434\u0435\u0442 \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e\u0439, \u0432\u0441\u0451 \u0442\u044f\u0436\u0451\u043b\u043e\u0435 \u0431\u044b\u043b\u043e \u043e\u0441\u0438\u043b\u0435\u043d\u043e \u0432 \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u043e\u043c \u0448\u0435\u0439\u0434\u0435\u0440\u0435.<br \/>  \u0412\u043e\u0437\u044c\u043c\u0451\u043c \u0438\u043d\u0442\u0435\u043d\u0441\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u0441\u0432\u0435\u0442\u0430 \u0438\u0437 <i>\u043e\u0442\u043b\u0438\u0447\u0438\u044f<\/i>:  <\/p>\n<pre><code class=\"css\">varying float v_light;<\/code><\/pre>\n<p>  \u0418 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0435\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u043c\u043e\u0434\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0446\u0432\u0435\u0442\u043e\u0432\u044b\u0435 \u043a\u043e\u044d\u0444\u0444\u0438\u0446\u0435\u043d\u0442\u044b (\u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c \u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0435\u043c):  <\/p>\n<pre><code class=\"css\">float r, g, b; r = g = b = v_light;<\/code><\/pre>\n<p>  \u0418 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c \u0438\u0445 \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043c\u0430\u0442\u0440\u0438\u0446\u0443 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0430 <a href=\"https:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html#feColorMatrixElement\">css_ColorMatrix<\/a>:  <\/p>\n<pre><code class=\"css\"> css_ColorMatrix = mat4( r, 0.0, 0.0, 0.0,                         0.0, g, 0.0, 0.0,                         0.0, 0.0, b, 0.0,                         0.0, 0.0, 0.0, 1.0 ); <\/code><\/pre>\n<p>  \u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u0446\u0432\u0435\u0442, \u044d\u043a\u0432\u0438\u0432\u0430\u043b\u0435\u0442\u043d\u044b\u0439 \u044d\u0442\u043e\u043c\u0443:  <\/p>\n<pre><code class=\"css\">gl_FragColor = vec4( r, g, b, 1.0 ) * sourceColor;<\/code><\/pre>\n<h6>\u0418\u0442\u043e\u0433\u043e\u0432\u044b\u0439 \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440<\/h6>\n<p>  <a href=\"http:\/\/alteredqualia.com\/css-shaders\/shaders\/sphere_simple.vs\">\u0421\u043a\u0430\u0447\u0430\u0442\u044c<\/a>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b><\/p>\n<div class=\"spoiler_text\">precision mediump float;<\/p>\n<p>  \/\/ \u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b<\/p>\n<p>  attribute vec4 a_position;<br \/>  attribute vec2 a_texCoord;<\/p>\n<p>  \/\/ \u0412\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0444\u043e\u0440\u043c\u044b<\/p>\n<p>  uniform mat4 u_projectionMatrix;<\/p>\n<p>  \/\/ \u0424\u043e\u0440\u043c\u044b, \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 CSS<\/p>\n<p>  uniform float amount;<br \/>  uniform float sphereRadius;<br \/>  uniform vec3 lightPosition;<\/p>\n<p>  \/\/ \u041e\u0442\u043b\u0438\u0447\u0438\u044f<\/p>\n<p>  varying float v_light;<\/p>\n<p>  \/\/ \u041a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u044b<\/p>\n<p>  const float PI = 3.1415;<\/p>\n<p>  \/\/ \u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 perspective matrix<\/p>\n<p>  vec3 computeSpherePosition( vec2 uv, float r ) {<\/p>\n<p>  vec3 p;<\/p>\n<p>  float fi = uv.x * PI * 2.0;<br \/>   float th = uv.y * PI;<\/p>\n<p>  p.x = r * sin( th ) * cos( fi );<br \/>   p.y = r * sin( th ) * sin( fi );<br \/>   p.z = r * cos( th );<\/p>\n<p>  return p;<\/p>\n<p>  }<\/p>\n<p>  \/\/ Main<\/p>\n<p>  void main() {<\/p>\n<p>  vec4 position = a_position;<\/p>\n<p>  \/\/ \u041c\u0430\u043f\u0438\u043c \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u044c \u0432 \u0441\u0444\u0435\u0440\u0443, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f UV \u043a\u043e\u043e\u0440\u0434\u0438\u043d\u0430\u0442\u044b<\/p>\n<p>  vec3 sphere = computeSpherePosition( a_texCoord, sphereRadius );<\/p>\n<p>  \/\/ \u041f\u0435\u0440\u0435\u0445\u043e\u0434 \u043e\u0442 \u043f\u043b\u043e\u0441\u043a\u043e\u0441\u0442\u0438 \u043a \u0441\u0444\u0435\u0440\u0435<\/p>\n<p>  position.xyz = mix( position.xyz, sphere, amount );<\/p>\n<p>  \/\/ \u0417\u0430\u0434\u0430\u0434\u0438\u043c \u043f\u043e\u0437\u0438\u0446\u0438\u044e \u0432\u0435\u0440\u0448\u0438\u043d\u044b<\/p>\n<p>  gl_Position = u_projectionMatrix * position;<\/p>\n<p>  \/\/ \u041f\u043e\u0441\u0447\u0438\u0442\u0430\u0435\u043c \u0441\u0432\u0435\u0442<\/p>\n<p>  vec3 lightPositionNormalized = normalize( lightPosition );<\/p>\n<p>  vec3 planeNormal = lightPositionNormalized;<br \/>   vec3 sphereNormal = normalize( position.xyz );<\/p>\n<p>  vec3 normal = normalize( mix( planeNormal, sphereNormal, amount ) );<\/p>\n<p>  float light = max( dot( normal, lightPositionNormalized ), 0.0 );<\/p>\n<p>  \/\/ \u041f\u0435\u0440\u0435\u0434\u0430\u0434\u0438\u043c \u0432 \u043e\u0442\u043b\u0438\u0447\u0438\u0435<\/p>\n<p>  v_light = light;<\/p>\n<p>  }<\/p><\/div>\n<\/div>\n<h6>\u0418\u0442\u043e\u0433\u043e\u0432\u044b\u0439 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u044b\u0439 \u0448\u0435\u0439\u0434\u0435\u0440<\/h6>\n<p>  <a href=\"http:\/\/alteredqualia.com\/css-shaders\/shaders\/sphere_simple.fs\">\u0421\u043a\u0430\u0447\u0430\u0442\u044c<\/a>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b><\/p>\n<div class=\"spoiler_text\">precision mediump float;<\/p>\n<p>  varying float v_light;<\/p>\n<p>  void main() {<\/p>\n<p>  float r, g, b;<br \/>   r = g = b = v_light;<\/p>\n<p>  css_ColorMatrix = mat4( r, 0.0, 0.0, 0.0,<br \/>   0.0, g, 0.0, 0.0,<br \/>   0.0, 0.0, b, 0.0,<br \/>   0.0, 0.0, 0.0, 1.0 );<\/p>\n<p>  }<\/p><\/div>\n<\/div>\n<h6>CSS \u0441\u0442\u0438\u043b\u044c<\/h6>\n<p>  <a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere_simple.html\">\u0421\u043a\u0430\u0447\u0430\u0442\u044c<\/a>  <\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b><\/p>\n<div class=\"spoiler_text\">.shader {<br \/>   -webkit-filter: custom(url(sphere.vs) mix(url(sphere.fs) normal source-atop), <br \/>   16 32, amount 1, sphereRadius 0.35, lightPosition 0.0 0.0 1.0);<br \/>   -webkit-transition: -webkit-filter ease-in-out 1s;<br \/>  }<\/p>\n<p>  .shader:hover {<br \/>   -webkit-filter: custom(url(sphere.vs) mix(url(sphere.fs) normal source-atop), <br \/>   16 32, amount 0, sphereRadius 0.35, lightPosition 0.0 0.0 1.0);<br \/>  }<\/div>\n<\/div>\n<h5>\u0415\u0449\u0435 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432<\/h5>\n<p>  <\/p>\n<ul>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/burn.html\">Burn shader<\/a><\/li>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/dissolve.html\">Dissolve shader<\/a><\/li>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/crumple.html\">Crumple shader<\/a><\/li>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/dots.html\">Dots shader<\/a><\/li>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/flip.html\">Flip shader (variant 1)<\/a><\/li>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/flip2.html\">Flip shader (variant 2)<\/a><\/li>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere.html\">Sphere shader (planets)<\/a><\/li>\n<li><a href=\"http:\/\/alteredqualia.com\/css-shaders\/sphere2.html\">Sphere shader (map)<\/a><\/li>\n<\/ul>\n<p>  <\/p>\n<h5>\u041e\u0442\u043b\u0430\u0434\u043a\u0430 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432<\/h5>\n<p>  \u041e\u0442\u043b\u0430\u0434\u043a\u0430 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u0432 CCSSF \u2014 \u0434\u0435\u043b\u043e \u0441\u043b\u043e\u0436\u043d\u043e\u0435. \u041f\u043e \u043a\u0440\u0430\u0439\u043d\u0435\u0439 \u043c\u0435\u0440\u0435, \u0441\u0435\u0439\u0447\u0430\u0441 \u043d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e error \u043b\u043e\u0433\u0430 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u044c Chrome (\u0432 \u043e\u0442\u043b\u0438\u0447\u0438\u0435 \u043e\u0442 WebGL, \u0433\u0434\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u0438 \u0448\u0435\u0439\u0434\u0435\u0440\u0430 \u0438, \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e, \u043d\u0430\u0439\u0442\u0438 \u043e\u0448\u0438\u0431\u043a\u0443 \u0438\u043b\u0438 \u043e\u043f\u0435\u0447\u0430\u0442\u043a\u0443).<\/p>\n<p>  \u041d\u0430 \u043c\u0430\u043a\u0435 \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c <a href=\"http:\/\/blattchat.com\/2012\/06\/19\/a-little-help-debugging-css-shaders\/\">error output<\/a> \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u043c\u044b\u0439 \u0432 \u043e\u043a\u043d\u0435 \u043a\u043e\u043d\u0441\u043e\u043b\u0438, \u0438\u0437 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u044b \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u043b\u0438 Chrome, \u043d\u043e \u0432 Windows \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u044c \u0442\u0430\u043a\u043e\u0433\u043e \u043d\u0435 \u043f\u0438\u0448\u0435\u0442\u0441\u044f.<\/p>\n<p>  \u0412\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u2014 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <a href=\"https:\/\/github.com\/WebGLTools\/GL-Shader-Validator\">GL shader validation plugin<\/a> \u0434\u043b\u044f <a href=\"http:\/\/www.sublimetext.com\/\">Sublime text editor<\/a>, \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0435\u0434\u0430\u0432\u043d\u043e \u0440\u0435\u0431\u044f\u0442\u0430\u043c\u0438 <a href=\"http:\/\/twitter.com\/aerotwist\">@aerotwist<\/a> \u0438 <a href=\"http:\/\/twitter.com\/brendankenny\">@brendankenny<\/a>.   <\/p>\n<h5>\u041f\u0440\u043e\u0444\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432<\/h5>\n<p>  \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u0442\u0430\u043a \u0436\u0435 \u043a\u0430\u043a \u0438 \u0432 WebGL \u043d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e \u0441\u043f\u043e\u0441\u043e\u0431\u0430 \u0443\u0432\u0438\u0434\u0435\u0442\u044c, \u0447\u0442\u043e \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043d\u0430 \u0441\u0442\u043e\u0440\u043e\u043d\u0435 GPU :S.<br \/>  \u0412\u0441\u0451 \u0436\u0435, \u0435\u0441\u0442\u044c \u043f\u0430\u0440\u0430 \u0445\u0438\u0442\u0440\u043e\u0441\u0442\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c, \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u043e \u0440\u0430\u0431\u043e\u0442\u0435 \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432.<br \/>  \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0435\u0441\u043b\u0438 \u0432\u044b \u0445\u043e\u0442\u0438\u0442\u0435 \u0443\u0437\u043d\u0430\u0442\u044c, \u043f\u0440\u0438\u0432\u044f\u0437\u0430\u043d\u043e \u043b\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0432\u0430\u0448\u0435\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u043f\u0440\u0438\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u043c \u043a \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u043d\u043e\u043c\u0443 \u0448\u0435\u0439\u0434\u0435\u0440\u0443, \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u043c\u0435\u0440 DOM \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430, \u0447\u0442\u043e\u0431\u044b \u0443\u0432\u0438\u0434\u0435\u0442\u044c, \u0441\u0442\u0430\u043b\u043e \u043b\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043b\u0443\u0447\u0448\u0435 \u043d\u0430 \u0443\u043c\u0435\u043d\u044c\u0448\u0435\u043d\u043d\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u0445.<br \/>  \u041f\u044b\u0442\u0430\u0439\u0442\u0435\u0441\u044c \u0438\u0437\u0431\u0435\u0433\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432, \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c\u044b\u0445 \u043a \u043f\u043e\u043b\u043d\u043e\u044d\u043a\u0440\u0430\u043d\u043d\u044b\u043c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c. \u042d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u043d\u0435\u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0438 \u043c\u043e\u0436\u0435\u0442 \u043e\u043a\u0430\u0437\u0430\u0442\u044c\u0441\u044f \u0443\u0437\u043a\u0438\u043c \u043c\u0435\u0441\u0442\u043e\u043c \u043f\u0440\u0438 \u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u0438 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b.<br \/>  \u0415\u0441\u043b\u0438 \u0445\u043e\u0442\u0438\u0442\u0435 \u0443\u0432\u0438\u0434\u0435\u0442\u044c, \u043f\u0440\u0438\u0432\u044f\u0437\u0430\u043d\u043e \u043b\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0432\u0430\u0448\u0435\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u043a \u0432\u0435\u0440\u0448\u0438\u043d\u043d\u044b\u043c \u0448\u0435\u0439\u0434\u0435\u0440\u0430\u043c, \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u0435\u0433\u043e \u043d\u0430 \u0441\u0435\u0442\u043a\u0435 \u0441 \u0434\u0440\u0443\u0433\u043e\u0439 \u043c\u043e\u0437\u0430\u0438\u043a\u043e\u0439.<\/p>\n<p>  \u041f\u043e\u043c\u043d\u0438\u0442\u0435, \u0447\u0442\u043e \u0435\u0441\u043b\u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442 \u043a \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0443 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c\u0438 \u043c\u043e\u0437\u0430\u0438\u043a\u0430\u043c\u0438 \u043d\u0430 \u043e\u0434\u043d\u043e\u0439 \u0438 \u0442\u043e\u0439 \u0436\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435, \u043c\u043e\u0436\u043d\u043e \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u043e \u043d\u0430\u0440\u0430\u0441\u0442\u0438\u0442\u044c \u043e\u0431\u0449\u0438\u0439 \u0441\u0447\u0451\u0442\u0447\u0438\u043a \u0442\u0440\u0435\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u043e\u0432.<\/p>\n<h4>\u041f\u043e\u043b\u0435\u0437\u043d\u044b\u0435 \u0441\u0441\u044b\u043b\u043a\u0438<\/h4>\n<p>  <\/p>\n<ul>\n<li><a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html\">Filter Effects specification<\/a><\/li>\n<li><a href=\"http:\/\/www.khronos.org\/files\/opengles_shading_language.pdf\">GLSL specification<\/a><\/li>\n<li><a href=\"https:\/\/dvcs.w3.org\/hg\/FXTF\/rawfile\/tip\/compositing\/index.html\"> Compositing and Blending specification<\/a><\/li>\n<li><a href=\"http:\/\/www.w3.org\/TR\/css3-transitions\/\">CSS transitions specification<\/a><\/li>\n<li><a href=\"http:\/\/www.w3.org\/TR\/2012\/WD-css3-transforms-20120911\/\">CSS transforms specification<\/a><\/li>\n<li><a href=\"https:\/\/bugs.webkit.org\/show_bug.cgi?id=71392\">Umbrella WebKit issue tracking CSS Shaders implementation progress<\/a><\/li>\n<li><a href=\"http:\/\/adobe.github.com\/web-platform\/samples\/css-customfilters\/\">Adobe custom CSS filter effects examples<\/a><\/li>\n<li><a href=\"http:\/\/www.adobe.com\/devnet\/html5\/articles\/css-shaders.html\">Introducing CSS shaders: Cinematic effects for the web<\/a><\/li>\n<li><a href=\"http:\/\/www.khronos.org\/files\/webgl\/webgl-reference-card-1_0.pdf\"> WebGL quick reference card<\/a> (\u0432\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u0439 \u0441\u043f\u0440\u0430\u0432\u043e\u0447\u043d\u0438\u043a GLSL)<\/li>\n<li><a href=\"http:\/\/glsl.heroku.com\/\"> GLSL Sandbox<\/a><\/li>\n<li><a href=\"http:\/\/experiments.hertzen.com\/css-shaders\/\">CSS Shaders implemented with WebGL<\/a><\/li>\n<\/ul>\n<p>  <\/p>\n<h5>\u041c\u0430\u0442\u0435\u0440\u0438\u0430\u043b<\/h5>\n<p>  <\/p>\n<ul>\n<li><a href=\"http:\/\/en.wikipedia.org\/wiki\/File:Jupiter_from_Voyager_1.jpg\">Jupiter close-up by Voyager 1<\/a><\/li>\n<li><a href=\"http:\/\/textures.forrest.cz\/index.php?spgmGal=maps&amp;spgmPic=14#spgmPicture\">Jupiter texture<\/a><\/li>\n<li><a href=\"http:\/\/maps.google.com\/\">Earth from Google Maps<\/a><\/li>\n<li><a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html\">Diagrams from Filter Effects spec<\/a><\/li>\n<\/ul>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u0421\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442<\/b><\/p>\n<div class=\"spoiler_text\">P.S. \u041f\u0435\u0440\u0435\u0432\u0451\u043b \u043f\u043e \u043f\u0440\u043e\u0441\u044c\u0431\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0438\u0437 \u0445\u0430\u0431\u0440\u0430\u044e\u0437\u0435\u0440\u043e\u0432 \u0433\u0434\u0435-\u0442\u043e \u0432 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0445, \u0441\u0430\u043c \u043d\u0438\u0447\u0435\u0433\u043e \u0432\u044b\u0448\u0435\u043e\u043f\u0438\u0441\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0435 \u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b =)  <\/div>\n<\/div>\n<p>            \t<\/p>\n<div class=\"clear\"><\/div>\n<\/p><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/post\/155447\/\"> http:\/\/habrahabr.ru\/post\/155447\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\">\n<h4>\u041f\u0440\u0438\u0441\u0442\u0443\u043f\u0430\u044f \u043a \u043a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u043c \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u043c \u043d\u0430 CSS (<b>C<\/b>ustom <b>C<\/b>ascading<b> S<\/b>tyle<b> S<\/b>heets<b> F<\/b>ilters)<\/h4>\n<h4>\u0412\u0441\u0442\u0443\u043f\u043b\u0435\u043d\u0438\u0435<\/h4>\n<p>  \u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b (\u0434\u0430\u043b\u0435\u0435 CCSSF)(\u0440\u0430\u043d\u0435\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0435 \u043a\u0430\u043a CSS \u0448\u0435\u0439\u0434\u0435\u0440\u044b) \u2014 \u044d\u0442\u043e \u043d\u043e\u0432\u0430\u044f \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u0430\u044f \u0444\u0438\u0447\u0430, \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0449\u0430\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0435 \u0440\u0443\u043a\u0430\u043c\u0438 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u043d\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b HTML \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430.<br \/>  \u041a\u0430\u0441\u0442\u043e\u043c\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0447\u0430\u0441\u0442\u044c\u044e <a href=\"http:\/\/dvcs.w3.org\/hg\/FXTF\/raw-file\/tip\/filters\/index.html\">Filter Effects 1.0 specification<\/a>. \u041e\u043d\u0438 \u0434\u043e\u043f\u043e\u043b\u043d\u044f\u044e\u0442 \u0434\u0440\u0443\u0433\u0443\u044e \u0447\u0430\u0441\u0442\u044c \u044d\u0442\u043e\u0439 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438, \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u044e\u0449\u0443\u044e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u0431\u0449\u0438\u0435 CSS \u0444\u0438\u043b\u044c\u0442\u0440\u044b, \u0443\u0436\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0432 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u044b (blur, sepia, contrast, grayscale).   <\/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-155447","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/155447","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=155447"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/155447\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=155447"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=155447"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=155447"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}