{"id":485375,"date":"2026-06-29T00:35:04","date_gmt":"2026-06-29T00:35:04","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=485375"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=485375","title":{"rendered":"Direct 2D #12. \u0421\u043b\u043e\u0438 \u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u044b"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p><strong>\u041e \u0421\u043b\u043e\u044f\u0445.<\/strong><br \/>\u0421\u043b\u043e\u0439 &#8212; \u044d\u0442\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f \u0446\u0435\u043b\u044c \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u044b \u0440\u0438\u0441\u0443\u0435\u0442\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e, \u0430 \u0437\u0430\u0442\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0446\u0435\u043b\u044c \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430. \u0412 Direct2D \u0441\u043b\u043e\u0439 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u043c ID2D1Layer. \u041f\u043e\u0434\u043e\u0431\u043d\u043e \u043a\u0438\u0441\u0442\u044f\u043c, \u0441\u043b\u043e\u0438 \u0441\u043e\u0437\u0434\u0430\u044e\u0442\u0441\u044f \u0440\u0435\u043d\u0434\u0435\u0440-\u0442\u0430\u0440\u0433\u0435\u0442\u043e\u043c \u0438 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0440\u0435\u0441\u0443\u0440\u0441\u0430\u043c\u0438, \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u043c\u0438 \u043e\u0442 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430. \u0421\u043b\u043e\u0439 \u043c\u043e\u0436\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u043e\u0439 \u0446\u0435\u043b\u044c\u044e \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u0432 \u043e\u0434\u0438\u043d \u043c\u043e\u043c\u0435\u043d\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u0438. \u0415\u0441\u043b\u0438 \u0440\u0430\u0437\u043c\u0435\u0440 \u0441\u043b\u043e\u044f \u043d\u0435 \u0443\u043a\u0430\u0437\u0430\u043d \u043f\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438, \u043c\u0435\u0442\u043e\u0434 PushLayer \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0439 \u0440\u0430\u0437\u043c\u0435\u0440 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0433\u043e \u0438 \u043c\u0430\u0441\u043a\u0438. \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u043e \u0441\u043b\u043e\u044f\u043c\u0438 (\u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u043e\u0431\u0449\u0438\u0439 \u043f\u043b\u0430\u043d):<\/p>\n<p>\u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u043e \u0441\u043b\u043e\u044f\u043c\u0438 (\u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u043e\u0431\u0449\u0438\u0439 \u043f\u043b\u0430\u043d):<\/p>\n<ol>\n<li>\n<p>\u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0441\u043b\u043e\u0439 \u0447\u0435\u0440\u0435\u0437 CreateLayer<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0441\u043b\u043e\u0439 \u0447\u0435\u0440\u0435\u0437 PushLayer &#8212; \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b(\u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u044f) \u0431\u0443\u0434\u0443\u0442 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u0432 \u0441\u043b\u043e\u0439<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0441\u0442\u0430\u0451\u043c \u0441\u043b\u043e\u0439 \u0447\u0435\u0440\u0435\u0437 PopLayer &#8212; \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0441\u043b\u043e\u044f \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0446\u0435\u043b\u044c\u044e \u0440\u0435\u043d\u0434\u0435\u0440\u0430<\/p>\n<\/li>\n<\/ol>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043f\u0443\u043d\u043a\u0442\u0430:<\/p>\n<p>\u0414\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0441\u043b\u043e\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 CreateLayer:<\/p>\n<pre><code class=\"cpp\">ID2D1Layer* pLayer = nullptr;HRESULT hr = pRenderTarget-&gt;CreateLayer(nullptr, &amp;pLayer);if (FAILED(hr)) {    \/\/ \u041e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043a\u0438}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041f\u0435\u0440\u0432\u044b\u0439 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 &#8212; \u0440\u0430\u0437\u043c\u0435\u0440 \u0441\u043b\u043e\u044f \u0432 \u043f\u0438\u043a\u0441\u0435\u043b\u044f\u0445. \u041f\u0440\u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u0447\u0435 nullptr \u0440\u0430\u0437\u043c\u0435\u0440 \u0431\u0443\u0434\u0435\u0442 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u0438 \u0432\u044b\u0437\u043e\u0432\u0435 PushLayer. \u0421\u043b\u043e\u0439 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0440\u0430\u0441\u0448\u0438\u0440\u044f\u0435\u0442\u0441\u044f \u043f\u0440\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438, \u043d\u043e \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0443\u043c\u0435\u043d\u044c\u0448\u0430\u0435\u0442\u0441\u044f<\/p>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0432\u0442\u043e\u0440\u043e\u0433\u043e \u043f\u0443\u043d\u043a\u0442\u0430:<\/p>\n<pre><code class=\"cpp\">D2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();pRenderTarget-&gt;PushLayer(layerParams, pLayer);<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435 D2D1_LAYER_PARAMETERS:<\/p>\n<pre><code class=\"java\">struct D2D1_LAYER_PARAMETERS {    D2D1_RECT_F contentBounds;          \/\/ \u041e\u0431\u043b\u0430\u0441\u0442\u044c \u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u044f \u043d\u0430 \u0441\u043b\u043e\u0435    ID2D1Geometry *geometricMask;       \/\/ \u041c\u0430\u0441\u043a\u0430-\u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u044f    D2D1_ANTIALIAS_MODE maskAntialiasMode; \/\/ \u0421\u0433\u043b\u0430\u0436\u0438\u0432\u0430\u043d\u0438\u0435 \u043c\u0430\u0441\u043a\u0438    D2D1_MATRIX_3X2_F maskTransform;    \/\/ \u0422\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u043c\u0430\u0441\u043a\u0438    FLOAT opacity;                      \/\/ \u041f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c \u0441\u043b\u043e\u044f (0.0 - 1.0)    ID2D1Brush *opacityBrush;           \/\/ \u041a\u0438\u0441\u0442\u044c \u0434\u043b\u044f \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438    D2D1_LAYER_OPTIONS layerOptions;    \/\/ \u0414\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043e\u043f\u0446\u0438\u0438. \u041d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Windows 8 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f D2D1_LAYER_OPTIONS1.};<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>layerOptions &#8212; \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043e\u043f\u0446\u0438\u0438 \u0441\u043b\u043e\u044f. \u041d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Windows 8 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f D2D1_LAYER_OPTIONS1  \u0441 \u043d\u043e\u0432\u044b\u043c\u0438 \u043e\u043f\u0446\u0438\u044f\u043c\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0433\u0443\u0442 \u0443\u043b\u0443\u0447\u0448\u0438\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c:<\/p>\n<p>D2D1_LAYER_OPTIONS1_INITIALIZE_FROM_BACKGROUND &#8212; Direct2D \u043d\u0435 \u043e\u0447\u0438\u0449\u0430\u0435\u0442 \u0441\u043b\u043e\u0439 \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u044b\u043c \u0447\u0451\u0440\u043d\u044b\u043c, \u0447\u0442\u043e \u0432 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0435 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u0434\u0430\u0451\u0442 \u043b\u0443\u0447\u0448\u0443\u044e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c.<\/p>\n<p>D2D1_LAYER_OPTIONS1_IGNORE_ALPHA &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u044f\u0442\u044c \u0430\u043b\u044c\u0444\u0430-\u043a\u0430\u043d\u0430\u043b \u0441\u043b\u043e\u044f (\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043a\u043e\u0433\u0434\u0430 \u0430\u043b\u044c\u0444\u0430-\u043a\u0430\u043d\u0430\u043b \u043d\u0435 \u043d\u0443\u0436\u0435\u043d).<\/p>\n<pre><code class=\"cpp\">\/\/ \u041f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u043d\u043e \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c\u044eD2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();layerParams.opacity = 0.5f; \/\/ 50% \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438m_pRenderTarget-&gt;PushLayer(layerParams, m_pLayer);\/\/ ... \u0437\u0434\u0435\u0441\u044c \u0440\u0438\u0441\u0443\u0435\u043c \u043d\u0430 \u0441\u043b\u043e\u0435 ...m_pRenderTarget-&gt;PopLayer();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0410 \u0432\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u043c\u0430\u0441\u043a\u0438 &#8212; \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0447\u0442\u043e\u0431\u044b \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0443 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u0440\u0443\u0433\u0430:<\/p>\n<pre><code class=\"cpp\">\/\/ \u041f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u0430\u044f \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u044f pCircleGeometryD2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();layerParams.geometricMask = pCircleGeometry;layerParams.maskAntialiasMode = D2D1_ANTIALIAS_MODE_PER_PRIMITIVE;m_pRenderTarget-&gt;PushLayer(layerParams, m_pLayer);\/\/ \u0420\u0438\u0441\u0443\u0435\u043c, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0443. \u041e\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0432\u0438\u0434\u043d\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u0440\u0443\u0433\u0430.m_pRenderTarget-&gt;PopLayer();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0442\u0440\u0435\u0442\u044c\u0435\u0433\u043e \u0448\u0430\u0433\u0430:<\/p>\n<p>\u041a\u043e\u0433\u0434\u0430 \u0432\u044b \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u043b\u0438 \u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u043d\u0430 \u0441\u043b\u043e\u0435:<\/p>\n<pre><code class=\"cpp\">m_pRenderTarget-&gt;PopLayer();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412 \u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0441\u043b\u043e\u044f \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0440\u0435\u043d\u0434\u0435\u0440-\u0442\u0430\u0440\u0433\u0435\u0442\u043e\u043c \u0441 \u0443\u0447\u0451\u0442\u043e\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432\u044b \u0437\u0430\u0434\u0430\u043b\u0438.<\/p>\n<p>\u041d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Windows 8, \u043f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u0440\u043e\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0432\u044b\u0437\u043e\u0432 CreateLayer \u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c nullptr \u0432 PushLayer &#8212; Direct2D \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u0440\u0435\u0441\u0443\u0440\u0441\u0430\u043c\u0438 \u0441\u043b\u043e\u044f:<\/p>\n<pre><code class=\"cpp\">\/\/ \u0412 Windows 8+ \u043c\u043e\u0436\u043d\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0441\u043b\u043e\u0439 \u044f\u0432\u043d\u043eD2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();layerParams.opacity = 0.6f;\/\/ \u041f\u0435\u0440\u0435\u0434\u0430\u0451\u043c nullptr \u2014 Direct2D \u0441\u0430\u043c \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u0438 \u0443\u043d\u0438\u0447\u0442\u043e\u0436\u0438\u0442 \u0441\u043b\u043e\u0439pRenderTarget-&gt;PushLayer(layerParams, nullptr);\/\/ ... \u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u0435 ...pRenderTarget-&gt;PopLayer();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0412\u0430\u0436\u043d\u043e\u0435 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435 \u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438. \u041a\u0430\u0436\u0434\u044b\u0439 \u0441\u043b\u043e\u0439 \u0442\u0440\u0435\u0431\u0443\u0435\u0442: \u043e\u0447\u0438\u0441\u0442\u043a\u0438 \u0441\u0432\u043e\u0435\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438, \u0432\u044b\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u043e\u0434 \u0431\u0443\u0444\u0435\u0440, \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u044f \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435\u043c. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u043b\u043e\u0438 \u0431\u0435\u0437 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 (\u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0430 \u043e\u0431\u0440\u0435\u0437\u0430\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u043c\u0430\u0441\u043a\u0443, \u0441\u043b\u043e\u0438 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0435 \u043d\u0443\u0436\u043d\u044b). <strong><em>\u0418 \u041d\u0415 \u0417\u0410\u0411\u042b\u0412\u0410\u0419\u0422\u0415 \u041e\u0421\u0412\u041e\u0411\u041e\u0416\u0414\u0410\u0422\u042c \u0421\u041b\u041e\u0419!<\/em><\/strong><\/p>\n<p>\u0412\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0430, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u043b\u043e\u0438<\/p>\n<pre><code class=\"cpp\">HRESULT RenderWithLayer(ID2D1RenderTarget* pRT, ID2D1Brush* pFillBrush, ID2D1Brush* pStrokeBrush){    HRESULT hr = S_OK;        \/\/ \u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0441\u043b\u043e\u0439     ID2D1Layer* pLayer = nullptr;    hr = pRT-&gt;CreateLayer(nullptr, &amp;pLayer);    if (FAILED(hr)) return hr;        \/\/ \u041d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0441\u043b\u043e\u044f    D2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();    layerParams.opacity = 0.6f;  \/\/ 60% \u043d\u0435\u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438    layerParams.contentBounds = D2D1::RectF(0, 0, 500, 400);        \/\/ \u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u0441\u043b\u043e\u0439    pRT-&gt;PushLayer(layerParams, pLayer);        \/\/ \u0420\u0438\u0441\u0443\u0435\u043c \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u043b\u043e\u044f    D2D1_RECT_F rect1 = D2D1::RectF(50.0f, 50.0f, 250.0f, 200.0f);    pRT-&gt;FillRectangle(rect1, pFillBrush);    pRT-&gt;DrawRectangle(rect1, pStrokeBrush, 2.0f);        D2D1_RECT_F rect2 = D2D1::RectF(150.0f, 100.0f, 350.0f, 250.0f);    pRT-&gt;FillRectangle(rect2, pFillBrush);    pRT-&gt;DrawRectangle(rect2, pStrokeBrush, 2.0f);        \/\/ \u0417\u0430\u0432\u0435\u0440\u0448\u0430\u0435\u043c \u0441\u043b\u043e\u0439    pRT-&gt;PopLayer();        \/\/ \u041e\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u043c \u0441\u043b\u043e\u0439    pLayer-&gt;Release();        return hr;}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p><strong>\u041e \u042d\u0424\u0424\u0415\u041a\u0422\u0410\u0425.<\/strong><\/p>\n<p>\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 \u044d\u0444\u0444\u0435\u043a\u0442 \u0432 Direct2D? \u042d\u0444\u0444\u0435\u043a\u0442 &#8212; \u044d\u0442\u043e \u0441\u043f\u043e\u0441\u043e\u0431 \u043c\u043e\u0434\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f (\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0438 \u0438\u0437\u043c\u0435\u043d\u044f\u0435\u0442 \u0435\u0433\u043e). \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c, \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0441\u0433\u043b\u0430\u0436\u0438\u0432\u0430\u043d\u0438\u0435 \u0438 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0434\u0440\u0443\u0433\u0438\u0445 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0439.<\/p>\n<p>API \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 \u043e\u0441\u043d\u043e\u0432\u0430\u043d \u043d\u0430 Direct3D 11 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 GPU \u0434\u043b\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439. \u041a\u0430\u0436\u0434\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0439 \u0433\u0440\u0430\u0444 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0439, \u0441\u043e\u0441\u0442\u043e\u044f\u0449\u0438\u0439 \u0438\u0437 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439. \u0412\u044b\u0445\u043e\u0434 \u043e\u0434\u043d\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u043f\u043e\u0434\u0430\u0451\u0442\u0441\u044f \u043d\u0430 \u0432\u0445\u043e\u0434 \u0434\u0440\u0443\u0433\u043e\u0433\u043e, \u0438 \u0442\u0430\u043a \u0434\u0430\u043b\u0435\u0435 &#8212; \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u043a\u043e\u043d\u0432\u0435\u0439\u0435\u0440 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439.<\/p>\n<p>\u041f\u0440\u0438\u043c\u0435\u0440\u044b \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 (\u0447\u0430\u0441\u0442\u044c \u0438\u0437 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u0441\u043f\u0438\u0441\u043a\u0430):<\/p>\n<p>\u042d\u0444\u0444\u0435\u043a\u0442\u044b \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f:<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">\u042d\u0444\u0444\u0435\u043a\u0442<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0413\u0430\u0443\u0441\u0441\u043e\u0432\u043e \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1GaussianBlur<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0420\u0430\u0437\u043c\u044b\u0432\u0430\u0435\u0442 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u2014 \u043e\u0441\u043d\u043e\u0432\u0430 \u0434\u043b\u044f \u043c\u043d\u043e\u0433\u0438\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0435 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1DirectionalBlur<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0420\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043f\u043e\u0434 \u0437\u0430\u0434\u0430\u043d\u043d\u044b\u043c \u0443\u0433\u043b\u043e\u043c (\u044d\u0444\u0444\u0435\u043a\u0442 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f)<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u042d\u0444\u0444\u0435\u043a\u0442\u044b \u0446\u0432\u0435\u0442\u043e\u043a\u043e\u0440\u0440\u0435\u043a\u0446\u0438\u0438:<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">\u042d\u0444\u0444\u0435\u043a\u0442<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0426\u0432\u0435\u0442\u043e\u0432\u0430\u044f \u043c\u0430\u0442\u0440\u0438\u0446\u0430<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1ColorMatrix<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0446\u0432\u0435\u0442\u043e\u0432 (\u0433\u0440\u0430\u0434\u0430\u0446\u0438\u0438 \u0441\u0435\u0440\u043e\u0433\u043e, \u0441\u0435\u043f\u0438\u044f)<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u042f\u0440\u043a\u043e\u0441\u0442\u044c<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1Brightness<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0420\u0435\u0433\u0443\u043b\u0438\u0440\u043e\u0432\u043a\u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u0438<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u044c<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1Contrast<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0420\u0435\u0433\u0443\u043b\u0438\u0440\u043e\u0432\u043a\u0430 \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1Saturation<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0418\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0446\u0432\u0435\u0442\u043e\u0432<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041e\u0442\u0442\u0435\u043d\u043a\u0438 \u0441\u0435\u0440\u043e\u0433\u043e<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1Grayscale<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0432 \u0447\u0451\u0440\u043d\u043e-\u0431\u0435\u043b\u043e\u0435<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u042d\u0444\u0444\u0435\u043a\u0442\u044b \u043a\u043e\u043c\u043f\u043e\u0437\u0438\u0442\u0438\u043d\u0433\u0430:<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">\u042d\u0444\u0444\u0435\u043a\u0442<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0422\u0435\u043d\u044c<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1Shadow<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0421\u043e\u0437\u0434\u0430\u0451\u0442 \u0442\u0435\u043d\u044c \u043e\u0442 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0421\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u0435<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1Blend<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0420\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0440\u0435\u0436\u0438\u043c\u044b \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u044f<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0410\u043b\u044c\u0444\u0430-\u043c\u0430\u0441\u043a\u0430<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1AlphaMask<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0430\u043b\u044c\u0444\u0430-\u043c\u0430\u0441\u043a\u0438<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0410\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043a\u043e\u043c\u043f\u043e\u0437\u0438\u0442<\/p>\n<\/td>\n<td>\n<p align=\"left\">CLSID_D2D1ArithmeticComposite<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0410\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u0435<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u0414\u0440\u0443\u0433\u0438\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b:<\/p>\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">\u042d\u0444\u0444\u0435\u043a\u0442<\/p>\n<\/td>\n<td data-colwidth=\"246\" width=\"246\">\n<p align=\"left\">CLSID<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041c\u043e\u0440\u0444\u043e\u043b\u043e\u0433\u0438\u044f<\/p>\n<\/td>\n<td data-colwidth=\"246\" width=\"246\">\n<p align=\"left\">CLSID_D2D1Morphology<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0420\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435\/\u0441\u0443\u0436\u0435\u043d\u0438\u0435 (\u0434\u0438\u043b\u0430\u0442\u0430\u0446\u0438\u044f\/\u044d\u0440\u043e\u0437\u0438\u044f)<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u0422\u0443\u0440\u0431\u0443\u043b\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u044c<\/p>\n<\/td>\n<td data-colwidth=\"246\" width=\"246\">\n<p align=\"left\">CLSID_D2D1Turbulence<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0413\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f \u0448\u0443\u043c\u0430 (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0434\u043b\u044f \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u043e\u0431\u043b\u0430\u043a\u043e\u0432)<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">\u041e\u0431\u043d\u0430\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0433\u0440\u0430\u043d\u0438\u0446<\/p>\n<\/td>\n<td data-colwidth=\"246\" width=\"246\">\n<p align=\"left\">CLSID_D2D1EdgeDetection<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u0412\u044b\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u0433\u0440\u0430\u043d\u0438\u0446 \u043d\u0430 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0438<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>\u041f\u043e\u043b\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a \u0432\u0441\u0435\u0445 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 \u0441 CLSID \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0432 <a href=\"https:\/\/learn.microsoft.com\/ru-ru\/windows\/win32\/direct2d\/built-in-effects\" rel=\"noopener noreferrer nofollow\">\u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 Microsoft<\/a>.<\/p>\n<p>\u041a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u044d\u0444\u0444\u0435\u043a\u0442\u0430\u043c\u0438 \u0414\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u044d\u0444\u0444\u0435\u043a\u0442\u0430\u043c\u0438 \u043d\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f ID2D1DeviceContext. \u0412\u0435\u0441\u044c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0437\u0431\u0438\u0442\u044c \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0448\u0430\u0433\u043e\u0432. \u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430 &#8212; \u044d\u0442\u043e \u043c\u044b \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u043b\u0438 \u0440\u0430\u043d\u0435\u0435. \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u043b\u0435\u0433\u043a\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442:<\/p>\n<pre><code class=\"cpp\">ComPtr&lt;ID2D1Effect&gt; gaussianBlurEffect;hr = d2dContext-&gt;CreateEffect(CLSID_D2D1GaussianBlur, &amp;gaussianBlurEffect);if (FAILED(hr)) {    \/\/ \u041e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043a\u0438}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c &#8212; \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0441\u0432\u043e\u0439\u0441\u0442\u0432. \u041a\u0430\u0436\u0434\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442 \u043e\u0431\u043b\u0430\u0434\u0430\u0435\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u043c \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432. \u0414\u043b\u044f \u0433\u0430\u0443\u0441\u0441\u043e\u0432\u0430 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0437\u0430\u0434\u0430\u0442\u044c StandardDeviation (\u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0435 \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u0435):<\/p>\n<pre><code class=\"cpp\">gaussianBlurEffect-&gt;SetValue(D2D1_GAUSSIANBLUR_PROP_STANDARD_DEVIATION, 5.0f);<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0421\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0433\u0430\u0443\u0441\u0441\u043e\u0432\u0430 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f:<\/p>\n<ul>\n<li>\n<p>D2D1_GAUSSIANBLUR_PROP_STANDARD_DEVIATION (float) &#8212; \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0435 \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u0435, \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d 0.0\u201320.0, \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e 3.0<\/p>\n<\/li>\n<li>\n<p>D2D1_GAUSSIANBLUR_PROP_OPTIMIZATION &#8212; \u0440\u0435\u0436\u0438\u043c \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438: SPEED, BALANCED (\u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e), QUALITY<\/p>\n<\/li>\n<li>\n<p>D2D1_GAUSSIANBLUR_PROP_BORDER_MODE &#8212; \u0440\u0435\u0436\u0438\u043c \u0433\u0440\u0430\u043d\u0438\u0446: SOFT (\u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e), HARD<\/p>\n<\/li>\n<\/ul>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0432\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f. \u0412\u0445\u043e\u0434\u043e\u043c \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c: ID2D1Bitmap , \u0434\u0440\u0443\u0433\u043e\u0439 ID2D1Effect (\u0447\u0435\u0440\u0435\u0437 SetInputEffect) , ID2D1Image (\u043e\u0431\u043e\u0431\u0449\u0451\u043d\u043d\u044b\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0434\u043b\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439)<\/p>\n<pre><code class=\"cpp\">\/\/ \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0431\u0438\u0442\u043c\u0430\u043fgaussianBlurEffect-&gt;SetInput(0, pBitmap);\/\/ \u0418\u043b\u0438 \u0435\u0441\u043b\u0438 \u0432\u044b \u0445\u043e\u0442\u0438\u0442\u0435 \u043f\u043e\u0434\u0430\u0442\u044c \u043d\u0430 \u0432\u0445\u043e\u0434 \u0434\u0440\u0443\u0433\u043e\u0439 \u044d\u0444\u0444\u0435\u043a\u0442\/\/ gaussianBlurEffect-&gt;SetInputEffect(0, previousEffect.Get());<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0420\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430. \u0412\u044b\u0445\u043e\u0434 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 &#8212; \u044d\u0442\u043e \u0442\u043e\u0436\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435, \u0438 \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0447\u0435\u0440\u0435\u0437 DrawImage:<\/p>\n<pre><code class=\"cpp\">d2dContext-&gt;BeginDraw();\/\/ \u041f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043a \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0443 (\u043e\u043f\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e)D2D1_POINT_2F targetOffset = D2D1::Point2F(100.0f, 100.0f);d2dContext-&gt;DrawImage(gaussianBlurEffect.Get(), targetOffset);d2dContext-&gt;EndDraw();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0418 \u0442\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e(\u043d\u0430\u0431\u0440\u043e\u0441\u043e\u043a \u043a\u043e\u0434\u0430) \u0442\u043e, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442:<\/p>\n<pre><code class=\"cpp\">HRESULT LoadBitmapFromFile(    ID2D1DeviceContext* pDC,    IWICImagingFactory* pWICFactory,    PCWSTR uri,    ID2D1Bitmap1** ppBitmap) {    IWICBitmapDecoder* pDecoder = nullptr;    HRESULT hr = pWICFactory-&gt;CreateDecoderFromFilename(        uri, nullptr, GENERIC_READ,        WICDecodeMetadataCacheOnLoad, &amp;pDecoder    );    if (FAILED(hr)) return hr;    IWICBitmapFrameDecode* pFrame = nullptr;    hr = pDecoder-&gt;GetFrame(0, &amp;pFrame);    if (FAILED(hr)) {        pDecoder-&gt;Release();        return hr;    }    IWICFormatConverter* pConverter = nullptr;    hr = pWICFactory-&gt;CreateFormatConverter(&amp;pConverter);    if (FAILED(hr)) {        pFrame-&gt;Release();        pDecoder-&gt;Release();        return hr;    }    hr = pConverter-&gt;Initialize(        pFrame,        GUID_WICPixelFormat32bppPBGRA,        WICBitmapDitherTypeNone,        nullptr,        0.0f,        WICBitmapPaletteTypeMedianCut    );    if (SUCCEEDED(hr)) {        D2D1_BITMAP_PROPERTIES1 props = D2D1::BitmapProperties1(            D2D1_BITMAP_OPTIONS_NONE,            D2D1::PixelFormat(DXGI_FORMAT_B8G8R8A8_UNORM, D2D1_ALPHA_MODE_PREMULTIPLIED)        );        hr = pDC-&gt;CreateBitmapFromWicBitmap(pConverter, props, ppBitmap);    }    pConverter-&gt;Release();    pFrame-&gt;Release();    pDecoder-&gt;Release();    return hr;}\/\/ \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435:ID2D1Bitmap1* pBitmap = nullptr;LoadBitmapFromFile(d2dContext.Get(), pWICFactory.Get(), L\"image.jpg\", &amp;pBitmap);\/\/ \u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u044d\u0444\u0444\u0435\u043a\u0442ComPtr&lt;ID2D1Effect&gt; blurEffect;d2dContext-&gt;CreateEffect(CLSID_D2D1GaussianBlur, &amp;blurEffect);blurEffect-&gt;SetInput(0, pBitmap);blurEffect-&gt;SetValue(D2D1_GAUSSIANBLUR_PROP_STANDARD_DEVIATION, 5.0f);d2dContext-&gt;BeginDraw();d2dContext-&gt;DrawImage(blurEffect.Get());d2dContext-&gt;EndDraw();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041e\u0434\u0438\u043d \u0438\u0437 \u043e\u0441\u043e\u0431\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 &#8212; \u0446\u0435\u043f\u043e\u0447\u043a\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432:<\/p>\n<pre><code class=\"cpp\">\/\/ \u042d\u0444\u0444\u0435\u043a\u0442 1: \u0420\u0430\u0437\u043c\u044b\u0442\u0438\u0435ComPtr&lt;ID2D1Effect&gt; blurEffect;d2dContext-&gt;CreateEffect(CLSID_D2D1GaussianBlur, &amp;blurEffect);blurEffect-&gt;SetValue(D2D1_GAUSSIANBLUR_PROP_STANDARD_DEVIATION, 3.0f);blurEffect-&gt;SetInput(0, pBitmap);\/\/ \u042d\u0444\u0444\u0435\u043a\u0442 2: \u0426\u0432\u0435\u0442\u043e\u0432\u0430\u044f \u043c\u0430\u0442\u0440\u0438\u0446\u0430 (\u0434\u0435\u043b\u0430\u0435\u043c \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0442\u0435\u043f\u043b\u0435\u0435)ComPtr&lt;ID2D1Effect&gt; colorEffect;d2dContext-&gt;CreateEffect(CLSID_D2D1ColorMatrix, &amp;colorEffect);\/\/ \u041c\u0430\u0442\u0440\u0438\u0446\u0430 \u0434\u043b\u044f \"\u0442\u0451\u043f\u043b\u043e\u0433\u043e\" \u043e\u0442\u0442\u0435\u043d\u043a\u0430D2D1_MATRIX_5X4_F warmMatrix = {    1.2f, 0.0f, 0.0f, 0.0f,    0.0f, 1.0f, 0.0f, 0.0f,    0.0f, 0.0f, 0.8f, 0.0f,    0.0f, 0.0f, 0.0f, 1.0f,    0.0f, 0.0f, 0.0f, 0.0f};colorEffect-&gt;SetValue(D2D1_COLORMATRIX_PROP_COLOR_MATRIX, warmMatrix);colorEffect-&gt;SetInputEffect(0, blurEffect.Get()); \/\/ \u0412\u0445\u043e\u0434 = \u0432\u044b\u0445\u043e\u0434 blurEffect\/\/ \u042d\u0444\u0444\u0435\u043a\u0442 3: \u0422\u0435\u043d\u044cComPtr&lt;ID2D1Effect&gt; shadowEffect;d2dContext-&gt;CreateEffect(CLSID_D2D1Shadow, &amp;shadowEffect);shadowEffect-&gt;SetInputEffect(0, colorEffect.Get());shadowEffect-&gt;SetValue(D2D1_SHADOW_PROP_BLUR_STANDARD_DEVIATION, 5.0f);shadowEffect-&gt;SetValue(D2D1_SHADOW_PROP_COLOR, D2D1::Vector4F(0.0f, 0.0f, 0.0f, 0.5f));\/\/ \u0420\u0438\u0441\u0443\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0432\u0441\u0435\u0439 \u0446\u0435\u043f\u043e\u0447\u043a\u0438d2dContext-&gt;BeginDraw();d2dContext-&gt;DrawImage(shadowEffect.Get());d2dContext-&gt;EndDraw();<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0418 \u0435\u0449\u0451 \u043e\u0434\u0438\u043d \u043f\u0440\u0438\u043c\u0435\u0440, \u0441\u043b\u043e\u0439 &#171;\u041c\u0430\u0442\u043e\u0432\u043e\u0435 \u0441\u0442\u0435\u043a\u043b\u043e&#187;:<\/p>\n<pre><code class=\"cpp\">void RenderFrostedGlass(ID2D1DeviceContext* pDC, ID2D1Bitmap1* pBackground){    \/\/ 1. \u0420\u0438\u0441\u0443\u0435\u043c \u0444\u043e\u043d    pDC-&gt;DrawBitmap(pBackground);    \/\/ 2. \u041e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u043c \u043e\u0431\u043b\u0430\u0441\u0442\u044c \u0441\u0442\u0435\u043a\u043b\u0430    D2D1_RECT_F glassRect = D2D1::RectF(200.0f, 150.0f, 600.0f, 350.0f);    \/\/ 3. \u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0431\u0438\u0442\u043c\u0430\u043f \u0441 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u044b\u043c \u0444\u043e\u043d\u0430 \u0432 \u044d\u0442\u043e\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438    \/\/ \u0412\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c \u0440\u0430\u0437\u043c\u0435\u0440 \u043e\u0431\u043b\u0430\u0441\u0442\u0438 \u0432 \u043f\u0438\u043a\u0441\u0435\u043b\u044f\u0445    D2D1_SIZE_U size = D2D1::SizeU(        static_cast&lt;UINT32&gt;(glassRect.right - glassRect.left),        static_cast&lt;UINT32&gt;(glassRect.bottom - glassRect.top)    );    ComPtr&lt;ID2D1Bitmap1&gt; pAreaBitmap;    D2D1_BITMAP_PROPERTIES1 props = D2D1::BitmapProperties1(        D2D1_BITMAP_OPTIONS_NONE,        D2D1::PixelFormat(DXGI_FORMAT_B8G8R8A8_UNORM, D2D1_ALPHA_MODE_PREMULTIPLIED)    );    HRESULT hr = pDC-&gt;CreateBitmap(size, nullptr, 0, props, &amp;pAreaBitmap);    if (FAILED(hr)) return;    \/\/ \u041a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0443\u044e \u043e\u0431\u043b\u0430\u0441\u0442\u044c \u0438\u0437 \u0444\u043e\u043d\u043e\u0432\u043e\u0433\u043e \u0431\u0438\u0442\u043c\u0430\u043f\u0430    D2D1_POINT_2U destPoint = D2D1::Point2U(0, 0);    D2D1_RECT_U srcRect = D2D1::RectU(        static_cast&lt;UINT32&gt;(glassRect.left),        static_cast&lt;UINT32&gt;(glassRect.top),        static_cast&lt;UINT32&gt;(glassRect.right),        static_cast&lt;UINT32&gt;(glassRect.bottom)    );    hr = pAreaBitmap-&gt;CopyFromBitmap(&amp;destPoint, pBackground, &amp;srcRect);    if (FAILED(hr)) return;    \/\/ 4. \u0421\u043e\u0437\u0434\u0430\u0451\u043c \u044d\u0444\u0444\u0435\u043a\u0442 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f    ComPtr&lt;ID2D1Effect&gt; blurEffect;    hr = pDC-&gt;CreateEffect(CLSID_D2D1GaussianBlur, &amp;blurEffect);    if (FAILED(hr)) return;        blurEffect-&gt;SetInput(0, pAreaBitmap.Get());    blurEffect-&gt;SetValue(D2D1_GAUSSIANBLUR_PROP_STANDARD_DEVIATION, 15.0f);    \/\/ 5. \u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0441\u043b\u043e\u0439 \u0441 \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c\u044e 0.8 \u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u0435\u0433\u043e    \/\/ (\u043f\u0435\u0440\u0435\u0434\u0430\u0451\u043c nullptr \u2014 Direct2D \u0441\u0430\u043c \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u0440\u0435\u0441\u0443\u0440\u0441\u0430\u043c\u0438 \u0441\u043b\u043e\u044f)    D2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters(glassRect);    layerParams.opacity = 0.8f;    pDC-&gt;PushLayer(layerParams, nullptr);    \/\/ 6. \u0420\u0438\u0441\u0443\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u043b\u043e\u044f    pDC-&gt;DrawImage(blurEffect.Get());    \/\/ 7. \u0417\u0430\u0432\u0435\u0440\u0448\u0430\u0435\u043c \u0441\u043b\u043e\u0439    pDC-&gt;PopLayer();}<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u0422\u0430\u043a \u043a\u0430\u043a \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u0447\u0430\u0441\u0442\u044c \u0443\u0436\u0435 \u0431\u044b\u043b\u0430 \u0438\u0437\u043b\u043e\u0436\u0435\u043d\u0430 \u0432 \u043f\u0440\u043e\u0448\u043b\u044b\u0445 \u0441\u0442\u0430\u0442\u044c\u044f\u0445, \u0442\u0435\u043f\u0435\u0440\u044c \u044f \u043c\u0435\u043d\u044c\u0448\u0435 \u043e\u0431\u0441\u0443\u0436\u0434\u0430\u044e \u043f\u043e\u0441\u0442\u0440\u043e\u0447\u043d\u043e &#8212; \u044d\u0442\u043e \u0432\u0441\u0451 \u0431\u044b\u043b\u043e \u0440\u0430\u043d\u044c\u0448\u0435. \u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435, \u043c\u044b \u043f\u043e\u0447\u0442\u0438 \u0443 \u0444\u0438\u043d\u0438\u0448\u0430. \u0422\u0435\u043f\u0435\u0440\u044c, \u043f\u043e \u0441\u0443\u0442\u0438, \u043f\u043e\u0439\u0434\u0443\u0442 \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u043d\u043e-\u0431\u044b\u0442\u043e\u0432\u044b\u0435 \u0432\u0435\u0449\u0438, \u043d\u043e \u0432 \u043d\u0443\u0436\u043d\u044b\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b \u0432\u044b \u0441\u043c\u043e\u0436\u0435\u0442\u0435 \u043e \u043d\u0438\u0445 \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0438 \u043e\u043d\u0438 \u043e\u0431\u043b\u0435\u0433\u0447\u0430\u0442 \u0432\u0430\u043c \u0436\u0438\u0437\u043d\u044c. \u0412\u043e\u0442 \u0438\u0445 \u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u0435: \u043c\u043d\u043e\u0433\u043e\u043f\u043e\u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c \u0438 Direct2D (\u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c, \u043a\u043e\u0433\u0434\u0430 \u0434\u043e\u0439\u0434\u0451\u043c \u0434\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0434\u0432\u0438\u0436\u043a\u0430 \u0438\u0433\u0440\u044b), \u0440\u0430\u0437\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u0440\u0435\u0441\u0443\u0440\u0441\u043e\u0432 \u043c\u0435\u0436\u0434\u0443 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430\u043c\u0438, \u0441\u0436\u0430\u0442\u0438\u0435 \u0431\u043b\u043e\u043a\u043e\u0432 (\u043f\u043e \u0441\u0443\u0442\u0438, \u0442\u0435\u043a\u0441\u0442\u0443\u0440), \u043f\u0440\u043e\u0444\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438 \u043e\u0442\u043b\u0430\u0434\u043a\u0430, \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435.<\/p>\n<p>\u0412\u0441\u0435\u043c \u0441\u043f\u043e\u043a\u043e\u0439\u043d\u043e\u0439 \u043d\u043e\u0447\u0438 \u0438\u043b\u0438 \u0443\u0434\u0430\u0447\u043d\u043e\u0433\u043e \u0434\u043d\u044f, \u0438 \u0443\u0434\u0430\u0447\u0438!<\/p>\n<p>\u041f\u0440\u0438 \u0436\u0435\u043b\u0430\u043d\u0438\u0438 \u043c\u0430\u0442\u0435\u0440\u0438\u0430\u043b\u044c\u043d\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0432\u043e\u0434 \u0438 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438\u00a0&#8212; \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0430 \u043c\u043e\u0436\u0435\u0442\u0435 \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u0447\u0435\u0440\u0435\u0437\u00a0<a href=\"https:\/\/yoomoney.ru\/fundraise\/1FC5LM5GP86.260118\" rel=\"noopener noreferrer nofollow\">\u0441\u0431\u043e\u0440 \u0432 \u042e\u041c\u0430\u043d\u0438<\/a>.<\/p>\n<\/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=\"https:\/\/habr.com\/ru\/articles\/1053086\/\">https:\/\/habr.com\/ru\/articles\/1053086\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u041e \u0421\u043b\u043e\u044f\u0445.\u0421\u043b\u043e\u0439 &#8212; \u044d\u0442\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f \u0446\u0435\u043b\u044c \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u044b \u0440\u0438\u0441\u0443\u0435\u0442\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e, \u0430 \u0437\u0430\u0442\u0435\u043c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0446\u0435\u043b\u044c \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430. \u0412 Direct2D \u0441\u043b\u043e\u0439 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u043c ID2D1Layer. \u041f\u043e\u0434\u043e\u0431\u043d\u043e \u043a\u0438\u0441\u0442\u044f\u043c, \u0441\u043b\u043e\u0438 \u0441\u043e\u0437\u0434\u0430\u044e\u0442\u0441\u044f \u0440\u0435\u043d\u0434\u0435\u0440-\u0442\u0430\u0440\u0433\u0435\u0442\u043e\u043c \u0438 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0440\u0435\u0441\u0443\u0440\u0441\u0430\u043c\u0438, \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u043c\u0438 \u043e\u0442 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430. \u0421\u043b\u043e\u0439 \u043c\u043e\u0436\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u043d\u043e\u0439 \u0446\u0435\u043b\u044c\u044e \u0440\u0435\u043d\u0434\u0435\u0440\u0438\u043d\u0433\u0430 \u0432 \u043e\u0434\u0438\u043d \u043c\u043e\u043c\u0435\u043d\u0442 \u0432\u0440\u0435\u043c\u0435\u043d\u0438. \u0415\u0441\u043b\u0438 \u0440\u0430\u0437\u043c\u0435\u0440 \u0441\u043b\u043e\u044f \u043d\u0435 \u0443\u043a\u0430\u0437\u0430\u043d \u043f\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438, \u043c\u0435\u0442\u043e\u0434 PushLayer \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442 \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0439 \u0440\u0430\u0437\u043c\u0435\u0440 \u043d\u0430 \u043e\u0441\u043d\u043e\u0432\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0433\u043e \u0438 \u043c\u0430\u0441\u043a\u0438. \u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u043e \u0441\u043b\u043e\u044f\u043c\u0438 (\u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u043e\u0431\u0449\u0438\u0439 \u043f\u043b\u0430\u043d):\u041f\u0440\u0438\u043c\u0435\u0440 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u043e \u0441\u043b\u043e\u044f\u043c\u0438 (\u0441\u043d\u0430\u0447\u0430\u043b\u0430 \u043e\u0431\u0449\u0438\u0439 \u043f\u043b\u0430\u043d):\u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0441\u043b\u043e\u0439 \u0447\u0435\u0440\u0435\u0437 CreateLayer\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0441\u043b\u043e\u0439 \u0447\u0435\u0440\u0435\u0437 PushLayer &#8212; \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b(\u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u044f) \u0431\u0443\u0434\u0443\u0442 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u0432 \u0441\u043b\u043e\u0439\u0414\u043e\u0441\u0442\u0430\u0451\u043c \u0441\u043b\u043e\u0439 \u0447\u0435\u0440\u0435\u0437 PopLayer &#8212; \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0441\u043b\u043e\u044f \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0446\u0435\u043b\u044c\u044e \u0440\u0435\u043d\u0434\u0435\u0440\u0430\u0412\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043f\u0443\u043d\u043a\u0442\u0430:\u0414\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0441\u043b\u043e\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 CreateLayer:ID2D1Layer* pLayer = nullptr;HRESULT hr = pRenderTarget-&gt;CreateLayer(nullptr, &amp;pLayer);if (FAILED(hr)) {    \/\/ \u041e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043a\u0438}\u041f\u0435\u0440\u0432\u044b\u0439 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 &#8212; \u0440\u0430\u0437\u043c\u0435\u0440 \u0441\u043b\u043e\u044f \u0432 \u043f\u0438\u043a\u0441\u0435\u043b\u044f\u0445. \u041f\u0440\u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u0447\u0435 nullptr \u0440\u0430\u0437\u043c\u0435\u0440 \u0431\u0443\u0434\u0435\u0442 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u0438 \u0432\u044b\u0437\u043e\u0432\u0435 PushLayer. \u0421\u043b\u043e\u0439 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0440\u0430\u0441\u0448\u0438\u0440\u044f\u0435\u0442\u0441\u044f \u043f\u0440\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438, \u043d\u043e \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0443\u043c\u0435\u043d\u044c\u0448\u0430\u0435\u0442\u0441\u044f\u0412\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0432\u0442\u043e\u0440\u043e\u0433\u043e \u043f\u0443\u043d\u043a\u0442\u0430:D2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();pRenderTarget-&gt;PushLayer(layerParams, pLayer);\u041e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0435 D2D1_LAYER_PARAMETERS:struct D2D1_LAYER_PARAMETERS {    D2D1_RECT_F contentBounds;          \/\/ \u041e\u0431\u043b\u0430\u0441\u0442\u044c \u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u044f \u043d\u0430 \u0441\u043b\u043e\u0435    ID2D1Geometry *geometricMask;       \/\/ \u041c\u0430\u0441\u043a\u0430-\u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u044f    D2D1_ANTIALIAS_MODE maskAntialiasMode; \/\/ \u0421\u0433\u043b\u0430\u0436\u0438\u0432\u0430\u043d\u0438\u0435 \u043c\u0430\u0441\u043a\u0438    D2D1_MATRIX_3X2_F maskTransform;    \/\/ \u0422\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u043c\u0430\u0441\u043a\u0438    FLOAT opacity;                      \/\/ \u041f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c \u0441\u043b\u043e\u044f (0.0 &#8212; 1.0)    ID2D1Brush *opacityBrush;           \/\/ \u041a\u0438\u0441\u0442\u044c \u0434\u043b\u044f \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438    D2D1_LAYER_OPTIONS layerOptions;    \/\/ \u0414\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043e\u043f\u0446\u0438\u0438. \u041d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Windows 8 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f D2D1_LAYER_OPTIONS1.};layerOptions &#8212; \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u043e\u043f\u0446\u0438\u0438 \u0441\u043b\u043e\u044f. \u041d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Windows 8 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f D2D1_LAYER_OPTIONS1  \u0441 \u043d\u043e\u0432\u044b\u043c\u0438 \u043e\u043f\u0446\u0438\u044f\u043c\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0433\u0443\u0442 \u0443\u043b\u0443\u0447\u0448\u0438\u0442\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c:D2D1_LAYER_OPTIONS1_INITIALIZE_FROM_BACKGROUND &#8212; Direct2D \u043d\u0435 \u043e\u0447\u0438\u0449\u0430\u0435\u0442 \u0441\u043b\u043e\u0439 \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u044b\u043c \u0447\u0451\u0440\u043d\u044b\u043c, \u0447\u0442\u043e \u0432 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0435 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u0434\u0430\u0451\u0442 \u043b\u0443\u0447\u0448\u0443\u044e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c.D2D1_LAYER_OPTIONS1_IGNORE_ALPHA &#8212; \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u044f\u0442\u044c \u0430\u043b\u044c\u0444\u0430-\u043a\u0430\u043d\u0430\u043b \u0441\u043b\u043e\u044f (\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043a\u043e\u0433\u0434\u0430 \u0430\u043b\u044c\u0444\u0430-\u043a\u0430\u043d\u0430\u043b \u043d\u0435 \u043d\u0443\u0436\u0435\u043d).\/\/ \u041f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u043d\u043e \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c\u044eD2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();layerParams.opacity = 0.5f; \/\/ 50% \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438m_pRenderTarget-&gt;PushLayer(layerParams, m_pLayer);\/\/ &#8230; \u0437\u0434\u0435\u0441\u044c \u0440\u0438\u0441\u0443\u0435\u043c \u043d\u0430 \u0441\u043b\u043e\u0435 &#8230;m_pRenderTarget-&gt;PopLayer();\u0410 \u0432\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u0447\u0435\u0441\u043a\u043e\u0439 \u043c\u0430\u0441\u043a\u0438 &#8212; \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0447\u0442\u043e\u0431\u044b \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0443 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u0440\u0443\u0433\u0430:\/\/ \u041f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u0430\u044f \u0433\u0435\u043e\u043c\u0435\u0442\u0440\u0438\u044f pCircleGeometryD2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();layerParams.geometricMask = pCircleGeometry;layerParams.maskAntialiasMode = D2D1_ANTIALIAS_MODE_PER_PRIMITIVE;m_pRenderTarget-&gt;PushLayer(layerParams, m_pLayer);\/\/ \u0420\u0438\u0441\u0443\u0435\u043c, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0443. \u041e\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0432\u0438\u0434\u043d\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u0440\u0443\u0433\u0430.m_pRenderTarget-&gt;PopLayer();\u0412\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0442\u0440\u0435\u0442\u044c\u0435\u0433\u043e \u0448\u0430\u0433\u0430:\u041a\u043e\u0433\u0434\u0430 \u0432\u044b \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u043b\u0438 \u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u043d\u0430 \u0441\u043b\u043e\u0435:m_pRenderTarget-&gt;PopLayer();\u0412 \u044d\u0442\u043e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0441\u043b\u043e\u044f \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0440\u0435\u043d\u0434\u0435\u0440-\u0442\u0430\u0440\u0433\u0435\u0442\u043e\u043c \u0441 \u0443\u0447\u0451\u0442\u043e\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0432\u044b \u0437\u0430\u0434\u0430\u043b\u0438.\u041d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Windows 8, \u043f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043f\u0440\u043e\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0432\u044b\u0437\u043e\u0432 CreateLayer \u0438 \u043f\u0435\u0440\u0435\u0434\u0430\u0442\u044c nullptr \u0432 PushLayer &#8212; Direct2D \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u0440\u0435\u0441\u0443\u0440\u0441\u0430\u043c\u0438 \u0441\u043b\u043e\u044f:\/\/ \u0412 Windows 8+ \u043c\u043e\u0436\u043d\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0441\u043b\u043e\u0439 \u044f\u0432\u043d\u043eD2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();layerParams.opacity = 0.6f;\/\/ \u041f\u0435\u0440\u0435\u0434\u0430\u0451\u043c nullptr \u2014 Direct2D \u0441\u0430\u043c \u0441\u043e\u0437\u0434\u0430\u0441\u0442 \u0438 \u0443\u043d\u0438\u0447\u0442\u043e\u0436\u0438\u0442 \u0441\u043b\u043e\u0439pRenderTarget-&gt;PushLayer(layerParams, nullptr);\/\/ &#8230; \u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u0435 &#8230;pRenderTarget-&gt;PopLayer();\u0412\u0430\u0436\u043d\u043e\u0435 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u0435 \u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438. \u041a\u0430\u0436\u0434\u044b\u0439 \u0441\u043b\u043e\u0439 \u0442\u0440\u0435\u0431\u0443\u0435\u0442: \u043e\u0447\u0438\u0441\u0442\u043a\u0438 \u0441\u0432\u043e\u0435\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438, \u0432\u044b\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u043e\u0434 \u0431\u0443\u0444\u0435\u0440, \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u044f \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435\u043c. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0435 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u043b\u043e\u0438 \u0431\u0435\u0437 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 (\u0442\u0435\u043a\u0441\u0442\u0443\u0440\u0430 \u043e\u0431\u0440\u0435\u0437\u0430\u0435\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 \u043c\u0430\u0441\u043a\u0443, \u0441\u043b\u043e\u0438 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0435 \u043d\u0443\u0436\u043d\u044b). \u0418 \u041d\u0415 \u0417\u0410\u0411\u042b\u0412\u0410\u0419\u0422\u0415 \u041e\u0421\u0412\u041e\u0411\u041e\u0416\u0414\u0410\u0422\u042c \u0421\u041b\u041e\u0419!\u0412\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0440\u0435\u043d\u0434\u0435\u0440\u0430, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0441\u043b\u043e\u0438HRESULT RenderWithLayer(ID2D1RenderTarget* pRT, ID2D1Brush* pFillBrush, ID2D1Brush* pStrokeBrush){    HRESULT hr = S_OK;        \/\/ \u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0441\u043b\u043e\u0439     ID2D1Layer* pLayer = nullptr;    hr = pRT-&gt;CreateLayer(nullptr, &amp;pLayer);    if (FAILED(hr)) return hr;        \/\/ \u041d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b \u0441\u043b\u043e\u044f    D2D1_LAYER_PARAMETERS layerParams = D2D1::LayerParameters();    layerParams.opacity = 0.6f;  \/\/ 60% \u043d\u0435\u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u0438    layerParams.contentBounds = D2D1::RectF(0, 0, 500, 400);        \/\/ \u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u0441\u043b\u043e\u0439    pRT-&gt;PushLayer(layerParams, pLayer);        \/\/ \u0420\u0438\u0441\u0443\u0435\u043c \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u043b\u043e\u044f    D2D1_RECT_F rect1 = D2D1::RectF(50.0f, 50.0f, 250.0f, 200.0f);    pRT-&gt;FillRectangle(rect1, pFillBrush);    pRT-&gt;DrawRectangle(rect1, pStrokeBrush, 2.0f);        D2D1_RECT_F rect2 = D2D1::RectF(150.0f, 100.0f, 350.0f, 250.0f);    pRT-&gt;FillRectangle(rect2, pFillBrush);    pRT-&gt;DrawRectangle(rect2, pStrokeBrush, 2.0f);        \/\/ \u0417\u0430\u0432\u0435\u0440\u0448\u0430\u0435\u043c \u0441\u043b\u043e\u0439    pRT-&gt;PopLayer();        \/\/ \u041e\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u043c \u0441\u043b\u043e\u0439    pLayer-&gt;Release();        return hr;}\u041e \u042d\u0424\u0424\u0415\u041a\u0422\u0410\u0425.\u0427\u0442\u043e \u0442\u0430\u043a\u043e\u0435 \u044d\u0444\u0444\u0435\u043a\u0442 \u0432 Direct2D? \u042d\u0444\u0444\u0435\u043a\u0442 &#8212; \u044d\u0442\u043e \u0441\u043f\u043e\u0441\u043e\u0431 \u043c\u043e\u0434\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f (\u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0438 \u0438\u0437\u043c\u0435\u043d\u044f\u0435\u0442 \u0435\u0433\u043e). \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e\u0441\u0442\u044c, \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0441\u0433\u043b\u0430\u0436\u0438\u0432\u0430\u043d\u0438\u0435 \u0438 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0434\u0440\u0443\u0433\u0438\u0445 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0439.API \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 \u043e\u0441\u043d\u043e\u0432\u0430\u043d \u043d\u0430 Direct3D 11 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 GPU \u0434\u043b\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439. \u041a\u0430\u0436\u0434\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0439 \u0433\u0440\u0430\u0444 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0439, \u0441\u043e\u0441\u0442\u043e\u044f\u0449\u0438\u0439 \u0438\u0437 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439. \u0412\u044b\u0445\u043e\u0434 \u043e\u0434\u043d\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u043f\u043e\u0434\u0430\u0451\u0442\u0441\u044f \u043d\u0430 \u0432\u0445\u043e\u0434 \u0434\u0440\u0443\u0433\u043e\u0433\u043e, \u0438 \u0442\u0430\u043a \u0434\u0430\u043b\u0435\u0435 &#8212; \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u043a\u043e\u043d\u0432\u0435\u0439\u0435\u0440 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439.\u041f\u0440\u0438\u043c\u0435\u0440\u044b \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 (\u0447\u0430\u0441\u0442\u044c \u0438\u0437 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u0441\u043f\u0438\u0441\u043a\u0430):\u042d\u0444\u0444\u0435\u043a\u0442\u044b \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f:\u042d\u0444\u0444\u0435\u043a\u0442CLSID\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442\u0413\u0430\u0443\u0441\u0441\u043e\u0432\u043e \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435CLSID_D2D1GaussianBlur\u0420\u0430\u0437\u043c\u044b\u0432\u0430\u0435\u0442 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u2014 \u043e\u0441\u043d\u043e\u0432\u0430 \u0434\u043b\u044f \u043c\u043d\u043e\u0433\u0438\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432\u041d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0435 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435CLSID_D2D1DirectionalBlur\u0420\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043f\u043e\u0434 \u0437\u0430\u0434\u0430\u043d\u043d\u044b\u043c \u0443\u0433\u043b\u043e\u043c (\u044d\u0444\u0444\u0435\u043a\u0442 \u0434\u0432\u0438\u0436\u0435\u043d\u0438\u044f)\u042d\u0444\u0444\u0435\u043a\u0442\u044b \u0446\u0432\u0435\u0442\u043e\u043a\u043e\u0440\u0440\u0435\u043a\u0446\u0438\u0438:\u042d\u0444\u0444\u0435\u043a\u0442CLSID\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442\u0426\u0432\u0435\u0442\u043e\u0432\u0430\u044f \u043c\u0430\u0442\u0440\u0438\u0446\u0430CLSID_D2D1ColorMatrix\u041f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0446\u0432\u0435\u0442\u043e\u0432 (\u0433\u0440\u0430\u0434\u0430\u0446\u0438\u0438 \u0441\u0435\u0440\u043e\u0433\u043e, \u0441\u0435\u043f\u0438\u044f)\u042f\u0440\u043a\u043e\u0441\u0442\u044cCLSID_D2D1Brightness\u0420\u0435\u0433\u0443\u043b\u0438\u0440\u043e\u0432\u043a\u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u0438\u041a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u044cCLSID_D2D1Contrast\u0420\u0435\u0433\u0443\u043b\u0438\u0440\u043e\u0432\u043a\u0430 \u043a\u043e\u043d\u0442\u0440\u0430\u0441\u0442\u0430\u041d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044cCLSID_D2D1Saturation\u0418\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0446\u0432\u0435\u0442\u043e\u0432\u041e\u0442\u0442\u0435\u043d\u043a\u0438 \u0441\u0435\u0440\u043e\u0433\u043eCLSID_D2D1Grayscale\u041f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0432 \u0447\u0451\u0440\u043d\u043e-\u0431\u0435\u043b\u043e\u0435\u042d\u0444\u0444\u0435\u043a\u0442\u044b \u043a\u043e\u043c\u043f\u043e\u0437\u0438\u0442\u0438\u043d\u0433\u0430:\u042d\u0444\u0444\u0435\u043a\u0442CLSID\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442\u0422\u0435\u043d\u044cCLSID_D2D1Shadow\u0421\u043e\u0437\u0434\u0430\u0451\u0442 \u0442\u0435\u043d\u044c \u043e\u0442 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f\u0421\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u0435CLSID_D2D1Blend\u0420\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0440\u0435\u0436\u0438\u043c\u044b \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u044f\u0410\u043b\u044c\u0444\u0430-\u043c\u0430\u0441\u043a\u0430CLSID_D2D1AlphaMask\u041f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435 \u0430\u043b\u044c\u0444\u0430-\u043c\u0430\u0441\u043a\u0438\u0410\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u043a\u043e\u043c\u043f\u043e\u0437\u0438\u0442CLSID_D2D1ArithmeticComposite\u0410\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u0441\u043c\u0435\u0448\u0438\u0432\u0430\u043d\u0438\u0435\u0414\u0440\u0443\u0433\u0438\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b:\u042d\u0444\u0444\u0435\u043a\u0442CLSID\u0427\u0442\u043e \u0434\u0435\u043b\u0430\u0435\u0442\u041c\u043e\u0440\u0444\u043e\u043b\u043e\u0433\u0438\u044fCLSID_D2D1Morphology\u0420\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435\/\u0441\u0443\u0436\u0435\u043d\u0438\u0435 (\u0434\u0438\u043b\u0430\u0442\u0430\u0446\u0438\u044f\/\u044d\u0440\u043e\u0437\u0438\u044f)\u0422\u0443\u0440\u0431\u0443\u043b\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u044cCLSID_D2D1Turbulence\u0413\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u044f \u0448\u0443\u043c\u0430 (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0434\u043b\u044f \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u043e\u0431\u043b\u0430\u043a\u043e\u0432)\u041e\u0431\u043d\u0430\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0433\u0440\u0430\u043d\u0438\u0446CLSID_D2D1EdgeDetection\u0412\u044b\u0434\u0435\u043b\u0435\u043d\u0438\u0435 \u0433\u0440\u0430\u043d\u0438\u0446 \u043d\u0430 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0438\u041f\u043e\u043b\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a \u0432\u0441\u0435\u0445 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 \u0441 CLSID \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 Microsoft.\u041a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441 \u044d\u0444\u0444\u0435\u043a\u0442\u0430\u043c\u0438 \u0414\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u044d\u0444\u0444\u0435\u043a\u0442\u0430\u043c\u0438 \u043d\u0430\u043c \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f ID2D1DeviceContext. \u0412\u0435\u0441\u044c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0437\u0431\u0438\u0442\u044c \u043d\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0448\u0430\u0433\u043e\u0432. \u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430 &#8212; \u044d\u0442\u043e \u043c\u044b \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u043b\u0438 \u0440\u0430\u043d\u0435\u0435. \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u043b\u0435\u0433\u043a\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442:ComPtr&lt;ID2D1Effect&gt; gaussianBlurEffect;hr = d2dContext-&gt;CreateEffect(CLSID_D2D1GaussianBlur, &amp;gaussianBlurEffect);if (FAILED(hr)) {    \/\/ \u041e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0448\u0438\u0431\u043a\u0438}\u0422\u0435\u043f\u0435\u0440\u044c &#8212; \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u0441\u0432\u043e\u0439\u0441\u0442\u0432. \u041a\u0430\u0436\u0434\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442 \u043e\u0431\u043b\u0430\u0434\u0430\u0435\u0442 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u043c \u043d\u0430\u0431\u043e\u0440\u043e\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432. \u0414\u043b\u044f \u0433\u0430\u0443\u0441\u0441\u043e\u0432\u0430 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0437\u0430\u0434\u0430\u0442\u044c StandardDeviation (\u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0435 \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u0435):gaussianBlurEffect-&gt;SetValue(D2D1_GAUSSIANBLUR_PROP_STANDARD_DEVIATION, 5.0f);\u0421\u0432\u043e\u0439\u0441\u0442\u0432\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0433\u0430\u0443\u0441\u0441\u043e\u0432\u0430 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f:D2D1_GAUSSIANBLUR_PROP_STANDARD_DEVIATION (float) &#8212; \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u043e\u0435 \u043e\u0442\u043a\u043b\u043e\u043d\u0435\u043d\u0438\u0435, \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d 0.0\u201320.0, \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e 3.0D2D1_GAUSSIANBLUR_PROP_OPTIMIZATION &#8212; \u0440\u0435\u0436\u0438\u043c \u043e\u043f\u0442\u0438\u043c\u0438\u0437\u0430\u0446\u0438\u0438: SPEED, BALANCED (\u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e), QUALITYD2D1_GAUSSIANBLUR_PROP_BORDER_MODE &#8212; \u0440\u0435\u0436\u0438\u043c \u0433\u0440\u0430\u043d\u0438\u0446: SOFT (\u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e), HARD\u0422\u0435\u043f\u0435\u0440\u044c \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0432\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f. \u0412\u0445\u043e\u0434\u043e\u043c \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c: ID2D1Bitmap , \u0434\u0440\u0443\u0433\u043e\u0439 ID2D1Effect (\u0447\u0435\u0440\u0435\u0437 SetInputEffect) , ID2D1Image (\u043e\u0431\u043e\u0431\u0449\u0451\u043d\u043d\u044b\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0434\u043b\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439)\/\/ \u0415\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0431\u0438\u0442\u043c\u0430\u043fgaussianBlurEffect-&gt;SetInput(0, pBitmap);\/\/ \u0418\u043b\u0438 \u0435\u0441\u043b\u0438 \u0432\u044b \u0445\u043e\u0442\u0438\u0442\u0435 \u043f\u043e\u0434\u0430\u0442\u044c \u043d\u0430 \u0432\u0445\u043e\u0434 \u0434\u0440\u0443\u0433\u043e\u0439 \u044d\u0444\u0444\u0435\u043a\u0442\/\/ gaussianBlurEffect-&gt;SetInputEffect(0, previousEffect.Get());\u0420\u0438\u0441\u043e\u0432\u0430\u043d\u0438\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430. \u0412\u044b\u0445\u043e\u0434 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 &#8212; \u044d\u0442\u043e \u0442\u043e\u0436\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435, \u0438 \u0435\u0433\u043e \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0447\u0435\u0440\u0435\u0437 DrawImage:d2dContext-&gt;BeginDraw();\/\/ \u041f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043a \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0443 (\u043e\u043f\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u043e)D2D1_POINT_2F targetOffset = D2D1::Point2F(100.0f, 100.0f);d2dContext-&gt;DrawImage(gaussianBlurEffect.Get(), targetOffset);d2dContext-&gt;EndDraw();\u0418 \u0442\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e(\u043d\u0430\u0431\u0440\u043e\u0441\u043e\u043a \u043a\u043e\u0434\u0430) \u0442\u043e, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442:HRESULT LoadBitmapFromFile(    ID2D1DeviceContext* pDC,    IWICImagingFactory* pWICFactory,    PCWSTR uri,    ID2D1Bitmap1** ppBitmap) {    IWICBitmapDecoder* pDecoder = nullptr;    HRESULT hr = pWICFactory-&gt;CreateDecoderFromFilename(        uri, nullptr, GENERIC_READ,        WICDecodeMetadataCacheOnLoad, &amp;pDecoder    );    if (FAILED(hr)) return hr;    IWICBitmapFrameDecode* pFrame = nullptr;    hr = pDecoder-&gt;GetFrame(0, &amp;pFrame);    if (FAILED(hr)) {        pDecoder-&gt;Release();        return hr;    }    IWICFormatConverter* pConverter = nullptr;    hr = pWICFactory-&gt;CreateFormatConverter(&amp;pConverter);    if (FAILED(hr)) {        pFrame-&gt;Release();        pDecoder-&gt;Release();        return hr;    }    hr = pConverter-&gt;Initialize(        pFrame,        GUID_WICPixelFormat32bppPBGRA,        WICBitmapDitherTypeNone,        nullptr,        0.0f,        WICBitmapPaletteTypeMedianCut    );    if (SUCCEEDED(hr)) {        D2D1_BITMAP_PROPERTIES1 props = D2D1::BitmapProperties1(            D2D1_BITMAP_OPTIONS_NONE,            D2D1::PixelFormat(DXGI_FORMAT_B8G8R8A8_UNORM, D2D1_ALPHA_MODE_PREMULTIPLIED)        );        hr = pDC-&gt;CreateBitmapFromWicBitmap(pConverter, props, ppBitmap);    }    pConverter-&gt;Release();    pFrame-&gt;Release();    pDecoder-&gt;Release();    return hr;}\/\/ \u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435:ID2D1Bitmap1* pBitmap = nullptr;LoadBitmapFromFile(d2dContext.Get(),&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-485375","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/485375","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=485375"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/485375\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=485375"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=485375"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=485375"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}