{"id":323531,"date":"2021-05-21T09:00:49","date_gmt":"2021-05-21T09:00:49","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=323531"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=323531","title":{"rendered":"\u0422\u043e, \u0447\u0435\u0433\u043e \u043d\u0430\u043c \u0442\u0430\u043a \u043d\u0435 \u0445\u0432\u0430\u0442\u0430\u043b\u043e: Render Effect \u0432 Android 12"},"content":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<p>\u0418\u043d\u043e\u0433\u0434\u0430 \u0431\u044b\u0432\u0430\u0435\u0442 \u043d\u0443\u0436\u043d\u043e \u0440\u0430\u0437\u043c\u044b\u0442\u044c \u0437\u0430\u0434\u043d\u0438\u0439 \u043f\u043b\u0430\u043d \u043d\u0430 \u044d\u043a\u0440\u0430\u043d\u0430\u0445 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0432 \u0447\u0430\u0442\u0435. \u0422\u0435\u043f\u0435\u0440\u044c \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u0441\u0435\u0433\u043e \u043f\u0430\u0440\u043e\u0439 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430. \u0412 Android 12 \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u043d\u043e\u0432\u044b\u0439 API <a href=\"https:\/\/developer.android.com\/reference\/android\/graphics\/RenderEffect\"><u>Render Effect<\/u><\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0442\u044c \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u043d\u0430 Canvas \u0438\u043b\u0438 View. \u042d\u0442\u043e\u0442 API \u0440\u0430\u0434\u0443\u0435\u0442 \u0441\u0432\u043e\u0435\u0439 \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u043e\u0439 \u0438 \u0432\u044b\u0441\u043e\u043a\u043e\u0439 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c\u044e \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438. \u041d\u0430\u0438\u0431\u043e\u043b\u044c\u0448\u0438\u0439 \u0438\u043d\u0442\u0435\u0440\u0435\u0441 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 Render Effect \u0434\u043b\u044f&nbsp;\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f (BlurEffect), \u043d\u043e \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0437\u0430\u0442\u0440\u043e\u043d\u0435\u043c \u0438 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u0432\u0438\u0434\u044b \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432. \u041c\u0430\u0442\u0435\u0440\u0438\u0430\u043b \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043f\u043e\u043b\u0435\u0437\u0435\u043d \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0430\u043d\u0434\u0440\u043e\u0438\u0434-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c, \u043d\u043e \u0438 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0430\u043c \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/1f2\/9b4\/2be\/1f29b42bed7b7dc686fc518bd92731e8.png\" alt=\"\" title=\"\" width=\"780\" height=\"440\"><figcaption><\/figcaption><\/figure>\n<p>\u0418\u0442\u0430\u043a, \u043a\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0437\u043c\u044b\u0442\u044c \u0437\u0430\u0434\u043d\u0438\u0439 \u043f\u043b\u0430\u043d \u043f\u0440\u0438 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0438 \u0434\u0438\u0430\u043b\u043e\u0433\u0430? \u0420\u0430\u043d\u044c\u0448\u0435 \u0432 \u0410\u043d\u0434\u0440\u043e\u0438\u0434\u0435 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0430\u0434\u043e \u0431\u044b\u043b\u043e \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0432\u0441\u0435 \u0432\u044c\u044e \u0441 \u0437\u0430\u0434\u043d\u0435\u0433\u043e \u043f\u043b\u0430\u043d\u0430 \u043d\u0430 bitmap-\u0435 \u0438 \u0437\u0430\u0442\u0435\u043c \u0440\u0430\u0437\u043c\u044b\u0442\u044c \u0435\u0433\u043e \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RenderScript \u0438\u043b\u0438 OpenGL. \u041d\u043e \u044d\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u043d\u0435\u043c\u0430\u043b\u043e \u0437\u0430\u043f\u0443\u0442\u0430\u043d\u043d\u043e\u0433\u043e \u0434\u043b\u044f \u043f\u0440\u043e\u0447\u0442\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430, \u043b\u0438\u0431\u043e \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u044e\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0434\u043b\u044f \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f. \u041f\u043b\u044e\u0441 \u0434\u043e\u0431\u0430\u0432\u044f\u0442\u0441\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u0439 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u0438 \u043a\u043e\u0434 \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0431\u0438\u0442\u043c\u0430\u043f\u0430. \u041a \u0442\u043e\u043c\u0443 \u0436\u0435 \u043f\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u044d\u0442\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u043c\u043e\u0433\u0443\u0442 \u043d\u0435 \u0434\u0430\u0432\u0430\u0442\u044c \u0436\u0435\u043b\u0430\u0435\u043c\u043e\u0433\u043e \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430. \u041f\u0440\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a \u0434\u043b\u044f \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0437\u0430\u043c\u0435\u0447\u0430\u044e\u0442 \u043b\u0430\u0433\u0438, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0435\u0441\u043b\u0438 \u0435\u0441\u0442\u044c RecyclerView, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u043c\u043d\u043e\u0433\u043e BlurView.<\/p>\n<p>\u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Render Effect \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0432\u0441\u0435\u0433\u043e \u043f\u0430\u0440\u043e\u0439 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0431\u043b\u044e\u0440 \u0431\u0435\u0437 \u043b\u0430\u0433\u043e\u0432. Render Effect \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e \u0437\u0430 \u0441\u0447\u0435\u0442 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043e\u043d \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 <strong>Render Nodes<\/strong> (\u0443\u0437\u043b\u044b \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438). \u041e\u043d\u0438 \u043e\u0431\u0440\u0430\u0437\u0443\u044e\u0442 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u044e \u0430\u043f\u043f\u0430\u0440\u0430\u0442\u043d\u043e \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u043d\u043e\u0439 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438, \u0438 \u044d\u0442\u0430 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e GPU (\u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u0430). \u041f\u0435\u0440\u0435\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0431\u0443\u0434\u0443\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435 \u0447\u0430\u0441\u0442\u0438 UI, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u043a\u0430\u0437\u0430\u043b\u0438\u0441\u044c \u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 invalidated. \u0412\u0441\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0434\u043b\u044f Render Effect \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0432 Render \u043f\u043e\u0442\u043e\u043a\u0435 \u0438 \u043d\u0435 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0442 UI.&nbsp;<\/p>\n<p>\u0423 Render Effect \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e\u0439 API:<\/p>\n<pre><code class=\"kotlin\">val renderNode = RenderNode(\"myRenderNode\") renderNode.setPosition(0, 0, 50, 50) renderNode.setRenderEffect(renderEffect)  canvas.drawRenderNode(renderNode)<\/code><\/pre>\n<p>\u041c\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 \u044d\u0444\u0444\u0435\u043a\u0442 \u0434\u043b\u044f RenderNode \u043c\u0435\u0442\u043e\u0434\u043e\u043c setRenderEffect(), \u0438 \u0435\u0433\u043e \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 Canvas.drawRenderNode().<\/p>\n<p>\u041c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c Render Effect \u0438 \u043a \u0443\u0437\u043b\u0443 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u0432\u044c\u044e\u0448\u043a\u0438:<\/p>\n<pre><code class=\"julia\">imageView.setRenderEffect(renderEffect)<\/code><\/pre>\n<p>\u041f\u0440\u0438\u0432\u0435\u0434\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u044d\u0444\u0444\u0435\u043a\u0442\u0430:  <\/p>\n<pre><code class=\"kotlin\">val blurEffect = RenderEffect.createBlurEffect(        20f, \/\/radiusX        20f, \/\/radiusY               Shader.TileMode.CLAMP ) imageView.setRenderEffect(blurEffect)<\/code><\/pre>\n<p>\u0417\u0434\u0435\u0441\u044c \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u044d\u0444\u0444\u0435\u043a\u0442 <strong>\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f<\/strong> \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0435\u0433\u043e \u043a \u0443\u0437\u043b\u0443 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438, \u043f\u0440\u0438\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u043c\u0443 \u043a imageView. \u0417\u0430\u0434\u0430\u0435\u043c \u0438\u043d\u0442\u0435\u043d\u0441\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u043f\u043e \u043e\u0441\u0438 X \u0438 \u043e\u0441\u0438 Y (\u0417\u043d\u0430\u0447\u0435\u043d\u0438\u044f 20f) . \u041f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442 \u2013 Shader.TileMode \u2013 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442 \u0442\u043e, \u043a\u0430\u043a \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442 \u043d\u0430 \u043a\u0440\u0430\u044f\u0445 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u043c\u043e\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e75\/8d3\/736\/e758d3736b630448c22ababff576cee1.png\" width=\"1498\" height=\"1306\"><figcaption><\/figcaption><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043a \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u043c\u0443 layout-\u0443, \u0442\u043e \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0437\u043c\u044b\u0442\u044b \u0432\u0441\u0435 \u0432\u044c\u044e\u0448\u043a\u0438: \u0438 \u043a\u043d\u043e\u043f\u043a\u0430, \u0438 \u043f\u043e\u043b\u0437\u0443\u043d\u043a\u0438.<\/p>\n<p>\u0412\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 <a href=\"https:\/\/developer.android.com\/reference\/android\/graphics\/Shader.TileMode\">TileMode<\/a>:<\/p>\n<ul>\n<li>\n<p><strong>MIRROR<\/strong>.<strong> <\/strong>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0437\u0435\u0440\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u0442\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043f\u043e \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u0438 \u0438 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438, \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043d\u0430 \u0433\u0440\u0430\u043d\u0438\u0446\u0430\u0445 \u043d\u0435\u0442 \u0440\u0435\u0437\u043a\u0438\u0445 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u043e\u0432.   <\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/57c\/c88\/0ff\/57cc880ff7f04b972863e3c386be4268.png\" width=\"391\" height=\"728\"><figcaption><\/figcaption><\/figure>\n<ul>\n<li>\n<p><strong>CLAMP<\/strong>. \u0415\u0441\u043b\u0438 shader \u0432\u044b\u0445\u043e\u0434\u0438\u0442 \u0437\u0430 \u043f\u0440\u0435\u0434\u0435\u043b\u044b \u0433\u0440\u0430\u043d\u0438\u0446, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0446\u0432\u0435\u0442 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u043d\u0430 \u0433\u0440\u0430\u043d\u0438\u0446\u0435. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0442\u0430\u043a\u0436\u0435 \u043a\u0430\u043a MIRROR, \u043d\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u043d\u0435\u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0438\u0441\u043a\u0430\u0436\u0435\u043d\u0438\u0435 \u0444\u043e\u0440\u043c\u044b \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0432\u043e\u0437\u043b\u0435 \u0433\u0440\u0430\u043d\u0438\u0446\u044b.    <\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b36\/ee6\/47b\/b36ee647b5984d4a5a3c4ff3cd4bb3af.png\" width=\"386\" height=\"726\"><figcaption><\/figcaption><\/figure>\n<ul>\n<li>\n<p><strong>REPEAT<\/strong>. \u0418\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u0442\u0441\u044f \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e \u0438 \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u043e. \u041d\u0430 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0438 \u0437\u0430\u043c\u0435\u0442\u043d\u043e, \u043a\u0430\u043a \u0442\u0435\u043c\u043d\u0430\u044f \u0432\u043e\u0434\u0430 \u0438\u0437 \u043d\u0438\u0436\u043d\u0435\u0439 \u0447\u0430\u0441\u0442\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043e\u0442\u0440\u0430\u0437\u0438\u043b\u0430\u0441\u044c \u043d\u0430&nbsp; \u0432\u0435\u0440\u0445\u043d\u0435\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f.<\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/066\/be5\/bb8\/066be5bb85b836a308faa2ba09ab5783.png\" width=\"384\" height=\"726\"><figcaption><\/figcaption><\/figure>\n<ul>\n<li>\n<p><strong>DECAL<\/strong> (\u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u0432 API 31). \u041e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 shader-\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u0445 \u0433\u0440\u0430\u043d\u0438\u0446. \u041c\u043e\u0436\u043d\u043e \u0437\u0430\u043c\u0435\u0442\u0438\u0442\u044c, \u0447\u0442\u043e \u043d\u0430 \u0433\u0440\u0430\u043d\u0438\u0446\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0441\u0442\u0430\u043b\u043e \u0447\u0443\u0442\u044c \u0441\u0432\u0435\u0442\u043b\u0435\u0435.  <\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/9d8\/8d5\/6cd\/9d88d56cdee29683d48f03038941f98e.png\" width=\"386\" height=\"725\"><figcaption><\/figcaption><\/figure>\n<p>\u041c\u044b \u0442\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043f\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 <strong>\u0442\u0435\u043d\u0438<\/strong>. \u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0442\u0435\u043d\u044c \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 Elevation:   <\/p>\n<pre><code class=\"xml\">android:elevation=\"10dp\"<\/code><\/pre>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/7f6\/a13\/f1f\/7f6a13f1fe448036cc275c2d6bc90360.png\" width=\"510\" height=\"294\"><figcaption><\/figcaption><\/figure>\n<p>\u041e\u0434\u043d\u0430\u043a\u043e, \u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043c\u044b \u043d\u0435 \u0441\u043c\u043e\u0436\u0435\u043c \u0437\u0430\u0434\u0430\u0432\u0430\u0442\u044c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0434\u043e\u043b\u0436\u043d\u0430 \u043e\u0442\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u0435\u043d\u044c, \u0438\u043b\u0438 \u0435\u0435 \u0446\u0432\u0435\u0442. \u0422\u0430\u043a\u0436\u0435 \u0442\u0435\u043d\u044c \u0434\u043b\u044f Elevation \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0441 \u0444\u043e\u0440\u043c\u0430\u043c\u0438 \u0441\u043a\u0440\u0443\u0433\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430 (\u043a\u0440\u0443\u0433 \u0438 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a \u2013 \u0447\u0430\u0441\u0442\u043d\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0438 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430 \u0441\u043e \u0441\u043a\u0440\u0443\u0433\u043b\u0435\u043d\u043d\u044b\u043c\u0438 \u0443\u0433\u043b\u0430\u043c\u0438). \u0414\u043b\u044f \u0442\u0435\u043d\u0438 \u0434\u0440\u0443\u0433\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u043d\u0443\u0436\u043d\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c ViewOutlineProvider, \u0447\u0442\u043e\u0431\u044b \u043e\u043d \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u043b Outline \u0441 setPath(&#8230;), \u0430 \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0432\u0435\u0441\u044c\u043c\u0430 \u0442\u0440\u0443\u0434\u043e\u0435\u043c\u043a\u043e.<\/p>\n<p>\u041a\u0430\u0441\u0442\u043e\u043c\u043d\u0443\u044e \u0442\u0435\u043d\u044c \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0438 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e xml, \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u0432 &lt;shape&gt; \u0441 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043e\u043c:<\/p>\n<pre><code class=\"xml\">&lt;gradient        android:type=\"radial\"        android:centerColor=\"#90000000\"        android:gradientRadius=\"70dp\"        android:startColor=\"@android:color\/white\"        android:endColor=\"@android:color\/transparent\"\/&gt;<\/code><\/pre>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/985\/23c\/e9e\/98523ce9e6d9e0a054f85e0afea0c914.png\" width=\"504\" height=\"314\"><figcaption><\/figcaption><\/figure>\n<p>\u041c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0442\u0435\u043d\u044c \u043a\u0440\u0443\u0433\u043b\u043e\u0439 \u0444\u043e\u0440\u043c\u044b, \u043b\u043e\u0436\u0430\u0449\u0443\u044e\u0441\u044f \u043e\u0442 \u0431\u0435\u043b\u043e\u0433\u043e \u043a\u0440\u0443\u0433\u0430 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u0432\u043e \u0432\u0441\u0435\u0445 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f\u0445 \u2013 \u0442\u043e \u0435\u0441\u0442\u044c \u0441\u0432\u0435\u0440\u0445\u0443 \u043e\u043d\u0430 \u0442\u0430\u043a\u043e\u0439 \u0436\u0435 \u0434\u043b\u0438\u043d\u044b, \u0447\u0442\u043e \u0438 \u0441\u043d\u0438\u0437\u0443. \u041d\u043e \u043c\u044b \u0432\u0441\u0435 \u0436\u0435 \u043d\u0435 \u0441\u043c\u043e\u0436\u0435\u043c \u0442\u0430\u043a\u0438\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0435\u043d\u044c \u0441\u043b\u043e\u0436\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b.<\/p>\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0434\u043b\u044f \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f \u043f\u043e\u043a\u0430\u0436\u0435\u043c, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u0443\u044e \u0442\u0435\u043d\u044c \u043a\u0440\u0443\u0433\u043b\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RenderEffect. \u0421\u043e\u0437\u0434\u0430\u0435\u043c \u043a\u0440\u0443\u0433 \u0441\u0435\u0440\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430:<\/p>\n<pre><code class=\"xml\">&lt;shape android:shape=\"oval\"&gt;    &lt;solid android:color=\"#CCCCCC\" \/&gt; &lt;\/shape&gt;<\/code><\/pre>\n<p>\u0417\u0430\u0442\u0435\u043c \u044d\u0442\u043e\u0442 drawable \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0433\u043e ImageView \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043a ImageView:<\/p>\n<pre><code class=\"kotlin\">imageView.setImageResource(R.drawable.gray_circle) val renderEffect = RenderEffect.createBlurEffect(20f, 20f, Shader.TileMode.CLAMP) imageView.setRenderEffect(renderEffect)<\/code><\/pre>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/208\/9fa\/54c\/2089fa54cf5b41aa3bf5661723dec6b1.png\" width=\"492\" height=\"294\"><figcaption><\/figcaption><\/figure>\n<p>\u0410 \u0432\u043e\u0442 \u043a\u0430\u043a \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RenderEffect \u043c\u043e\u0436\u043d\u043e \u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u0442\u0435\u043d\u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0438, \u0435\u0441\u043b\u0438 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f, \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430:<\/p>\n<pre><code class=\"xml\">&lt;ImageView    android:id=\"@+id\/shadow\"    android:layout_width=\"150dp\"    android:layout_height=\"150dp\"    android:src=\"@drawable\/ic_baseline_time_to_leave_24\"    android:tint=\"#444444\"\/&gt;<\/code><\/pre>\n<pre><code class=\"kotlin\">val effect = RenderEffect.createBlurEffect(10f, 10f, Shader.TileMode.CLAMP) imageViewfindViewById&lt;ImageView&gt;(R.id.shadow).setRenderEffect(effect)<\/code><\/pre>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c88\/10c\/a72\/c8810ca7299ceb6232d220588f240e0c.png\" width=\"352\" height=\"358\"><figcaption><\/figcaption><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u0441 \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 \u0440\u0430\u0434\u0438\u0443\u0441\u0430, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, 20 \u043f\u043e \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438 \u0438 0 \u043f\u043e \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u0438, \u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u044d\u0444\u0444\u0435\u043a\u0442, \u043f\u043e\u0445\u043e\u0436\u0438\u0439 \u043d\u0430 <strong>\u0441\u043c\u0430\u0437\u0430\u043d\u043d\u044b\u0439 \u0441\u043d\u0438\u043c\u043e\u043a<\/strong>.  <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/f46\/ba1\/509\/f46ba15095c87d456c6c3605748a4a42.png\" width=\"900\" height=\"1600\"><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0441\u0435\u0433\u043e \u0435\u0441\u0442\u044c \u0441\u0435\u043c\u044c \u0432\u0438\u0434\u043e\u0432 RenderEffect:<\/p>\n<ul>\n<li>\n<p><strong>Bitmap<\/strong> \u2013 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0431\u0438\u0442\u043c\u0430\u043f\u0430. \u041e\u0431\u044b\u0447\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0432 \u0446\u0435\u043f\u043e\u0447\u043a\u0435 \u0434\u043b\u044f \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p><strong>Blur<\/strong> \u2013 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043f\u043e \u043e\u0441\u0438 X \u0438 Y.<\/p>\n<\/li>\n<li>\n<p><strong>ColorFilter<\/strong> \u2013 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0446\u0432\u0435\u0442\u043d\u043e\u0439 \u0444\u0438\u043b\u044c\u0442\u0440 (\u0441\u043c. \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442 \u043d\u0438\u0436\u0435).<\/p>\n<\/li>\n<li>\n<p><strong>Offset <\/strong>\u2013 \u0441\u0434\u0432\u0438\u0433 \u043f\u043e \u043e\u0441\u044f\u043c X, Y (\u0436\u0430\u043b\u044c, \u0447\u0442\u043e \u043d\u0435\u0442 \u043f\u043e\u0432\u043e\u0440\u043e\u0442\u0430).<\/p>\n<\/li>\n<li>\n<p><strong>Shader<\/strong> \u2013 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u0442 \u0448\u0435\u0439\u0434\u0435\u0440, \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0439 \u0432 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430\u0445. \u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432 \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440,&nbsp; \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u044b.<\/p>\n<\/li>\n<li>\n<p><strong>Chain<\/strong> \u2013 \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u044f 2 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432. \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u043e\u0434\u043d\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043a\u0430\u043a \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a \u0434\u043b\u044f \u0432\u0442\u043e\u0440\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430.<\/p>\n<\/li>\n<li>\n<p><strong>BlendMode<\/strong> \u2013 \u0434\u043b\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f 2 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435.<\/p>\n<\/li>\n<\/ul>\n<p>\u041c\u043e\u0436\u043d\u043e \u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u043a\u0440\u0430\u0441\u0438\u0432\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u201c<strong>\u0437\u0430\u043c\u0435\u0440\u0437\u0448\u0435\u0433\u043e \u0441\u0442\u0435\u043a\u043b\u0430<\/strong>\u201d (\u0438\u043b\u0438 \u201c\u0437\u0430\u043f\u043e\u0442\u0435\u0432\u0448\u0435\u0433\u043e \u043e\u043a\u043d\u0430\u201d): \u043e\u043d \u0434\u043e\u0441\u0442\u0438\u0433\u0430\u0435\u0442\u0441\u044f \u0441\u043e\u0447\u0435\u0442\u0430\u043d\u0438\u0435\u043c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u0438 \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e-\u0431\u0435\u043b\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/eae\/489\/e76\/eae489e76715fa0be37b371b0ac781b0.png\" width=\"900\" height=\"1600\"><figcaption><\/figcaption><\/figure>\n<p>\u041f\u0440\u0438\u043c\u0435\u043d\u0438\u043c \u0442\u0430\u043a\u043e\u0439 \u044d\u0444\u0444\u0435\u043a\u0442 \u043a \u043f\u0430\u043d\u0435\u043b\u0438 \u0432\u043d\u0438\u0437\u0443 \u044d\u043a\u0440\u0430\u043d\u0430. \u0424\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0437\u0434\u0435\u0441\u044c \u043d\u0430\u0434\u043e \u0441\u043e\u0447\u0435\u0442\u0430\u0442\u044c \u0442\u0440\u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u0430: \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 \u0431\u0438\u0442\u043c\u0430\u043f\u0430 + \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 + \u0446\u0432\u0435\u0442\u043d\u043e\u0439 \u0444\u0438\u043b\u044c\u0442\u0440. \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043d\u0435\u043b\u044c\u0437\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043c\u044b\u0432\u0430\u043b\u0430\u0441\u044c \u0442\u0430 \u0447\u0430\u0441\u0442\u044c UI, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0430 \u043f\u043e\u0434 \u0432\u044c\u044e\u0448\u043a\u043e\u0439. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 RenderEffect \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u043d\u0435 \u043a \u0441\u0430\u043c\u043e\u0439 \u043f\u0430\u043d\u0435\u043b\u0438, \u0430 \u043a \u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u043e\u0434 \u043d\u0435\u0439 \u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0444\u043e\u043d\u043e\u0432\u043e\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435: \u043a imageView \u0438\u043b\u0438 \u043a \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u043c\u0443 layout-\u0443. \u041a\u043e\u043c\u0431\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u043c\u043e\u0436\u043d\u043e 2 \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u043c\u0438: \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u043e\u0434\u0438\u043d \u044d\u0444\u0444\u0435\u043a\u0442 \u0432 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 create-\u043c\u0435\u0442\u043e\u0434\u0430 \u0434\u0440\u0443\u0433\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430, \u043b\u0438\u0431\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043c\u0435\u0442\u043e\u0434 createChainEffect():  <\/p>\n<pre><code class=\"kotlin\">val bmpEffect = RenderEffect.createBitmapEffect(...) val blurBmpEffect = RenderEffect.createBlurEffect(..., bmpEffect, ..) val finalEffect = RenderEffect.createColorFilterEffect(..., blurBitmapEffect)<\/code><\/pre>\n<p>\u0438\u043b\u0438<\/p>\n<pre><code class=\"kotlin\">val finalEffect = RenderEffect.createChainEffect(colorEffect, blurEffect)<\/code><\/pre>\n<p>\u041f\u0440\u0438\u0432\u0435\u0434\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440 \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u044f <strong>\u0446\u0432\u0435\u0442\u043d\u043e\u0433\u043e \u0444\u0438\u043b\u044c\u0442\u0440\u0430<\/strong>:  <\/p>\n<pre><code class=\"kotlin\">val argb = Color.valueOf(red, green, blue, transparency).toArgb() val colorEffect = RenderEffect.createColorFilterEffect(        PorterDuffColorFilter(argb, PorterDuff.Mode.SRC_ATOP) )<\/code><\/pre>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442:  <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e7f\/5c1\/5cc\/e7f5c15cc116769bb32fc8857585883a.png\" width=\"900\" height=\"1600\"><figcaption><\/figcaption><\/figure>\n<p>\u0418\u043b\u0438 \u043c\u043e\u0436\u043d\u043e \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0446\u0432\u0435\u0442\u043d\u043e\u0433\u043e \u0444\u0438\u043b\u044c\u0442\u0440\u0430 \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f:  <\/p>\n<pre><code class=\"kotlin\">val matrix = ColorMatrix() matrix.setSaturation(0f) imageView.setRenderEffect(RenderEffect.createColorFilterEffect(ColorMatrixColorFilter(matrix)))<\/code><\/pre>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0434\u043b\u044f setSaturation(0f) \u0438 setSaturation(100f):  <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b51\/a0c\/8a2\/b51a0c8a2584bbd857439887cc04a72a.png\" width=\"1810\" height=\"1600\"><figcaption><\/figcaption><\/figure>\n<h3>BlendMode<\/h3>\n<p>\u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043c\u0435\u0442\u043e\u0434\u0430 RenderEffect.createBlendModeEffect() \u043c\u043e\u0436\u043d\u043e \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0438\u0442\u044c \u0434\u0432\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0432 \u043e\u0434\u043d\u043e\u043c \u0438\u0437 \u0440\u0435\u0436\u0438\u043c\u043e\u0432:  <\/p>\n<ul>\n<li>\n<p>CLEAR<\/p>\n<\/li>\n<li>\n<p>SRC<\/p>\n<\/li>\n<li>\n<p>DST<\/p>\n<\/li>\n<li>\n<p>SRC_OVER<\/p>\n<\/li>\n<li>\n<p>DST_OVER<\/p>\n<\/li>\n<li>\n<p>SRC_IN<\/p>\n<\/li>\n<li>\n<p>DST_IN<\/p>\n<\/li>\n<li>\n<p>SRC_OUT<\/p>\n<\/li>\n<li>\n<p>DST_OUT<\/p>\n<\/li>\n<li>\n<p>SRC_ATOP<\/p>\n<\/li>\n<li>\n<p>DST_ATOP<\/p>\n<\/li>\n<li>\n<p>XOR<\/p>\n<\/li>\n<li>\n<p>PLUS<\/p>\n<\/li>\n<li>\n<p>MODULATE<\/p>\n<\/li>\n<li>\n<p>SCREEN<\/p>\n<\/li>\n<li>\n<p>OVERLAY<\/p>\n<\/li>\n<li>\n<p>DARKEN<\/p>\n<\/li>\n<li>\n<p>LIGHTEN<\/p>\n<\/li>\n<li>\n<p>COLOR_DODGE<\/p>\n<\/li>\n<li>\n<p>COLOR_BURN<\/p>\n<\/li>\n<li>\n<p>HARD_LIGHT<\/p>\n<\/li>\n<li>\n<p>SOFT_LIGHT<\/p>\n<\/li>\n<li>\n<p>DIFFERENCE<\/p>\n<\/li>\n<li>\n<p>EXCLUSION<\/p>\n<\/li>\n<li>\n<p>MULTIPLY<\/p>\n<\/li>\n<li>\n<p>HUE<\/p>\n<\/li>\n<li>\n<p>SATURATION<\/p>\n<\/li>\n<li>\n<p>COLOR<\/p>\n<\/li>\n<li>\n<p>LUMINOSITY<\/p>\n<\/li>\n<\/ul>\n<p>\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u0440\u0435\u0436\u0438\u043c\u043e\u0432 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c <a href=\"https:\/\/developer.android.com\/reference\/android\/graphics\/BlendMode\">\u0437\u0434\u0435\u0441\u044c<\/a>. \u0414\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u043c \u0442\u0440\u0438 \u0440\u0435\u0436\u0438\u043c\u0430 (\u0437\u0434\u0435\u0441\u044c \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a, \u0442\u043e \u0435\u0441\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 RenderEffect \u2013 \u044d\u0442\u043e \u0441\u0438\u043d\u0438\u0439 \u043a\u0432\u0430\u0434\u0440\u0430\u0442, \u0430 \u043f\u0440\u0438\u0435\u043c\u043d\u0438\u043a, \u0442\u043e \u0435\u0441\u0442\u044c \u0432\u0442\u043e\u0440\u043e\u0439 Render Effect \u2013 \u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u043a\u0440\u0443\u0433):<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b05\/399\/a4c\/b05399a4cf8f03dc3d9b2925bc7b89fb.png\" alt=\"DST_ATOP \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0435\u0442 \u043f\u0438\u043a\u0441\u0435\u043b\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a. \" title=\"DST_ATOP \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0435\u0442 \u043f\u0438\u043a\u0441\u0435\u043b\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a. \" width=\"256\" height=\"256\"><figcaption>DST_ATOP \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0435\u0442 \u043f\u0438\u043a\u0441\u0435\u043b\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a. <\/figcaption><\/figure>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d9b\/8a5\/e9b\/d9b8a5e9b287dba9ef062d3f61b76060.png\" alt=\"OVERLAY \u0443\u043c\u043d\u043e\u0436\u0430\u0435\u0442 \u0446\u0432\u0435\u0442\u0430.\" title=\"OVERLAY \u0443\u043c\u043d\u043e\u0436\u0430\u0435\u0442 \u0446\u0432\u0435\u0442\u0430.\" width=\"256\" height=\"256\"><figcaption>OVERLAY \u0443\u043c\u043d\u043e\u0436\u0430\u0435\u0442 \u0446\u0432\u0435\u0442\u0430.<\/figcaption><\/figure>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c03\/619\/3fe\/c036193fe7b06e0308ee4e445547187c.png\" alt=\"COLOR \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u043e\u0442\u0442\u0435\u043d\u043e\u043a \u0438 \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430, \u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u044c \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u0430\u043a \u0443 \u043f\u0440\u0438\u0435\u043c\u043d\u0438\u043a\u0430.\" title=\"COLOR \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u043e\u0442\u0442\u0435\u043d\u043e\u043a \u0438 \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430, \u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u044c \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u0430\u043a \u0443 \u043f\u0440\u0438\u0435\u043c\u043d\u0438\u043a\u0430.\" width=\"256\" height=\"256\"><figcaption>COLOR \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u043e\u0442\u0442\u0435\u043d\u043e\u043a \u0438 \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430, \u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u044c \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u0430\u043a \u0443 \u043f\u0440\u0438\u0435\u043c\u043d\u0438\u043a\u0430.<\/figcaption><\/figure>\n<p>\u041a\u0430\u043a \u0443\u0436\u0435 \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u043b\u043e\u0441\u044c \u0432\u044b\u0448\u0435, RenderEffect \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043a\u0440\u0430\u0439\u043d\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e. \u041f\u0440\u0438 \u0441\u043a\u0440\u043e\u043b\u043b\u0435 RecyclerView \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0440\u0430\u0437\u043c\u044b\u0442\u043e \u043f\u043e \u0434\u0432\u0435 ImageView (\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 radiusX: 20f, radiusY: 20f, Shader.TileMode.CLAMP), \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u043e\u0434\u0442\u043e\u0440\u043c\u0430\u0436\u0438\u0432\u0430\u043d\u0438\u0439 \u043d\u0435 \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0435\u0442\u0441\u044f. \u0420\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u0432\u044c\u044e \u0441 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0435\u0439 \u0442\u043e\u0436\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0431\u0435\u0437 \u0437\u0430\u0434\u0435\u0440\u0436\u0435\u043a. \u0412 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 \u0440\u0430\u0431\u043e\u0442\u0430 RenderEffect \u0431\u044b\u043b\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u0430 \u0430\u0432\u0442\u043e\u0440\u043e\u043c \u043d\u0430 \u044d\u043c\u0443\u043b\u044f\u0442\u043e\u0440\u0435 Android 12 (API 31).&nbsp;<\/p>\n<p>\u0427\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 RenderEffect API, \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0434\u0435\u044f\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u043e\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0430 \u0432 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 AndroidX&nbsp; \u0434\u043b\u044f Android 10 \u0438 11, \u0442\u0430\u043a \u043a\u0430\u043a Render Nodes, \u043b\u0435\u0436\u0430\u0449\u0438\u0435 \u0432 \u043e\u0441\u043d\u043e\u0432\u0435 RenderEffect, \u0431\u044b\u043b\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u044b \u0432 Android 10 (API level 29). \u041e\u0434\u043d\u0430\u043a\u043e, \u043a\u0430\u043a \u043f\u0438\u0448\u0443\u0442 \u0432 <a href=\"https:\/\/developer.android.com\/about\/versions\/12\/features#rendereffect\"><u>\u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u043e\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438<\/u><\/a>, Render Effect \u043c\u043e\u0433\u0443\u0442 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c \u043d\u0435 \u0432\u0441\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430: \u201cDifferent Android devices may or may not support the feature due to limited processing power\u201d.<\/p>\n<p>\u041e\u0442\u043c\u0435\u0442\u0438\u043c \u0442\u0430\u043a\u0436\u0435, \u0447\u0442\u043e Render Effect \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0437\u0430\u043c\u0435\u043d\u044b \u0434\u043b\u044f RenderScript API, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0443\u0441\u0442\u0430\u0440\u0435\u043b <a href=\"https:\/\/developer.android.com\/guide\/topics\/renderscript\/migrate\">\u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Android 12<\/a>.  <\/p>\n<h2>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h2>\n<p>\u0418\u0442\u0430\u043a, \u0432 Android 12 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0442\u043e, \u0447\u0435\u0433\u043e \u0442\u0430\u043a \u0434\u043e\u043b\u0433\u043e \u043d\u0435 \u0445\u0432\u0430\u0442\u0430\u043b\u043e \u043c\u043d\u043e\u0433\u0438\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c \u2013 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 API \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432. \u0421\u043e\u0447\u0435\u0442\u0430\u044f \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b (\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435, \u0446\u0432\u0435\u0442\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b, \u0448\u0435\u0439\u0434\u0435\u0440\u044b), \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0435 \u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0432\u043e\u0437\u0438\u0442\u044c\u0441\u044f \u0441 \u0432\u044b\u0442\u0430\u0441\u043a\u0438\u0432\u0430\u043d\u0438\u0435\u043c bitmap-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u044d\u0444\u0444\u0435\u043a\u0442 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u043e\u0432\u0435\u0441\u0438\u0442\u044c \u043d\u0430 \u0432\u044c\u044e\u0448\u043a\u0443. \u0410 \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044e RenderNodes, \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 RenderEffect \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u043e.&nbsp;<\/p>\n<p><strong>\u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0437\u0430 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435! \u041d\u0430\u0434\u0435\u0435\u043c\u0441\u044f, \u0447\u0442\u043e \u043d\u0430\u0448 \u043e\u043f\u044b\u0442 \u0431\u044b\u043b \u0432\u0430\u043c \u043f\u043e\u043b\u0435\u0437\u0435\u043d.<\/strong><\/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\/company\/simbirsoft\/blog\/558542\/\"> https:\/\/habr.com\/ru\/company\/simbirsoft\/blog\/558542\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<p>\u0418\u043d\u043e\u0433\u0434\u0430 \u0431\u044b\u0432\u0430\u0435\u0442 \u043d\u0443\u0436\u043d\u043e \u0440\u0430\u0437\u043c\u044b\u0442\u044c \u0437\u0430\u0434\u043d\u0438\u0439 \u043f\u043b\u0430\u043d \u043d\u0430 \u044d\u043a\u0440\u0430\u043d\u0430\u0445 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0432 \u0447\u0430\u0442\u0435. \u0422\u0435\u043f\u0435\u0440\u044c \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u0441\u0435\u0433\u043e \u043f\u0430\u0440\u043e\u0439 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430. \u0412 Android 12 \u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u043d\u043e\u0432\u044b\u0439 API <a href=\"https:\/\/developer.android.com\/reference\/android\/graphics\/RenderEffect\"><u>Render Effect<\/u><\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0442\u044c \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u043d\u0430 Canvas \u0438\u043b\u0438 View. \u042d\u0442\u043e\u0442 API \u0440\u0430\u0434\u0443\u0435\u0442 \u0441\u0432\u043e\u0435\u0439 \u043f\u0440\u043e\u0441\u0442\u043e\u0442\u043e\u0439 \u0438 \u0432\u044b\u0441\u043e\u043a\u043e\u0439 \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c\u044e \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438. \u041d\u0430\u0438\u0431\u043e\u043b\u044c\u0448\u0438\u0439 \u0438\u043d\u0442\u0435\u0440\u0435\u0441 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 Render Effect \u0434\u043b\u044f&nbsp;\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f (BlurEffect), \u043d\u043e \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u043c\u044b \u0437\u0430\u0442\u0440\u043e\u043d\u0435\u043c \u0438 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u0432\u0438\u0434\u044b \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432. \u041c\u0430\u0442\u0435\u0440\u0438\u0430\u043b \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043f\u043e\u043b\u0435\u0437\u0435\u043d \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0430\u043d\u0434\u0440\u043e\u0438\u0434-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c, \u043d\u043e \u0438 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0430\u043c \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0439.<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0418\u0442\u0430\u043a, \u043a\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0437\u043c\u044b\u0442\u044c \u0437\u0430\u0434\u043d\u0438\u0439 \u043f\u043b\u0430\u043d \u043f\u0440\u0438 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0438 \u0434\u0438\u0430\u043b\u043e\u0433\u0430? \u0420\u0430\u043d\u044c\u0448\u0435 \u0432 \u0410\u043d\u0434\u0440\u043e\u0438\u0434\u0435 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u043d\u0430\u0434\u043e \u0431\u044b\u043b\u043e \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u0430\u0442\u044c \u0432\u0441\u0435 \u0432\u044c\u044e \u0441 \u0437\u0430\u0434\u043d\u0435\u0433\u043e \u043f\u043b\u0430\u043d\u0430 \u043d\u0430 bitmap-\u0435 \u0438 \u0437\u0430\u0442\u0435\u043c \u0440\u0430\u0437\u043c\u044b\u0442\u044c \u0435\u0433\u043e \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RenderScript \u0438\u043b\u0438 OpenGL. \u041d\u043e \u044d\u0442\u043e \u043e\u0437\u043d\u0430\u0447\u0430\u0435\u0442, \u0447\u0442\u043e \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u043d\u0435\u043c\u0430\u043b\u043e \u0437\u0430\u043f\u0443\u0442\u0430\u043d\u043d\u043e\u0433\u043e \u0434\u043b\u044f \u043f\u0440\u043e\u0447\u0442\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430, \u043b\u0438\u0431\u043e \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u044e\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0434\u043b\u044f \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f. \u041f\u043b\u044e\u0441 \u0434\u043e\u0431\u0430\u0432\u044f\u0442\u0441\u044f \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0441\u043e\u0431\u044b\u0442\u0438\u0439 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u0438 \u043a\u043e\u0434 \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0431\u0438\u0442\u043c\u0430\u043f\u0430. \u041a \u0442\u043e\u043c\u0443 \u0436\u0435 \u043f\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u044d\u0442\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u043c\u043e\u0433\u0443\u0442 \u043d\u0435 \u0434\u0430\u0432\u0430\u0442\u044c \u0436\u0435\u043b\u0430\u0435\u043c\u043e\u0433\u043e \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430. \u041f\u0440\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a \u0434\u043b\u044f \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438 \u0437\u0430\u043c\u0435\u0447\u0430\u044e\u0442 \u043b\u0430\u0433\u0438, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0435\u0441\u043b\u0438 \u0435\u0441\u0442\u044c RecyclerView, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u043c\u043d\u043e\u0433\u043e BlurView.<\/p>\n<p>\u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e Render Effect \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0432\u0441\u0435\u0433\u043e \u043f\u0430\u0440\u043e\u0439 \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0431\u043b\u044e\u0440 \u0431\u0435\u0437 \u043b\u0430\u0433\u043e\u0432. Render Effect \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e \u0437\u0430 \u0441\u0447\u0435\u0442 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043e\u043d \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 <strong>Render Nodes<\/strong> (\u0443\u0437\u043b\u044b \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438). \u041e\u043d\u0438 \u043e\u0431\u0440\u0430\u0437\u0443\u044e\u0442 \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u044e \u0430\u043f\u043f\u0430\u0440\u0430\u0442\u043d\u043e \u0443\u0441\u043a\u043e\u0440\u0435\u043d\u043d\u043e\u0439 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438, \u0438 \u044d\u0442\u0430 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e GPU (\u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u043e\u0433\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u043e\u0440\u0430). \u041f\u0435\u0440\u0435\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0431\u0443\u0434\u0443\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u0435 \u0447\u0430\u0441\u0442\u0438 UI, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u043a\u0430\u0437\u0430\u043b\u0438\u0441\u044c \u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 invalidated. \u0412\u0441\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u0434\u043b\u044f Render Effect \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0432 Render \u043f\u043e\u0442\u043e\u043a\u0435 \u0438 \u043d\u0435 \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044e\u0442 UI.&nbsp;<\/p>\n<p>\u0423 Render Effect \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e\u0439 API:<\/p>\n<pre><code class=\"kotlin\">val renderNode = RenderNode(\"myRenderNode\") renderNode.setPosition(0, 0, 50, 50) renderNode.setRenderEffect(renderEffect)  canvas.drawRenderNode(renderNode)<\/code><\/pre>\n<p>\u041c\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u043b\u0438 \u044d\u0444\u0444\u0435\u043a\u0442 \u0434\u043b\u044f RenderNode \u043c\u0435\u0442\u043e\u0434\u043e\u043c setRenderEffect(), \u0438 \u0435\u0433\u043e \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 Canvas.drawRenderNode().<\/p>\n<p>\u041c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c Render Effect \u0438 \u043a \u0443\u0437\u043b\u0443 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u0432\u044c\u044e\u0448\u043a\u0438:<\/p>\n<pre><code class=\"julia\">imageView.setRenderEffect(renderEffect)<\/code><\/pre>\n<p>\u041f\u0440\u0438\u0432\u0435\u0434\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u044d\u0444\u0444\u0435\u043a\u0442\u0430:  <\/p>\n<pre><code class=\"kotlin\">val blurEffect = RenderEffect.createBlurEffect(        20f, \/\/radiusX        20f, \/\/radiusY               Shader.TileMode.CLAMP ) imageView.setRenderEffect(blurEffect)<\/code><\/pre>\n<p>\u0417\u0434\u0435\u0441\u044c \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u044d\u0444\u0444\u0435\u043a\u0442 <strong>\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f<\/strong> \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0435\u0433\u043e \u043a \u0443\u0437\u043b\u0443 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438, \u043f\u0440\u0438\u0432\u044f\u0437\u0430\u043d\u043d\u043e\u043c\u0443 \u043a imageView. \u0417\u0430\u0434\u0430\u0435\u043c \u0438\u043d\u0442\u0435\u043d\u0441\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u043f\u043e \u043e\u0441\u0438 X \u0438 \u043e\u0441\u0438 Y (\u0417\u043d\u0430\u0447\u0435\u043d\u0438\u044f 20f) . \u041f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442 \u2013 Shader.TileMode \u2013 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0435\u0442 \u0442\u043e, \u043a\u0430\u043a \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442 \u043d\u0430 \u043a\u0440\u0430\u044f\u0445 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u043c\u043e\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u0438.<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043a \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u043c\u0443 layout-\u0443, \u0442\u043e \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0437\u043c\u044b\u0442\u044b \u0432\u0441\u0435 \u0432\u044c\u044e\u0448\u043a\u0438: \u0438 \u043a\u043d\u043e\u043f\u043a\u0430, \u0438 \u043f\u043e\u043b\u0437\u0443\u043d\u043a\u0438.<\/p>\n<p>\u0412\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0439 <a href=\"https:\/\/developer.android.com\/reference\/android\/graphics\/Shader.TileMode\">TileMode<\/a>:<\/p>\n<ul>\n<li>\n<p><strong>MIRROR<\/strong>.<strong> <\/strong>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u0437\u0435\u0440\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u0442\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043f\u043e \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u0438 \u0438 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438, \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043d\u0430 \u0433\u0440\u0430\u043d\u0438\u0446\u0430\u0445 \u043d\u0435\u0442 \u0440\u0435\u0437\u043a\u0438\u0445 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u043e\u0432.   <\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<ul>\n<li>\n<p><strong>CLAMP<\/strong>. \u0415\u0441\u043b\u0438 shader \u0432\u044b\u0445\u043e\u0434\u0438\u0442 \u0437\u0430 \u043f\u0440\u0435\u0434\u0435\u043b\u044b \u0433\u0440\u0430\u043d\u0438\u0446, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0446\u0432\u0435\u0442 \u043f\u0438\u043a\u0441\u0435\u043b\u0435\u0439 \u043d\u0430 \u0433\u0440\u0430\u043d\u0438\u0446\u0435. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0442\u0430\u043a\u0436\u0435 \u043a\u0430\u043a MIRROR, \u043d\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e \u043d\u0435\u0437\u043d\u0430\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0438\u0441\u043a\u0430\u0436\u0435\u043d\u0438\u0435 \u0444\u043e\u0440\u043c\u044b \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0432\u043e\u0437\u043b\u0435 \u0433\u0440\u0430\u043d\u0438\u0446\u044b.    <\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<ul>\n<li>\n<p><strong>REPEAT<\/strong>. \u0418\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u0442\u0441\u044f \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e \u0438 \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u043e. \u041d\u0430 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0438 \u0437\u0430\u043c\u0435\u0442\u043d\u043e, \u043a\u0430\u043a \u0442\u0435\u043c\u043d\u0430\u044f \u0432\u043e\u0434\u0430 \u0438\u0437 \u043d\u0438\u0436\u043d\u0435\u0439 \u0447\u0430\u0441\u0442\u0438 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u043e\u0442\u0440\u0430\u0437\u0438\u043b\u0430\u0441\u044c \u043d\u0430&nbsp; \u0432\u0435\u0440\u0445\u043d\u0435\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f.<\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<ul>\n<li>\n<p><strong>DECAL<\/strong> (\u043f\u043e\u044f\u0432\u0438\u043b\u0441\u044f \u0432 API 31). \u041e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 shader-\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u0445 \u0433\u0440\u0430\u043d\u0438\u0446. \u041c\u043e\u0436\u043d\u043e \u0437\u0430\u043c\u0435\u0442\u0438\u0442\u044c, \u0447\u0442\u043e \u043d\u0430 \u0433\u0440\u0430\u043d\u0438\u0446\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435 \u0441\u0442\u0430\u043b\u043e \u0447\u0443\u0442\u044c \u0441\u0432\u0435\u0442\u043b\u0435\u0435.  <\/p>\n<\/li>\n<\/ul>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<p>\u041c\u044b \u0442\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043f\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 <strong>\u0442\u0435\u043d\u0438<\/strong>. \u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0442\u0435\u043d\u044c \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0441\u0432\u043e\u0439\u0441\u0442\u0432\u0430 Elevation:   <\/p>\n<pre><code class=\"xml\">android:elevation=\"10dp\"<\/code><\/pre>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<p>\u041e\u0434\u043d\u0430\u043a\u043e, \u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043c\u044b \u043d\u0435 \u0441\u043c\u043e\u0436\u0435\u043c \u0437\u0430\u0434\u0430\u0432\u0430\u0442\u044c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0434\u043e\u043b\u0436\u043d\u0430 \u043e\u0442\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0442\u0435\u043d\u044c, \u0438\u043b\u0438 \u0435\u0435 \u0446\u0432\u0435\u0442. \u0422\u0430\u043a\u0436\u0435 \u0442\u0435\u043d\u044c \u0434\u043b\u044f Elevation \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0441 \u0444\u043e\u0440\u043c\u0430\u043c\u0438 \u0441\u043a\u0440\u0443\u0433\u043b\u0435\u043d\u043d\u043e\u0433\u043e \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430 (\u043a\u0440\u0443\u0433 \u0438 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a \u2013 \u0447\u0430\u0441\u0442\u043d\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0438 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a\u0430 \u0441\u043e \u0441\u043a\u0440\u0443\u0433\u043b\u0435\u043d\u043d\u044b\u043c\u0438 \u0443\u0433\u043b\u0430\u043c\u0438). \u0414\u043b\u044f \u0442\u0435\u043d\u0438 \u0434\u0440\u0443\u0433\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u043d\u0443\u0436\u043d\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c ViewOutlineProvider, \u0447\u0442\u043e\u0431\u044b \u043e\u043d \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u043b Outline \u0441 setPath(&#8230;), \u0430 \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0432\u0435\u0441\u044c\u043c\u0430 \u0442\u0440\u0443\u0434\u043e\u0435\u043c\u043a\u043e.<\/p>\n<p>\u041a\u0430\u0441\u0442\u043e\u043c\u043d\u0443\u044e \u0442\u0435\u043d\u044c \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0438 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e xml, \u043f\u0440\u043e\u043f\u0438\u0441\u0430\u0432 &lt;shape&gt; \u0441 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043e\u043c:<\/p>\n<pre><code class=\"xml\">&lt;gradient        android:type=\"radial\"        android:centerColor=\"#90000000\"        android:gradientRadius=\"70dp\"        android:startColor=\"@android:color\/white\"        android:endColor=\"@android:color\/transparent\"\/&gt;<\/code><\/pre>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<p>\u041c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0442\u0435\u043d\u044c \u043a\u0440\u0443\u0433\u043b\u043e\u0439 \u0444\u043e\u0440\u043c\u044b, \u043b\u043e\u0436\u0430\u0449\u0443\u044e\u0441\u044f \u043e\u0442 \u0431\u0435\u043b\u043e\u0433\u043e \u043a\u0440\u0443\u0433\u0430 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e \u0432\u043e \u0432\u0441\u0435\u0445 \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f\u0445 \u2013 \u0442\u043e \u0435\u0441\u0442\u044c \u0441\u0432\u0435\u0440\u0445\u0443 \u043e\u043d\u0430 \u0442\u0430\u043a\u043e\u0439 \u0436\u0435 \u0434\u043b\u0438\u043d\u044b, \u0447\u0442\u043e \u0438 \u0441\u043d\u0438\u0437\u0443. \u041d\u043e \u043c\u044b \u0432\u0441\u0435 \u0436\u0435 \u043d\u0435 \u0441\u043c\u043e\u0436\u0435\u043c \u0442\u0430\u043a\u0438\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0435\u043d\u044c \u0441\u043b\u043e\u0436\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b.<\/p>\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u0434\u043b\u044f \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u044f \u043f\u043e\u043a\u0430\u0436\u0435\u043c, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u0443\u044e \u0442\u0435\u043d\u044c \u043a\u0440\u0443\u0433\u043b\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RenderEffect. \u0421\u043e\u0437\u0434\u0430\u0435\u043c \u043a\u0440\u0443\u0433 \u0441\u0435\u0440\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430:<\/p>\n<pre><code class=\"xml\">&lt;shape android:shape=\"oval\"&gt;    &lt;solid android:color=\"#CCCCCC\" \/&gt; &lt;\/shape&gt;<\/code><\/pre>\n<p>\u0417\u0430\u0442\u0435\u043c \u044d\u0442\u043e\u0442 drawable \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0433\u043e ImageView \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043a ImageView:<\/p>\n<pre><code class=\"kotlin\">imageView.setImageResource(R.drawable.gray_circle) val renderEffect = RenderEffect.createBlurEffect(20f, 20f, Shader.TileMode.CLAMP) imageView.setRenderEffect(renderEffect)<\/code><\/pre>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<p>\u0410 \u0432\u043e\u0442 \u043a\u0430\u043a \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RenderEffect \u043c\u043e\u0436\u043d\u043e \u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u0442\u0435\u043d\u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0438, \u0435\u0441\u043b\u0438 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f, \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430:<\/p>\n<pre><code class=\"xml\">&lt;ImageView    android:id=\"@+id\/shadow\"    android:layout_width=\"150dp\"    android:layout_height=\"150dp\"    android:src=\"@drawable\/ic_baseline_time_to_leave_24\"    android:tint=\"#444444\"\/&gt;<\/code><\/pre>\n<pre><code class=\"kotlin\">val effect = RenderEffect.createBlurEffect(10f, 10f, Shader.TileMode.CLAMP) imageViewfindViewById&lt;ImageView&gt;(R.id.shadow).setRenderEffect(effect)<\/code><\/pre>\n<figure class=\"\"><figcaption><\/figcaption><\/figure>\n<p>\u0415\u0441\u043b\u0438 \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u0441 \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f\u043c\u0438 \u0440\u0430\u0434\u0438\u0443\u0441\u0430, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, 20 \u043f\u043e \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438 \u0438 0 \u043f\u043e \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u0438, \u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u044d\u0444\u0444\u0435\u043a\u0442, \u043f\u043e\u0445\u043e\u0436\u0438\u0439 \u043d\u0430 <strong>\u0441\u043c\u0430\u0437\u0430\u043d\u043d\u044b\u0439 \u0441\u043d\u0438\u043c\u043e\u043a<\/strong>.  <\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0441\u0435\u0433\u043e \u0435\u0441\u0442\u044c \u0441\u0435\u043c\u044c \u0432\u0438\u0434\u043e\u0432 RenderEffect:<\/p>\n<ul>\n<li>\n<p><strong>Bitmap<\/strong> \u2013 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u0431\u0438\u0442\u043c\u0430\u043f\u0430. \u041e\u0431\u044b\u0447\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0432 \u0446\u0435\u043f\u043e\u0447\u043a\u0435 \u0434\u043b\u044f \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p><strong>Blur<\/strong> \u2013 \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u043f\u043e \u043e\u0441\u0438 X \u0438 Y.<\/p>\n<\/li>\n<li>\n<p><strong>ColorFilter<\/strong> \u2013 \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u0446\u0432\u0435\u0442\u043d\u043e\u0439 \u0444\u0438\u043b\u044c\u0442\u0440 (\u0441\u043c. \u0441\u043a\u0440\u0438\u043d\u0448\u043e\u0442 \u043d\u0438\u0436\u0435).<\/p>\n<\/li>\n<li>\n<p><strong>Offset <\/strong>\u2013 \u0441\u0434\u0432\u0438\u0433 \u043f\u043e \u043e\u0441\u044f\u043c X, Y (\u0436\u0430\u043b\u044c, \u0447\u0442\u043e \u043d\u0435\u0442 \u043f\u043e\u0432\u043e\u0440\u043e\u0442\u0430).<\/p>\n<\/li>\n<li>\n<p><strong>Shader<\/strong> \u2013 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u044b\u0432\u0430\u0435\u0442 \u0448\u0435\u0439\u0434\u0435\u0440, \u043f\u0435\u0440\u0435\u0434\u0430\u043d\u043d\u044b\u0439 \u0432 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430\u0445. \u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0448\u0435\u0439\u0434\u0435\u0440\u043e\u0432 \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440,&nbsp; \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u044b.<\/p>\n<\/li>\n<li>\n<p><strong>Chain<\/strong> \u2013 \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u044f 2 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432. \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u043e\u0434\u043d\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043a\u0430\u043a \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a \u0434\u043b\u044f \u0432\u0442\u043e\u0440\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430.<\/p>\n<\/li>\n<li>\n<p><strong>BlendMode<\/strong> \u2013 \u0434\u043b\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f 2 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432 \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435.<\/p>\n<\/li>\n<\/ul>\n<p>\u041c\u043e\u0436\u043d\u043e \u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u043a\u0440\u0430\u0441\u0438\u0432\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u201c<strong>\u0437\u0430\u043c\u0435\u0440\u0437\u0448\u0435\u0433\u043e \u0441\u0442\u0435\u043a\u043b\u0430<\/strong>\u201d (\u0438\u043b\u0438 \u201c\u0437\u0430\u043f\u043e\u0442\u0435\u0432\u0448\u0435\u0433\u043e \u043e\u043a\u043d\u0430\u201d): \u043e\u043d \u0434\u043e\u0441\u0442\u0438\u0433\u0430\u0435\u0442\u0441\u044f \u0441\u043e\u0447\u0435\u0442\u0430\u043d\u0438\u0435\u043c \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u044f \u0438 \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u043e-\u0431\u0435\u043b\u043e\u0433\u043e \u0446\u0432\u0435\u0442\u0430.<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u041f\u0440\u0438\u043c\u0435\u043d\u0438\u043c \u0442\u0430\u043a\u043e\u0439 \u044d\u0444\u0444\u0435\u043a\u0442 \u043a \u043f\u0430\u043d\u0435\u043b\u0438 \u0432\u043d\u0438\u0437\u0443 \u044d\u043a\u0440\u0430\u043d\u0430. \u0424\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0437\u0434\u0435\u0441\u044c \u043d\u0430\u0434\u043e \u0441\u043e\u0447\u0435\u0442\u0430\u0442\u044c \u0442\u0440\u0438 \u044d\u0444\u0444\u0435\u043a\u0442\u0430: \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 \u0431\u0438\u0442\u043c\u0430\u043f\u0430 + \u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 + \u0446\u0432\u0435\u0442\u043d\u043e\u0439 \u0444\u0438\u043b\u044c\u0442\u0440. \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043d\u0435\u043b\u044c\u0437\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043c\u044b\u0432\u0430\u043b\u0430\u0441\u044c \u0442\u0430 \u0447\u0430\u0441\u0442\u044c UI, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u0430\u043d\u0430 \u043f\u043e\u0434 \u0432\u044c\u044e\u0448\u043a\u043e\u0439. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 RenderEffect \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u043d\u0435 \u043a \u0441\u0430\u043c\u043e\u0439 \u043f\u0430\u043d\u0435\u043b\u0438, \u0430 \u043a \u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u043e\u0434 \u043d\u0435\u0439 \u0438 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0444\u043e\u043d\u043e\u0432\u043e\u0435 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435: \u043a imageView \u0438\u043b\u0438 \u043a \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u043c\u0443 layout-\u0443. \u041a\u043e\u043c\u0431\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u0444\u0444\u0435\u043a\u0442\u044b \u043c\u043e\u0436\u043d\u043e 2 \u0441\u043f\u043e\u0441\u043e\u0431\u0430\u043c\u0438: \u043f\u0435\u0440\u0435\u0434\u0430\u0432\u0430\u0442\u044c \u043e\u0434\u0438\u043d \u044d\u0444\u0444\u0435\u043a\u0442 \u0432 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 create-\u043c\u0435\u0442\u043e\u0434\u0430 \u0434\u0440\u0443\u0433\u043e\u0433\u043e \u044d\u0444\u0444\u0435\u043a\u0442\u0430, \u043b\u0438\u0431\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043c\u0435\u0442\u043e\u0434 createChainEffect():  <\/p>\n<pre><code class=\"kotlin\">val bmpEffect = RenderEffect.createBitmapEffect(...) val blurBmpEffect = RenderEffect.createBlurEffect(..., bmpEffect, ..) val finalEffect = RenderEffect.createColorFilterEffect(..., blurBitmapEffect)<\/code><\/pre>\n<p>\u0438\u043b\u0438<\/p>\n<pre><code class=\"kotlin\">val finalEffect = RenderEffect.createChainEffect(colorEffect, blurEffect)<\/code><\/pre>\n<p>\u041f\u0440\u0438\u0432\u0435\u0434\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440 \u043d\u0430\u043b\u043e\u0436\u0435\u043d\u0438\u044f <strong>\u0446\u0432\u0435\u0442\u043d\u043e\u0433\u043e \u0444\u0438\u043b\u044c\u0442\u0440\u0430<\/strong>:  <\/p>\n<pre><code class=\"kotlin\">val argb = Color.valueOf(red, green, blue, transparency).toArgb() val colorEffect = RenderEffect.createColorFilterEffect(        PorterDuffColorFilter(argb, PorterDuff.Mode.SRC_ATOP) )<\/code><\/pre>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442:  <\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0418\u043b\u0438 \u043c\u043e\u0436\u043d\u043e \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0446\u0432\u0435\u0442\u043d\u043e\u0433\u043e \u0444\u0438\u043b\u044c\u0442\u0440\u0430 \u043f\u043e\u043c\u0435\u043d\u044f\u0442\u044c \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f:  <\/p>\n<pre><code class=\"kotlin\">val matrix = ColorMatrix() matrix.setSaturation(0f) imageView.setRenderEffect(RenderEffect.createColorFilterEffect(ColorMatrixColorFilter(matrix)))<\/code><\/pre>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0434\u043b\u044f setSaturation(0f) \u0438 setSaturation(100f):  <\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<h3>BlendMode<\/h3>\n<p>\u0421 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043c\u0435\u0442\u043e\u0434\u0430 RenderEffect.createBlendModeEffect() \u043c\u043e\u0436\u043d\u043e \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u0438\u0442\u044c \u0434\u0432\u0430 \u044d\u0444\u0444\u0435\u043a\u0442\u0430 \u0432 \u043e\u0434\u043d\u043e\u043c \u0438\u0437 \u0440\u0435\u0436\u0438\u043c\u043e\u0432:  <\/p>\n<ul>\n<li>\n<p>CLEAR<\/p>\n<\/li>\n<li>\n<p>SRC<\/p>\n<\/li>\n<li>\n<p>DST<\/p>\n<\/li>\n<li>\n<p>SRC_OVER<\/p>\n<\/li>\n<li>\n<p>DST_OVER<\/p>\n<\/li>\n<li>\n<p>SRC_IN<\/p>\n<\/li>\n<li>\n<p>DST_IN<\/p>\n<\/li>\n<li>\n<p>SRC_OUT<\/p>\n<\/li>\n<li>\n<p>DST_OUT<\/p>\n<\/li>\n<li>\n<p>SRC_ATOP<\/p>\n<\/li>\n<li>\n<p>DST_ATOP<\/p>\n<\/li>\n<li>\n<p>XOR<\/p>\n<\/li>\n<li>\n<p>PLUS<\/p>\n<\/li>\n<li>\n<p>MODULATE<\/p>\n<\/li>\n<li>\n<p>SCREEN<\/p>\n<\/li>\n<li>\n<p>OVERLAY<\/p>\n<\/li>\n<li>\n<p>DARKEN<\/p>\n<\/li>\n<li>\n<p>LIGHTEN<\/p>\n<\/li>\n<li>\n<p>COLOR_DODGE<\/p>\n<\/li>\n<li>\n<p>COLOR_BURN<\/p>\n<\/li>\n<li>\n<p>HARD_LIGHT<\/p>\n<\/li>\n<li>\n<p>SOFT_LIGHT<\/p>\n<\/li>\n<li>\n<p>DIFFERENCE<\/p>\n<\/li>\n<li>\n<p>EXCLUSION<\/p>\n<\/li>\n<li>\n<p>MULTIPLY<\/p>\n<\/li>\n<li>\n<p>HUE<\/p>\n<\/li>\n<li>\n<p>SATURATION<\/p>\n<\/li>\n<li>\n<p>COLOR<\/p>\n<\/li>\n<li>\n<p>LUMINOSITY<\/p>\n<\/li>\n<\/ul>\n<p>\u041f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u0440\u0435\u0436\u0438\u043c\u043e\u0432 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c <a href=\"https:\/\/developer.android.com\/reference\/android\/graphics\/BlendMode\">\u0437\u0434\u0435\u0441\u044c<\/a>. \u0414\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u043f\u0440\u0438\u0432\u0435\u0434\u0435\u043c \u0442\u0440\u0438 \u0440\u0435\u0436\u0438\u043c\u0430 (\u0437\u0434\u0435\u0441\u044c \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a, \u0442\u043e \u0435\u0441\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 RenderEffect \u2013 \u044d\u0442\u043e \u0441\u0438\u043d\u0438\u0439 \u043a\u0432\u0430\u0434\u0440\u0430\u0442, \u0430 \u043f\u0440\u0438\u0435\u043c\u043d\u0438\u043a, \u0442\u043e \u0435\u0441\u0442\u044c \u0432\u0442\u043e\u0440\u043e\u0439 Render Effect \u2013 \u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u043a\u0440\u0443\u0433):<\/p>\n<figure class=\"\"><figcaption>DST_ATOP \u0432\u044b\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0435\u0442 \u043f\u0438\u043a\u0441\u0435\u043b\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u043d\u0430\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0430 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a. <\/figcaption><\/figure>\n<figure class=\"\"><figcaption>OVERLAY \u0443\u043c\u043d\u043e\u0436\u0430\u0435\u0442 \u0446\u0432\u0435\u0442\u0430.<\/figcaption><\/figure>\n<figure class=\"\"><figcaption>COLOR \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442 \u043e\u0442\u0442\u0435\u043d\u043e\u043a \u0438 \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430, \u0430 \u044f\u0440\u043a\u043e\u0441\u0442\u044c \u0434\u0435\u043b\u0430\u0435\u0442 \u043a\u0430\u043a \u0443 \u043f\u0440\u0438\u0435\u043c\u043d\u0438\u043a\u0430.<\/figcaption><\/figure>\n<p>\u041a\u0430\u043a \u0443\u0436\u0435 \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u043b\u043e\u0441\u044c \u0432\u044b\u0448\u0435, RenderEffect \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043a\u0440\u0430\u0439\u043d\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u0438\u0432\u043d\u043e. \u041f\u0440\u0438 \u0441\u043a\u0440\u043e\u043b\u043b\u0435 RecyclerView \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0443 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0440\u0430\u0437\u043c\u044b\u0442\u043e \u043f\u043e \u0434\u0432\u0435 ImageView (\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438 radiusX: 20f, radiusY: 20f, Shader.TileMode.CLAMP), \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u043e\u0434\u0442\u043e\u0440\u043c\u0430\u0436\u0438\u0432\u0430\u043d\u0438\u0439 \u043d\u0435 \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0435\u0442\u0441\u044f. \u0420\u0430\u0437\u043c\u044b\u0442\u0438\u0435 \u0432\u044c\u044e \u0441 \u0430\u043d\u0438\u043c\u0430\u0446\u0438\u0435\u0439 \u0442\u043e\u0436\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0431\u0435\u0437 \u0437\u0430\u0434\u0435\u0440\u0436\u0435\u043a. \u0412 \u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0439 \u043c\u043e\u043c\u0435\u043d\u0442 \u0440\u0430\u0431\u043e\u0442\u0430 RenderEffect \u0431\u044b\u043b\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u0435\u043d\u0430 \u0430\u0432\u0442\u043e\u0440\u043e\u043c \u043d\u0430 \u044d\u043c\u0443\u043b\u044f\u0442\u043e\u0440\u0435 Android 12 (API 31).&nbsp;<\/p>\n<p>\u0427\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 RenderEffect API, \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0434\u0435\u044f\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u043e\u043d\u0430 \u0431\u0443\u0434\u0435\u0442 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0430 \u0432 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 AndroidX&nbsp; \u0434\u043b\u044f Android 10 \u0438 11, \u0442\u0430\u043a \u043a\u0430\u043a Render Nodes, \u043b\u0435\u0436\u0430\u0449\u0438\u0435 \u0432 \u043e\u0441\u043d\u043e\u0432\u0435 RenderEffect, \u0431\u044b\u043b\u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u044b \u0432 Android 10 (API level 29). \u041e\u0434\u043d\u0430\u043a\u043e, \u043a\u0430\u043a \u043f\u0438\u0448\u0443\u0442 \u0432 <a href=\"https:\/\/developer.android.com\/about\/versions\/12\/features#rendereffect\"><u>\u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u043e\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438<\/u><\/a>, Render Effect \u043c\u043e\u0433\u0443\u0442 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c \u043d\u0435 \u0432\u0441\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0430: \u201cDifferent Android devices may or may not support the feature due to limited processing power\u201d.<\/p>\n<p>\u041e\u0442\u043c\u0435\u0442\u0438\u043c \u0442\u0430\u043a\u0436\u0435, \u0447\u0442\u043e Render Effect \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0437\u0430\u043c\u0435\u043d\u044b \u0434\u043b\u044f RenderScript API, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0443\u0441\u0442\u0430\u0440\u0435\u043b <a href=\"https:\/\/developer.android.com\/guide\/topics\/renderscript\/migrate\">\u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 Android 12<\/a>.  <\/p>\n<h2>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h2>\n<p>\u0418\u0442\u0430\u043a, \u0432 Android 12 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0442\u043e, \u0447\u0435\u0433\u043e \u0442\u0430\u043a \u0434\u043e\u043b\u0433\u043e \u043d\u0435 \u0445\u0432\u0430\u0442\u0430\u043b\u043e \u043c\u043d\u043e\u0433\u0438\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c \u2013 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 API \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u0445 \u044d\u0444\u0444\u0435\u043a\u0442\u043e\u0432. \u0421\u043e\u0447\u0435\u0442\u0430\u044f \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u044d\u0444\u0444\u0435\u043a\u0442\u044b (\u0440\u0430\u0437\u043c\u044b\u0442\u0438\u0435, \u0446\u0432\u0435\u0442\u043d\u044b\u0435 \u0444\u0438\u043b\u044c\u0442\u0440\u044b, \u0448\u0435\u0439\u0434\u0435\u0440\u044b), \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0435 \u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0432\u043e\u0437\u0438\u0442\u044c\u0441\u044f \u0441 \u0432\u044b\u0442\u0430\u0441\u043a\u0438\u0432\u0430\u043d\u0438\u0435\u043c bitmap-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u044d\u0444\u0444\u0435\u043a\u0442 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u043e\u0432\u0435\u0441\u0438\u0442\u044c \u043d\u0430 \u0432\u044c\u044e\u0448\u043a\u0443. \u0410 \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044e RenderNodes, \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0430 RenderEffect \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043e\u0447\u0435\u043d\u044c \u0431\u044b\u0441\u0442\u0440\u043e.&nbsp;<\/p>\n<p><strong>\u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0437\u0430 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435! \u041d\u0430\u0434\u0435\u0435\u043c\u0441\u044f, \u0447\u0442\u043e \u043d\u0430\u0448 \u043e\u043f\u044b\u0442 \u0431\u044b\u043b \u0432\u0430\u043c \u043f\u043e\u043b\u0435\u0437\u0435\u043d.<\/strong><\/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\/company\/simbirsoft\/blog\/558542\/\"> https:\/\/habr.com\/ru\/company\/simbirsoft\/blog\/558542\/<\/a><br \/><\/br><\/br><\/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-323531","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/323531","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=323531"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/323531\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=323531"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=323531"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=323531"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}