{"id":46623,"date":"2023-09-01T19:37:10","date_gmt":"2023-09-01T10:37:10","guid":{"rendered":"https:\/\/www.charlezz.com\/?p=46623"},"modified":"2023-09-01T19:37:13","modified_gmt":"2023-09-01T10:37:13","slug":"palette-%eb%9d%bc%ec%9d%b4%eb%b8%8c%eb%9f%ac%eb%a6%ac-%eb%9c%af%ec%96%b4%eb%b3%b4%ea%b8%b0","status":"publish","type":"post","link":"https:\/\/charlezz.com\/?p=46623","title":{"rendered":"Palette \ub77c\uc774\ube0c\ub7ec\ub9ac \ub72f\uc5b4\ubcf4\uae30"},"content":{"rendered":"\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" loading=\"lazy\" width=\"1024\" height=\"440\" src=\"https:\/\/www.charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-p-palette-library-color-profiles-2-1-2x-1-1024x440.png\" alt=\"\" class=\"wp-image-46624\" srcset=\"https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-p-palette-library-color-profiles-2-1-2x-1-1024x440.png 1024w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-p-palette-library-color-profiles-2-1-2x-1-300x129.png 300w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-p-palette-library-color-profiles-2-1-2x-1-768x330.png 768w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-p-palette-library-color-profiles-2-1-2x-1.png 1248w\" sizes=\"(max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<p><a href=\"https:\/\/developer.android.com\/develop\/ui\/views\/graphics\/palette-colors\">Palette \ub77c\uc774\ube0c\ub7ec\ub9ac<\/a>\ub294 \uc774\ubbf8\uc9c0\uc5d0\uc11c \ub208\uc5d0 \ub744\ub294 \uc0c9\uc0c1\ub4e4\uc744 \ucd94\ucd9c\ud574\uc8fc\ub294 \ub77c\uc774\ube0c\ub7ec\ub9ac\ub2e4.<\/p>\n\n\n\n<p>\uc774 \ub77c\uc774\ube0c\ub7ec\ub9ac\uac00 \uc5b4\ub5a4\uc2dd\uc73c\ub85c \ub3d9\uc791\ud558\ub294\uc9c0 \ud655\uc778\ud574\ubcf4\uc790.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Median cut <\/h2>\n\n\n\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" loading=\"lazy\" width=\"319\" height=\"402\" src=\"https:\/\/www.charlezz.com\/wordpress\/wp-content\/uploads\/2023\/09\/www.charlezz.com-palette-reducedrgbcube.jpg\" alt=\"\" class=\"wp-image-46630\" srcset=\"https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/09\/www.charlezz.com-palette-reducedrgbcube.jpg 319w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/09\/www.charlezz.com-palette-reducedrgbcube-238x300.jpg 238w\" sizes=\"(max-width: 319px) 100vw, 319px\" \/><\/figure>\n\n\n\n<p>Palette \ub77c\uc774\ube0c\ub7ec\ub9ac\ub294 Median cut \uc54c\uace0\ub9ac\uc998\uc744 \uae30\ubc18\uc73c\ub85c \ub3d9\uc791\ud55c\ub2e4. Median cut\uc740 \ub9d0 \uadf8\ub300\ub85c \uc911\uc559\uac12\uc744 \uc790\ub978\ub2e4\ub294 \ub73b\uc774\ub2e4. \uac00\uc7a5 \uae34 \ucc28\uc6d0\uc744 \ub530\ub77c \uc911\uc559\uac12\uc774 \uc788\ub294 \uc9c0\uc810(\uc778\ub371\uc2a4)\uc5d0\uc11c \uac01 \ub370\uc774\ud130 \uc9d1\ud569\uc744 \uc7ac\uadc0\uc801\uc73c\ub85c \uc790\ub974\uace0 \uc784\uc758 \uac1c\uc218\uc758 \ucc28\uc6d0 \ub370\uc774\ud130\ub97c \uc77c\ub828\uc758 \uc9d1\ud569\uc73c\ub85c \uc815\ub82c\ud558\ub294 \uc54c\uace0\ub9ac\uc998\uc774\ub2e4. \uc774 \uc54c\uace0\ub9ac\uc998\uc740 \uc77c\ubc18\uc801\uc73c\ub85c \uc0c9\uc0c1 \uc591\uc790\ud654(<a href=\"https:\/\/en.wikipedia.org\/wiki\/Color_quantization\">Color quantization<\/a>)\uc5d0 \uc0ac\uc6a9\ub41c\ub2e4.<\/p>\n\n\n\n<blockquote class=\"wp-block-quote\">\n<p>\uc5ec\uae30\uc5d0\uc11c \ub9d0\ud558\ub294 \uc591\uc790\ud654(quantization)\ub780 \uc5f0\uc18d\uc801\uc778 \uac12\uc744\u00a0\ub744\uc5c4\ub744\uc5c4\ud55c \uac12\uc73c\ub85c \ubc14\uafb8\uc5b4 \uadfc\uc0ac\ud558\ub294 \uacfc\uc815\uc744 \uc758\ubbf8\ud55c\ub2e4.<\/p>\n<\/blockquote>\n\n\n\n<h2 class=\"wp-block-heading\">ColorCutQuantizer(<a href=\"https:\/\/androidx.tech\/artifacts\/palette\/palette\/1.0.0-source\/androidx\/palette\/graphics\/ColorCutQuantizer.java.html\">\uc18c\uc2a4\ucf54\ub4dc<\/a>)<\/h2>\n\n\n\n<p>ColorCutQuantizer\ub294 Palette \ub77c\uc774\ube0c\ub7ec\ub9ac\uc5d0\uc11c \uc0c9\uc0c1\uc744 \uc591\uc790\ud654 \ud558\ub294 \ud575\uc2ec \ud074\ub798\uc2a4\ub2e4.<\/p>\n\n\n\n<p>\uc774 \ud074\ub798\uc2a4\uac00 \ud558\ub294 \uc77c\uc744 3\ub2e8\uacc4\ub85c \ucd94\uc0c1\ud654 \ud558\uba74 \ub2e4\uc74c\uacfc \uac19\ub2e4.<\/p>\n\n\n\n<ol>\n<li><strong>\ud53d\uc140\uc744 RGB888\uc5d0\uc11c RGB555\ub85c \ubcc0\ud658<\/strong><\/li>\n\n\n\n<li><strong>\ud788\uc2a4\ud1a0\uadf8\ub7a8 \ub9cc\ub4e4\uae30<\/strong><\/li>\n\n\n\n<li><strong>\uc784\uc758\uc758 \uc218\ub85c \uceec\ub7ec \uac2f\uc218\ub97c \uc904\uc774\uae30<\/strong><\/li>\n<\/ol>\n\n\n\n<p>\uac01\uac01 \ud558\ub098\uc529 \uc0b4\ud3b4\ubcf4\uc790<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">1. \ud53d\uc140 \uc591\uc790\ud654<\/h3>\n\n\n\n<p>Palette \ub77c\uc774\ube0c\ub7ec\ub9ac\uc758 ColorCutQuantizer\uc5d0\uc11c\ub294 \uc5f0\uc0b0\ub7c9\uc744 \uc904\uc774\uace0 \ucd5c\uc801\ud654\ub41c \uceec\ub7ec \uac12\uc744 \ucd94\ucd9c\ud558\uae30 \uc704\ud574, quantizeFromRgb888 \ud568\uc218 \ud638\ucd9c\uc744 \ud1b5\ud574 \ud53d\uc140\uc744 \uc591\uc790\ud654\ud558\ub294 \uc791\uc5c5\uc744 \uc120\ud589\ud55c\ub2e4.<\/p>\n\n\n\n<blockquote class=\"wp-block-quote\">\n<p>\ucef4\ud4e8\ud130 \uadf8\ub798\ud53d\uc2a4\uc5d0\uc11c \uc77c\ubc18\uc801\uc73c\ub85c \ud53d\uc140 \ud558\ub098\ub294 RGB888\ub85c \ud45c\ud604\ud558\ub294\ub370 R\uc740 \ube68\uac15, G\ub294 \ub179\uc0c9, B\ub294 \ud30c\ub791\uc774\uace0 8\uc740 8bits \ub77c\ub294 \uc758\ubbf8\ub2e4. \uc989, R(0~255), G(0~255), B(0~255)\ub85c \ube5b\uc758 \uc0bc\uc6d0\uc0c9 \uc870\ud569\uc73c\ub85c \uc57d 16\ub9cc \uac00\uc9c0\uc758 \uc0c9\uc0c1\uc744 \ud45c\ud604\ud558\uac8c \ub41c\ub2e4. \uc5ec\uae30\uc5d0 \ud22c\uba85\ub3c4 Alpha(0~255)\ub97c \ub354\ud574 \uc77c\ubc18\uc801\uc73c\ub85c 32bits \uc989 4\ubc14\uc774\ud2b8 int\ud0c0\uc785\uc758 \uc815\uc218\ud615\uc73c\ub85c \ud53d\uc140\uc744 \ud45c\ud604\ud55c\ub2e4. Palette\uc5d0\uc11c\ub294 Alpha\ub294 \uace0\ub824\ud558\uc9c0 \uc54a\ub294\ub2e4.<\/p>\n<\/blockquote>\n\n\n\n<pre class=\"wp-block-code\"><code>for (int i = 0; i &lt; pixels.length; i++) {\n<strong>    final int quantizedColor = quantizeFromRgb888(pixels&#91;i]);<\/strong>\n    \/\/ \uc591\uc790\ud654 \ub41c \ud53d\uc140\uac12\uc73c\ub85c \uc774\ubbf8\uc9c0\ub0b4 \ud53d\uc140\uc744 \ubcc0\uacbd\n    pixels&#91;i] = quantizedColor;\n    ...\n}<\/code><\/pre>\n\n\n\n<blockquote class=\"wp-block-quote\">\n<p><em>pixels\uc5d0 length\uc5d0 \uc758\uc874\ud558\uc5ec \ubc18\ubcf5\ubb38\uc744 \uc218\ud589\ud558\uae30 \ub54c\ubb38\uc5d0 \uc2e4\uc81c\ub85c \uc774\ubbf8\uc9c0\uc758 \uc0ac\uc774\uc988(\ub108\ube44 * \ub192\uc774)\uac00 \ud074 \uc218\ub85d \uc5f0\uc0b0\ub7c9\uc774 \ub9ce\uc544\uc9c0\uac8c \ub41c\ub2e4. Palette \ub77c\uc774\ube0c\ub7ec\ub9ac\ub294 \uc77c\uc815 \ud37c\ud3ec\uba3c\uc2a4\ub97c \ubcf4\uc7a5\ud558\uae30 \uc704\ud574 \uc2e4\uc81c\ub85c \ud53d\uc140 \uc591\uc790\ud654 \uc9c4\ud589\ud558\uae30 \uc804\uc5d0 \ube44\ud2b8\ub9f5 \uc774\ubbf8\uc9c0\ub97c 112*112 \uc774\ud558\ub85c \uc791\uac8c(scale-down) \ub9cc\ub4e4\uace0 \uc2dc\uc791\ud55c\ub2e4.<\/em><\/p>\n<\/blockquote>\n\n\n\n<p>\uc704 \ucf54\ub4dc\uc5d0\uc11c <strong>pixels<\/strong>\ub294 \uc6d0\ubcf8 \ube44\ud2b8\ub9f5 \uc774\ubbf8\uc9c0 \ubc30\uc5f4\uc774\uba70, \uac01 \ud53d\uc140\ub4e4\uc740 quantizeFromRgb888 \ud638\ucd9c \uc774\ud6c4 \uc591\uc790\ud654 \ub41c \ud53d\uc140 \uac12\uc73c\ub85c \uce58\ud658\ub41c\ub2e4.   <\/p>\n\n\n\n<p><strong>8\ube44\ud2b8\ub85c \ud45c\ud604\ub418\ub358 \ud53d\uc140\uac12\uc740 \uc591\uc790\ud654 \uc774\ud6c4\uc5d0 5\ube44\ud2b8\ub85c \ud45c\ud604\ub41c\ub2e4.<\/strong> \uc65c \uadf8\ub7f0\uc9c0 \ub0b4\ubd80\ub97c quantizeFromRgb888 \ud568\uc218\uc640 \uadf8 \ub0b4\ubd80\uc5d0\uc11c \ud638\ucd9c\ud558\ub294 modifyWordWidth \ud568\uc218\ub97c \uc0b4\ud3b4\ubcf4\uc790<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">private static int quantizeFromRgb888(int color) {\n    int r = <em>modifyWordWidth<\/em>(Color.<em>red<\/em>(color), 8, <em>QUANTIZE_WORD_WIDTH<\/em>);\n    int g = <em>modifyWordWidth<\/em>(Color.<em>green<\/em>(color), 8, <em>QUANTIZE_WORD_WIDTH<\/em>);\n    int b = <em>modifyWordWidth<\/em>(Color.<em>blue<\/em>(color), 8, <em>QUANTIZE_WORD_WIDTH<\/em>);\n    return r &lt;&lt; (<em>QUANTIZE_WORD_WIDTH <\/em>+ <em>QUANTIZE_WORD_WIDTH<\/em>) | g &lt;&lt; <em>QUANTIZE_WORD_WIDTH <\/em>| b;\n}\n\nprivate static int modifyWordWidth(int value, int currentWidth, int targetWidth) {\n    final int newValue;\n    if (targetWidth > currentWidth) {\n        newValue = value &lt;&lt; (targetWidth - currentWidth);\n    } else {\n        newValue = value >> (currentWidth - targetWidth);\n    }\n    return newValue &amp; ((1 &lt;&lt; targetWidth) - 1);\n}<\/pre>\n\n\n\n<p>\uc2e4\uc81c\ub85c\ub294 modifyWordWidth \ud638\ucd9c\uc2dc\uc5d0 \uc804\ub2ec\ud558\ub294 \uc778\uc218\uc778 currentWidth \uc640 targetWidth\ub294 \ub77c\uc774\ube0c\ub7ec\ub9ac \uc678\ubd80\uc5d0\uc11c\ub294 \ubcc0\uacbd\uc774 \ubd88\uac00\ub2a5 \ud558\ub2e4. \uadf8\ub7ec\ubbc0\ub85c \uc704 \ud568\uc218\ub97c \uc880 \ub354 \ub2e8\uc21c\ud654 \ud558\uc790\uba74 \ub2e4\uc74c\uacfc \uac19\ub2e4. (<em>QUANTIZE_WORD_WIDTH<\/em> = 5)<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>private static int quantizeFromRgb888(int color) {\n    int r = <em>modifyWordWidth<\/em>(Color.<em>red<\/em>(color));\n    int g = <em>modifyWordWidth<\/em>(Color.<em>green<\/em>(color));\n    int b = <em>modifyWordWidth<\/em>(Color.<em>blue<\/em>(color));\n    return r &lt;&lt; (<em>5 <\/em>+ <em>5<\/em>) | g &lt;&lt; <em>5 <\/em>| b;\n}\n\nprivate static int modifyWordWidth(int value) {\n    int newValue = value >> 3;\n    return newValue &amp; ((1 &lt;&lt; 5) - 1);\n}<\/code><\/pre>\n\n\n\n<p>\ube44\ud2b8 \uc5f0\uc0b0\uc790\uc5d0 \uc775\uc219\ud558\uc9c0 \uc54a\ub2e4\uba74, \uc774 \ucf54\ub4dc\uac00 \uc5b4\ub835\uac8c \ub290\uaef4\uc9c8 \uc218 \uc788\ub2e4. (\uc774\ubc88 \uae30\ud68c\uc5d0 \ube44\ud2b8\uc5f0\uc0b0\uc790\ub97c \ub2e4\uc2dc \ud55c\ubc88 \uc0b4\ud3b4\ubcf4\uc790!)<\/p>\n\n\n\n<p>\ub2e4\uc74c\uacfc \uac19\uc740 \ud53d\uc140 \uac12\uc774 \uc788\ub2e4\uace0 \uac00\uc815\ud574\ubcf4\uc790<\/p>\n\n\n\n<p><strong>|   RED (255) |  GREEN (170) |   BLUE (240)  |<br>| 1 1 1 1 1 1 1 1 | 1 0 1 0 1 0 1 0 | 1 1 1 1 0 0 0 0 | <\/strong><\/p>\n\n\n\n<p>quantizeFromRgb888\ub97c \ud638\ucd9c\ud558\uba74 \ud53d\uc140\uac12\uc758 \ube44\ud2b8\ub97c \uc624\ub978\ucabd\uc73c\ub85c 3\ubc88 \uc26c\ud504\ud2b8 \ud588\ub2e4\uac00 \ub2e4\uc2dc \uc67c\ucabd\uc73c\ub85c 3\ubc88 \uc26c\ud504\ud2b8 \ud558\uba74\uc11c \uc591\uc790\ud654\ub97c \uc9c4\ud589\ud55c\ub2e4. \uadf8\ub7ec\uba74 \ub2e4\uc74c\uacfc \uac19\uc740 \uacb0\uacfc\ub97c \uc5bb\uac8c \ub41c\ub2e4.<\/p>\n\n\n\n<p><strong>|   RED (248)   |  GREEN (168) |   BLUE (240)  |<br>| 1 1 1 1 1 0 0 0 | 1 0 1 0 1 0 0 0 | 1 1 1 1 0 0 0 0 | <\/strong><\/p>\n\n\n\n<p>\uac12\uc774 \ub2ec\ub77c\uc84c\uc9c0\ub9cc \uc0c9\uc0c1\uc744 \ub208\uc73c\ub85c \ubcfc \ub54c\ub294 \ud070 \ucc28\uc774\ub97c \ub290\ub07c\uae30 \uc5b4\ub824\uc6b0\uba70, \uc774\ubbf8\uc9c0\uc5d0\uc11c \uc5f0\uc18d\ub418\ub294 \ube44\uc2b7\ud55c \ud53d\uc140\uac12\ub4e4\uc744 \uadf8\ub8f9\ud654 \ud560 \uc218 \uc788\ub2e4.<\/p>\n\n\n\n<figure class=\"wp-block-gallery has-nested-images columns-default is-cropped wp-block-gallery-1 is-layout-flex\">\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" loading=\"lazy\" width=\"1024\" height=\"346\" data-id=\"46627\"  src=\"https:\/\/www.charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.17-1-1024x346.png\" alt=\"\" class=\"wp-image-46627\" srcset=\"https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.17-1-1024x346.png 1024w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.17-1-300x101.png 300w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.17-1-768x259.png 768w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.17-1-1536x519.png 1536w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.17-1.png 1854w\" sizes=\"(max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" loading=\"lazy\" width=\"1024\" height=\"366\" data-id=\"46628\"  src=\"https:\/\/www.charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.10-1-1024x366.png\" alt=\"\" class=\"wp-image-46628\" srcset=\"https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.10-1-1024x366.png 1024w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.10-1-300x107.png 300w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.10-1-768x275.png 768w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.10-1-1536x549.png 1536w, https:\/\/charlezz.com\/wordpress\/wp-content\/uploads\/2023\/08\/www.charlezz.com-palette--2023-08-31--11.39.10-1.png 1824w\" sizes=\"(max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n<\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">2. \ud788\uc2a4\ud1a0\uadf8\ub7a8 \ub9cc\ub4e4\uae30<\/h3>\n\n\n\n<p>\uc774 \ud3ec\uc2a4\ud305\uc5d0\uc11c \ub9d0\ud558\ub294 \ud788\uc2a4\ud1a0\uadf8\ub7a8\uc774\ub780 \uc774\ubbf8\uc9c0\ub0b4\uc5d0 \ud3ec\ud568\ub41c \ub3d9\uc77c \ud53d\uc140\uac12\ub4e4\uc758 \uac1c\uc218\ub97c \ubc30\uc5f4\uc5d0 \uce74\uc6b4\ud2b8 \ud574\ub454\uac83\uc744 \uc758\ubbf8\ud55c\ub2e4. <\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>int&#91;] hist = new int&#91;1 &lt;&lt; (QUANTIZE_WORD_WIDTH * 3)];<\/code><\/pre>\n\n\n\n<p>\ucc44\ub110\ub2f9 8\ube44\ud2b8\ub85c \ud45c\ud604\ud558\ub294 RGB\ud3ec\ub9f7\uc5d0 \ub300\ud55c \ud788\uc2a4\ud1a0\uadf8\ub7a8\uc744 \ub9cc\ub4dc\ub824\uba74 2^(3*8) = 2^24 = 16777216 \uae38\uc774\uc758 \ubc30\uc5f4\uc774 \ud544\uc694\ud558\uc9c0\ub9cc, \uc704 \uacfc\uc815\uc5d0\uc11c \ud53d\uc140\uc744 5\ube44\ud2b8\ub85c \uc591\uc790\ud654 \ud588\uae30 \ub54c\ubb38\uc5d0 \ubc30\uc5f4\uc758 \uae38\uc774\ub294 2^(3*5) = 2^15 = 32768\uc774 \ub41c\ub2e4. \uc989 \ucd5c\ub300 32768\uac1c\uc758 \uceec\ub7ec\ub85c \uc774\ubbf8\uc9c0\uac00 \ud45c\ud604\ub41c\ub2e4.<\/p>\n\n\n\n<p>\ud788\uc2a4\ud1a0\uadf8\ub7a8 \uc0dd\uc131\uc740 \uc704\uc5d0\uc11c \ub2e4\ub8e8\uc5c8\ub358 \ud53d\uc140 \uc591\uc790\ud654\ub97c \uc9c4\ud589\ud55c \uc9c1\ud6c4\uc5d0 \ubc14\ub85c \uc774\ub8e8\uc5b4 \uc9c4\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>for (int i = 0; i &lt; pixels.length; i++) {\n    final int quantizedColor = quantizeFromRgb888(pixels&#91;i]);\n    pixels&#91;i] = quantizedColor;\n<strong>    \/\/ \ud788\uc2a4\ud1a0\uadf8\ub7a8 \ub9cc\ub4e4\uae30\n    hist&#91;quantizedColor]++;\n<\/strong>}<\/code><\/pre>\n\n\n\n<p>\ud788\uc2a4\ud1a0\uadf8\ub7a8\uc744 \ub9cc\ub4e4\uace0 \ub098\uba74 \ub2e4\uc74c\uacfc \uac19\uc774 \uc774\ubbf8\uc9c0\uc5d0\uc11c \uba87\uac1c\uc758 \uceec\ub7ec\uac00 \uc0ac\uc6a9\ub418\uc5c8\ub294\uc9c0 \ud655\uc778\ud558\ub294 \uacfc\uc815\uc744 \uac70\uce5c\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>int distinctColorCount = 0; \/\/ \uc0ac\uc6a9\ub41c \uceec\ub7ec \uac2f\uc218\nfor (int color = 0; color &lt; hist.length; color++) {\n    ...\n    if (hist&#91;color] > 0) {\n        distinctColorCount++;\n    }\n}<\/code><\/pre>\n\n\n\n<p>\uc0ac\uc6a9\ub41c \uceec\ub7ec \uac2f\uc218 \uacc4\uc0b0\uc774 \ub05d\ub0ac\ub2e4\uba74, \uc0ac\uc6a9\ub41c \uceec\ub7ec\ub9cc \ud3ec\ud568\ud558\ub294 \ubc30\uc5f4\uc744  \uc0dd\uc131\ud55c\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>final int&#91;] colors = mColors = new int&#91;distinctColorCount];\nint distinctColorIndex = 0;\nfor (int color = 0; color &lt; hist.length; color++) {\n    if (hist&#91;color] > 0) {\n        colors&#91;distinctColorIndex++] = color;\n    }\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">3. \uc784\uc758\uc758 \uc218\ub85c \uceec\ub7ec \uac2f\uc218\ub97c \uc904\uc774\uae30<\/h3>\n\n\n\n<p>median cut\uc774 \uc801\uc6a9\ub418\ub294 \uac00\uc7a5 \uc911\uc694\ud55c \ubd80\ubd84\uc774\ub2e4. \ud53d\uc140 \uc591\uc790\ud654\ub97c \ud1b5\ud574 \uc0ac\uc6a9\ub41c \uceec\ub7ec \uac2f\uc218\ub97c \uc904\uc774\uae30\ub294 \ud588\uc9c0\ub9cc, \ucda9\ubd84\ud558\uc9c0 \uc54a\ub2e4. \ub0b4\ubd80\uc5d0\uc11c quantizePixels\ub77c\ub294 \uba54\uc11c\ub4dc \ud638\ucd9c\uc744 \ud1b5\ud574 \uae30\ubcf8\uac12\uc73c\ub85c \ucd5c\ub300 16\uceec\ub7ec\ub97c \ucd94\ucd9c\ud558\uac8c \ub41c\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>private List&lt;Palette.Swatch> quantizePixels(int maxColors) { \/\/ maxColors=16\n\n    PriorityQueue&lt;Vbox> pq = new PriorityQueue&lt;>(maxColors, VBOX_COMPARATOR_VOLUME);\n    \n    pq.offer(new Vbox(0, mColors.length - 1));\n\n    splitBoxes(pq, maxColors);\n\n    return generateAverageColors(pq);\n}\n\n\ub2e4\uc18c \ub0b4\uc6a9\uc774 \ubcf5\uc7a1\ud560 \uc218 \uc788\uc5b4 \uc8fc\uc694 \uc6a9\uc5b4\ub97c \uc815\ub9ac\ud558\uace0\uc790 \ud55c\ub2e4.<\/code><\/pre>\n\n\n\n<ul>\n<li>Palette.Swatch : Palette \ub77c\uc774\ube0c\ub7ec\ub9ac\uac00 \ucd94\ucd9c\ud55c \uceec\ub7ec\ub97c \ud45c\ud604\ud558\ub294 \ud074\ub798\uc2a4<\/li>\n\n\n\n<li>PriorityQueue : java.util \ud328\ud0a4\uc9c0\uc5d0 \ud3ec\ud568\ub41c \ub370\uc774\ud130 \uad6c\uc870. \uae30\ubcf8\uc801\uc73c\ub85c \uc77c\ubc18\uc801\uc778 \ud050\uc640 \uac19\uc9c0\ub9cc, comparator \ub85c\uc9c1\uc5d0 \ub530\ub77c \uc694\uc18c\ub4e4\uc744 \uc7ac\uc815\ub82c\ud55c\ub2e4.<\/li>\n\n\n\n<li>Vbox : \uc0c9 \uacf5\uac04(color space)\uc5d0\uc11c \uc54c\ub9de\ub294 \uc601\uc5ed\uc758 \ubc15\uc2a4\ub85c \ud45c\ud604\ud55c\ub2e4. (\uc911\uc694)<\/li>\n\n\n\n<li>VBOX_COMPARATOR_VOLUME : PriorityQueue&lt;Vbox>\uc5d0 \uc0ac\uc6a9\ub420 comparator\ub2e4. \ube44\uad50\ud560 \ub450 Vbox \uc5d0\uc11c \ubcfc\ub968\uc774 \ub354 \ud070 \uac83\uc744 \uc6b0\uc120\uc801\uc73c\ub85c \uc815\ub82c\ud55c\ub2e4. \ubcfc\ub968\uc774\ub780 RGB \uac01 \ucc44\ub110 \ubcc4 \uceec\ub7ec \ud45c\ud604 \ubc94\uc704\ub97c \ub2e4 \ub354\ud558\uc5ec \uc5bc\ub9c8\ub098 \ub354 \ubc15\uc2a4\uac00 \ud070\uc9c0\ub97c \uc758\ubbf8 \ud55c\ub2e4. \ubcf8\ubb38 \uc704\uc5d0\uc11c median cut \uc124\uba85\uc5d0 \ud3ec\ud568\ub41c \uc0bd\ud654\uc5d0\uc11c \ud050\ube0c \ubaa8\uc591\uc758 \uc774\ubbf8\uc9c0\ub97c \ucc38\uc870\ud558\uc790.<\/li>\n<\/ul>\n\n\n\n<p>\uc704 \ucf54\ub4dc\uc5d0\uc11c \ub450\ubc88\uc9f8 \ub77c\uc778\uc5d0 \uc788\ub294 <strong>pq.offer(new Vbox(&#8230;));<\/strong> \uc744 \ubcf4\uba74 \ucd5c\ucd08\uc5d0 pq\uc5d0\ub294 Vbox \uac1d\uccb4\uac00 \ud558\ub098\ub9cc \uc0bd\uc785\ub41c\ub2e4. \uc774 \ubc15\uc2a4\ub294 splitBoxes \ub0b4\ubd80\uc5d0\uc11c \uc7ac\uadc0\uc801\uc73c\ub85c \ubc15\uc2a4\ub97c \ucabc\uac1c\uac00\uba74\uc11c pq\uc758 \uc544\uc774\ud15c\uc744 \ub298\ub824\ub098\uac04\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>private void splitBoxes(final PriorityQueue&lt;Vbox> queue, final int maxSize) {\n    while (queue.size() &lt; maxSize) {\n        final Vbox vbox = queue.poll();\n        if (vbox != null &amp;&amp; vbox.canSplit()) {\n            \/\/ \ubc15\uc2a4\ub97c \ucabc\uac1c\uc5b4 \uc0bd\uc785\n            queue.offer(vbox.splitBox());\n            \/\/ \uaebc\ub0b8 \ubc15\uc2a4\ub97c \ub2e4\uc2dc \uc7ac\uc0bd\uc785\n            queue.offer(vbox);\n        } else {\n            \/\/ \ub354 \uc774\uc0c1 \ubc15\uc2a4\ub97c \ucabc\uac24 \uc218 \uc5c6\uc73c\ubbc0\ub85c \ubc18\ud658\n            return;\n        }\n    }\n}<\/code><\/pre>\n\n\n\n<p>\uc2e4\uc81c\ub85c \ubc15\uc2a4\ub97c \ucabc\uac1c\ub294 \ub85c\uc9c1\uc740 Vbox.split()\uc5d0 \uc788\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>final Vbox splitBox() {\n    ...\n    \/\/ \uac01 \ucc44\ub110\uc5d0\uc11c \ucc44\ub110\ud3ed\uc774 \uac00\uc7a5 \ud070 \ub140\uc11d\uc758 \uc911\uc559\uac12\uc744 \ucc3e\ub294\ub2e4\n    final int splitPoint = findSplitPoint();\n\n    Vbox newBox = new Vbox(splitPoint + 1, mUpperIndex);\n\n    \/\/ mUpperIndex \uc7ac\uc124\uc815 \ubc0f fitBox() \ud638\ucd9c\ub85c \ubc15\uc2a4\uc758 \uacbd\uacc4\uac12\uc744 \ub2e4\uc2dc \uc7ac\uacc4\uc0b0\ud55c\ub2e4.\n    mUpperIndex = splitPoint;\n    fitBox();\n    return newBox;\n}<\/code><\/pre>\n\n\n\n<p>\uc911\uc559 \uac12\uc744 \ucc3e\ub294 \ub85c\uc9c1(findSplitPoint)\uc774 \ub2e4\uc18c \ubcf5\uc7a1\ud558\ub2e4. \uc774 \ud3ec\uc2a4\ud305\uc5d0\uc11c\ub294 \uc774\ud574\ub97c \ub3d5\uae30\uc704\ud55c \ubd80\ubd84\uc801\uc778 \uc18c\uc2a4\ucf54\ub4dc\ub9cc \uc18c\uac1c\ud558\ubbc0\ub85c \uc774 \ud3ec\uc2a4\ud305\uc744 \uc77d\uc740 \uc774\ud6c4 <a href=\"https:\/\/androidx.tech\/artifacts\/palette\/palette\/1.0.0-source\/androidx\/palette\/graphics\/ColorCutQuantizer.java.html\">\uc804\uccb4 \uc18c\uc2a4\ucf54\ub4dc<\/a>\ub97c \ud655\uc778\ud558\ub294 \uac83\uc744 \uad8c\uc7a5\ud55c\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>final int findSplitPoint() {\n    \/\/ R(-3),G(-2),B(-1) \uc911 \uac00\uc7a5 \ucc44\ub110 \ud3ed\uc774 \ud070 \ucc44\ub110(dimension)\uc744 \ucc3e\ub294\ub2e4.\n    final int longestDimension = getLongestColorDimension(); \n    final int&#91;] colors = mColors;\n    final int&#91;] hist = mHistogram;\n\n    \/\/ \uac00\uc7a5 \ud070 \uceec\ub7ec \ucc44\ub110\uc744 \uae30\ubc18\uc73c\ub85c \ubc15\uc2a4 \ub0b4 \ucc44\ub110\uc21c\uc11c \ubc14\uafbc\ub2e4.\n    \/\/ \uc77c\ubc18\uc801\uc73c\ub85c RGB \uc21c\uc73c\ub85c \ud45c\ud604\ud558\uc9c0\ub9cc, longestDimension\uc5d0 \ub530\ub77c\n    \/\/ RGB, GRB \ub610\ub294 BRG \ub85c \uc2a4\uc651\ud55c\ub2e4.\n    modifySignificantOctet(\n        colors, \n        longestDimension, \n        mLowerIndex, \n        mUpperIndex\n    );\n    \n    \/\/ \uc804\uccb4 \uceec\ub7ec\ubc30\uc5f4\uc5d0\uc11c \ubc15\uc2a4 \ub0b4 \ubc94\uc704(mLowerIndex ~ mUpperIndex+1)\ub9cc \uc791\uc740\uc21c\uc73c\ub85c \uc7ac\uc815\ub82c\n    Arrays.sort(colors, mLowerIndex, mUpperIndex + 1);\n\n    \/\/ RGB\ub85c \ub2e4\uc2dc \ud45c\ud604\ud558\uae30 \uc704\ud574 \ud55c\ubc88 \ub354 modifySignificantOctet \ud638\ucd9c\ub85c \ucc44\ub110\uc744 \uc2a4\uc651\n    modifySignificantOctet(\n        colors, \n        longestDimension, \n        mLowerIndex, \n        mUpperIndex\n    );\n    \n    \/\/ \uceec\ub7ec\uc758 \uc911\uc559\uac12\uc744 \ucc3e\uc544 \ubc18\ud658\ud558\ub294 \uacfc\uc815\uc73c\ub85c, fitBox() \ud638\ucd9c \uc774\ud6c4 mPopulation\uc774 \uacb0\uc815\ub41c\ub2e4.\n    \/\/ mPopulation\uc740 Vbox\uac00 \ud45c\ud604\ud560 \uc218 \uc788\ub294 \uceec\ub7ec\uc758 \uac2f\uc218\n    final int midPoint = mPopulation \/ 2;    \n    for (int i = mLowerIndex, count = 0; i &lt;= mUpperIndex; i++)  {\n        count += hist&#91;colors&#91;i]];\n        if (count >= midPoint) {\n            return Math.min(mUpperIndex - 1, i);\n        }\n    }\n    return mLowerIndex;\n}<\/code><\/pre>\n\n\n\n<p>\uc704 \uacfc\uc815\uc744 \uac70\uccd0 maxColors \ub9cc\ud07c Vbox\uac00 \ucabc\uac1c\uc9c0\uba74, generateAverageColors\ub97c \ud638\ucd9c\ud558\uc5ec \ucd5c\uc885\uc801\uc778 \uceec\ub7ec\uc14b\uc744 \ub9cc\ub4e4\uac8c \ub41c\ub2e4.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>private List&lt;Palette.Swatch> generateAverageColors(Collection&lt;Vbox> vboxes) {\n    ArrayList&lt;Palette.Swatch> colors = new ArrayList&lt;>(vboxes.size());\n    for (Vbox vbox : vboxes) {\n        Palette.Swatch swatch = vbox.getAverageColor();\n        colors.add(swatch);\n    }\n    return colors;\n}<\/code><\/pre>\n\n\n\n<p>\uae30\ubcf8\uc801\uc73c\ub85c \ucd5c\ub300 16\uac1c\uc758 Vbox\uac00 \uc0dd\uc131\ub418\uc5c8\uc744 \uac83\uc774\uace0, \ud558\ub098\uc758 Vbox\uac00 \ud45c\ud604\ud558\ub294 \uceec\ub7ec\ubc94\uc704\ub0b4\uc5d0\uc11c \ud3c9\uade0 \uceec\ub7ec \uac12\uc744 \uad6c\ud558\uc5ec \ucd5c\uc885\uc801\uc73c\ub85c Swatch\ub85c \ubc18\ud658\ud55c\ub2e4. \ucd5c\ub300 16\uac1c\uc758 Swatch\uac00 \uc0dd\uc131\uc774 \ub420 \uac83 \uc774\uba70, \uc774\ub85c\uc368 \uceec\ub7ec \ucd94\ucd9c\uc774 \ub05d\ub09c\ub2e4. <\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Target<\/h2>\n\n\n\n<p>Palette\uc5d0\ub294 Target(\ud074\ub798\uc2a4)\uc774\ub77c\ub294 \uac1c\ub150\uc744 \ub450\uc5b4, \ucd94\ucd9c\ud55c Swatch \ubaa9\ub85d\uc5d0\uc11c \ub2e4\uc2dc \ud55c\ubc88 \uc0ac\uc6a9\uc790\uac00 \uc6d0\ud558\ub294 \uceec\ub7ec\ub85c \uc815\uc81c\ud558\ub294 \uacfc\uc815\uc744 \uac70\uce5c\ub2e4.<\/p>\n\n\n\n<p>\ud0c0\uac9f\uc744 \uc124\uc815\ud558\ub294 \uae30\uc900\uc740 \ucc44\ub3c4(Saturation)\uc640 \ubc1d\uae30(Luminance)\ub2e4<\/p>\n\n\n\n<p>\uae30 \uc815\uc758\ub41c Target\uc740 \ub2e4\uc74c\uacfc \uac19\ub2e4.<\/p>\n\n\n\n<ul>\n<li>Light Vibrant : \ucc44\ub3c4 \u2191, \ubc1d\uae30 \u2191<\/li>\n\n\n\n<li>Vibrant : \ucc44\ub3c4 \u2191<\/li>\n\n\n\n<li>Dark Vibrant: \ucc44\ub3c4 \u2191, \ubc1d\uae30 \u2193<\/li>\n\n\n\n<li>Light Muted: \ucc44\ub3c4 \u2193, \ubc1d\uae30 \u2191<\/li>\n\n\n\n<li>Muted: \ucc44\ub3c4 \u2193<\/li>\n\n\n\n<li>Dark Muted: \ucc44\ub3c4 \u2193, \ubc1d\uae30 \u2193<\/li>\n<\/ul>\n\n\n\n<p>\ucc44\ub3c4 \ubc0f \ubc1d\uae30\ub294 0f~1f \ub85c \ud45c\ud604\ub418\uba70, \ucd94\ucd9c\ub41c Swatch\ub4e4 \uc911\uc5d0\uc11c \ucee4\uc2a4\ud140 \ud0c0\uac9f\uc815\uc758 \ud558\uc5ec \uc774\uc5d0 \ubd80\ud569\ud558\ub294 Swatch\ub97c \ub2e4\uc2dc \ubf51\uc544 \ub0bc \uc218\ub3c4 \uc788\ub2e4.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\ub9c8\uce58\uba70<\/h2>\n\n\n\n<p>median cut\uc744 \uae30\ubc18\uc73c\ub85c \ud55c Palette\uc758 \ub0b4\ubd80 \ub3d9\uc791 \uc6d0\ub9ac\ub97c \uc54c\uc544\ubcf4\uc558\ub2e4. \ub9ce\uc740 \ub0b4\uc6a9\uc774 \uc0dd\ub7b5 \ub418\uc5c8\uc9c0\ub9cc, \ub300\ubd80\ubd84 \ubd80\uc218\uc801\uc778 \ub0b4\uc6a9\uc774\ub77c \ud310\ub2e8\ub418\uc5b4 \uc5b8\uae09\ud558\uc9c0 \uc54a\uc558\ub2e4. \uc804\uccb4\uc801\uc778 \ub0b4\uc6a9\uc740 <a href=\"https:\/\/developer.android.com\/develop\/ui\/views\/graphics\/palette-colors\">\uacf5\uc2dd\ubb38\uc11c<\/a>\uc640 <a href=\"https:\/\/androidx.tech\/artifacts\/palette\/palette\/1.0.0\">\uc18c\uc2a4\ucf54\ub4dc<\/a>\ub97c \ud655\uc778\ud560 \uc218 \uc788\ub2e4.<\/p>\n\n\n\n<p>Palette\ub294 \ud65c\uc6a9\ub3c4\uac00 \ub192\uc740 \ub77c\uc774\ube0c\ub7ec\ub9ac\uc774\uae30 \ub54c\ubb38\uc5d0 \ub2e4\ub978 \ud50c\ub7ab\ud3fc\uc5d0\uc11c\ub3c4 \uc548\ub4dc\ub85c\uc774\ub4dc\uc758 Palette\ub97c \uce74\ud53c\ud558\uc5ec \ub9cc\ub4e0 \ub77c\uc774\ube0c\ub7ec\ub9ac \ub4e4\uc774 \ub9ce\ub2e4. \ub098\ub3c4 KMP\ub97c \ud1b5\ud574 \uc774 \ub77c\uc774\ube0c\ub7ec\ub9ac\ub97c \ucf54\ud2c0\ub9b0\uc73c\ub85c \uc7ac\uc791\uc131\ud558\uace0, iOS, Android, Web\uc5d0\uc11c \ub3d9\uc77c\ud55c \uceec\ub7ec\ub97c \ubf51\ub294 \uacb0\uacfc\ub97c \uae30\ub300\ud558\uba70, \uc0bd\uc9c8 \ud588\uc73c\ub098 \uc2e4\ud328\ud55c \uacbd\ud5d8\uc774 \uc788\ub2e4. \uc2e4\ud328\uae30\ub97c \ud655\uc778\ud558\uace0 \uc2f6\ub2e4\uba74, <a href=\"https:\/\/www.charlezz.com\/?p=46606\"><strong>\uc774\uc804 \ud3ec\uc2a4\ud305<\/strong><\/a>\uc744 \ucc38\uc870\ud558\uc790.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Palette \ub77c\uc774\ube0c\ub7ec\ub9ac\ub294 \uc774\ubbf8\uc9c0\uc5d0\uc11c \ub208\uc5d0 \ub744\ub294 \uc0c9\uc0c1\ub4e4\uc744 \ucd94\ucd9c\ud574\uc8fc\ub294 \ub77c\uc774\ube0c\ub7ec\ub9ac\ub2e4. \uc774 \ub77c\uc774\ube0c\ub7ec\ub9ac\uac00 \uc5b4\ub5a4\uc2dd\uc73c\ub85c \ub3d9\uc791\ud558\ub294\uc9c0 \ud655\uc778\ud574\ubcf4\uc790. Median cut Palette \ub77c\uc774\ube0c\ub7ec\ub9ac\ub294 Median cut \uc54c\uace0\ub9ac\uc998\uc744 \uae30\ubc18\uc73c\ub85c \ub3d9\uc791\ud55c\ub2e4. Median cut\uc740 \ub9d0 \uadf8\ub300\ub85c \uc911\uc559\uac12\uc744 \uc790\ub978\ub2e4\ub294 \ub73b\uc774\ub2e4. \uac00\uc7a5 \uae34 \ucc28\uc6d0\uc744 \ub530\ub77c \uc911\uc559\uac12\uc774 \uc788\ub294 \uc9c0\uc810(\uc778\ub371\uc2a4)\uc5d0\uc11c \uac01 \ub370\uc774\ud130 \uc9d1\ud569\uc744 \uc7ac\uadc0\uc801\uc73c\ub85c \uc790\ub974\uace0 \uc784\uc758 \uac1c\uc218\uc758 \ucc28\uc6d0 \ub370\uc774\ud130\ub97c \uc77c\ub828\uc758 \uc9d1\ud569\uc73c\ub85c \uc815\ub82c\ud558\ub294 \uc54c\uace0\ub9ac\uc998\uc774\ub2e4. \uc774 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"om_disable_all_campaigns":false,"inline_featured_image":false,"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0},"categories":[24],"tags":[],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/charlezz.com\/index.php?rest_route=\/wp\/v2\/posts\/46623"}],"collection":[{"href":"https:\/\/charlezz.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/charlezz.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/charlezz.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/charlezz.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=46623"}],"version-history":[{"count":2,"href":"https:\/\/charlezz.com\/index.php?rest_route=\/wp\/v2\/posts\/46623\/revisions"}],"predecessor-version":[{"id":46631,"href":"https:\/\/charlezz.com\/index.php?rest_route=\/wp\/v2\/posts\/46623\/revisions\/46631"}],"wp:attachment":[{"href":"https:\/\/charlezz.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=46623"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/charlezz.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=46623"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/charlezz.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=46623"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}