{"id":77016,"date":"2026-02-23T20:42:42","date_gmt":"2026-02-23T12:42:42","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/77016.html"},"modified":"2026-02-23T20:42:42","modified_gmt":"2026-02-23T12:42:42","slug":"%e3%80%90egui%e3%80%91color32-%e4%bd%bf%e7%94%a8%e6%89%8b%e5%86%8c","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/77016.html","title":{"rendered":"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c"},"content":{"rendered":"<h2>Color32 \u4f7f\u7528\u624b\u518c&#xff08;\u4fee\u8ba2\u7248&#xff09;<\/h2>\n<h3>\u4e00\u3001\u7b80\u4ecb<\/h3>\n<p>Color32 \u662f egui\/ecolor \u4e2d\u6700\u5e38\u7528\u7684\u989c\u8272\u7c7b\u578b&#xff0c;\u91c7\u752832\u4f4d\u5b58\u50a8\u7684\u9884\u4e58Alpha sRGBA\u683c\u5f0f\u3002\u5b83\u662f\u9762\u5411\u663e\u793a\u8bbe\u5907\u7684\u989c\u8272\u683c\u5f0f&#xff0c;\u6240\u6709\u64cd\u4f5c\u90fd\u5728\u4f3d\u9a6c\u7a7a\u95f4\u8fdb\u884c\u2014\u2014\u8fd9\u610f\u5473\u7740\u5b83\u7684\u6570\u503c\u53d8\u5316\u4e0e\u4eba\u773c\u611f\u77e5\u4e00\u81f4&#xff0c;\u540c\u65f6\u5b8c\u7f8e\u5339\u914d\u663e\u793a\u5668\u7684\u7269\u7406\u7279\u6027\u3002<\/p>\n<h4>\u4ec0\u4e48\u662f\u4f3d\u9a6c\u7a7a\u95f4&#xff1f;<\/h4>\n<p><span class=\"token comment\">\/\/ \u4f3d\u9a6c\u7a7a\u95f4\u662f\u8fde\u63a5\u7269\u7406\u4e16\u754c\u548c\u4eba\u773c\u611f\u77e5\u7684\u6865\u6881<\/span><br \/>\n\u7269\u7406\u5149\u5f3a<span class=\"token punctuation\">(<\/span>\u7ebf\u6027<span class=\"token punctuation\">)<\/span> \u2190<span class=\"token punctuation\">(<\/span>\u03b3\u2248<span class=\"token number\">2.2<\/span><span class=\"token punctuation\">)<\/span>\u2192 \u4f3d\u9a6c\u503c<span class=\"token punctuation\">(<\/span>\u5b58\u50a8<span class=\"token punctuation\">)<\/span> \u2190<span class=\"token punctuation\">(<\/span>\u03b3\u2248<span class=\"token number\">0.45<\/span><span class=\"token punctuation\">)<\/span>\u2192 \u4eba\u773c\u611f\u77e5<\/p>\n<p><span class=\"token comment\">\/\/ \u7b80\u5355\u7406\u89e3&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u5728\u4f3d\u9a6c\u7a7a\u95f4&#xff0c;\u6570\u503c\u589e\u52a0\u4e00\u500d&#xff0c;\u4eba\u773c\u611f\u89c9\u4eae\u5ea6\u589e\u52a0\u4e00\u500d<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u5728\u7269\u7406\u4e16\u754c&#xff0c;\u8fd9\u5bf9\u5e94\u7740\u7ea64.6\u500d\u7684\u5149\u5f3a\u53d8\u5316<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u8fd9\u79cd\u8bbe\u8ba1\u8ba9\u5b58\u50a8\u503c\u65e2\u7b26\u5408\u76f4\u89c9&#xff0c;\u53c8\u5339\u914d\u663e\u793a\u5668\u786c\u4ef6<\/span><\/p>\n<hr \/>\n<h3>\u4e8c\u3001\u5feb\u901f\u5f00\u59cb<\/h3>\n<h4>2.1 \u521b\u5efa\u989c\u8272<\/h4>\n<p><span class=\"token keyword\">use<\/span> <span class=\"token namespace\">ecolor<span class=\"token punctuation\">::<\/span><\/span><span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f7f\u7528\u9884\u5b9a\u4e49\u5e38\u91cf<\/span><br \/>\n<span class=\"token keyword\">let<\/span> red <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">RED<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> transparent <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">TRANSPARENT<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> black <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">BLACK<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> white <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">WHITE<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4eceRGB\u521b\u5efa&#xff08;\u4e0d\u900f\u660e&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> custom <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">180<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">220<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4ece\u7070\u5ea6\u521b\u5efa<\/span><br \/>\n<span class=\"token keyword\">let<\/span> gray <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_gray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u89c6\u89c9\u4e0a50%\u7684\u7070<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4ece\u5e26\u900f\u660e\u5ea6\u7684RGBA\u521b\u5efa&#xff08;\u63a8\u8350\u65b9\u5f0f&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> semi_red <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<h4>2.2 \u5e38\u7528\u9884\u5b9a\u4e49\u989c\u8272<\/h4>\n<table>\n<tr>\u989c\u8272\u5e38\u91cfRGB\u503c<\/tr>\n<tbody>\n<tr>\n<td align=\"left\">\u900f\u660e<\/td>\n<td align=\"left\">TRANSPARENT<\/td>\n<td align=\"left\">(0,0,0,0)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u9ed1<\/td>\n<td align=\"left\">BLACK<\/td>\n<td align=\"left\">(0,0,0)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u6df1\u7070<\/td>\n<td align=\"left\">DARK_GRAY<\/td>\n<td align=\"left\">(96,96,96)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u7070<\/td>\n<td align=\"left\">GRAY<\/td>\n<td align=\"left\">(160,160,160)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u6d45\u7070<\/td>\n<td align=\"left\">LIGHT_GRAY<\/td>\n<td align=\"left\">(220,220,220)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u767d<\/td>\n<td align=\"left\">WHITE<\/td>\n<td align=\"left\">(255,255,255)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u7ea2<\/td>\n<td align=\"left\">RED<\/td>\n<td align=\"left\">(255,0,0)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u7eff<\/td>\n<td align=\"left\">GREEN<\/td>\n<td align=\"left\">(0,255,0)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u84dd<\/td>\n<td align=\"left\">BLUE<\/td>\n<td align=\"left\">(0,0,255)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u9ec4<\/td>\n<td align=\"left\">YELLOW<\/td>\n<td align=\"left\">(255,255,0)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u9752<\/td>\n<td align=\"left\">CYAN<\/td>\n<td align=\"left\">(0,255,255)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u7d2b<\/td>\n<td align=\"left\">MAGENTA<\/td>\n<td align=\"left\">(255,0,255)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u6a59<\/td>\n<td align=\"left\">ORANGE<\/td>\n<td align=\"left\">(255,165,0)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u68d5<\/td>\n<td align=\"left\">BROWN<\/td>\n<td align=\"left\">(165,42,42)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u7d2b\u7f57\u5170<\/td>\n<td align=\"left\">PURPLE<\/td>\n<td align=\"left\">(128,0,128)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u91d1<\/td>\n<td align=\"left\">GOLD<\/td>\n<td align=\"left\">(255,215,0)<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<hr \/>\n<h3>\u4e09\u3001\u6838\u5fc3\u6982\u5ff5\u7406\u89e3<\/h3>\n<h4>3.1 \u9884\u4e58Alpha (Premultiplied Alpha)<\/h4>\n<p>Color32\u5185\u90e8\u4f7f\u7528\u9884\u4e58Alpha\u683c\u5f0f&#xff0c;\u5373RGB\u503c\u5df2\u7ecf\u4e58\u4ee5\u4e86Alpha\u901a\u9053&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ \u666e\u901aRGBA&#xff08;\u975e\u9884\u4e58&#xff09;&#xff1a;(r, g, b, a)<\/span><br \/>\n<span class=\"token comment\">\/\/ \u9884\u4e58RGBA&#xff1a;(r*a\/255, g*a\/255, b*a\/255, a)<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u793a\u4f8b&#xff1a;50%\u900f\u660e\u7684\u7ea2\u8272<\/span><br \/>\n<span class=\"token keyword\">let<\/span> normal <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>           <span class=\"token comment\">\/\/ \u666e\u901aRGBA<\/span><br \/>\n<span class=\"token keyword\">let<\/span> premultiplied <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token number\">128<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>    <span class=\"token comment\">\/\/ \u9884\u4e58RGBA&#xff08;Color32\u5185\u90e8\u683c\u5f0f&#xff09;<\/span><\/p>\n<p>\u9884\u4e58Alpha\u7684\u4f18\u52bf&#xff1a;<\/p>\n<ul>\n<li>\u2705 \u7edf\u4e00\u5904\u7406\u666e\u901a\u989c\u8272\u548c\u52a0\u6cd5\u989c\u8272&#xff1a;alpha&#061;0\u65f6\u81ea\u7136\u8868\u793a\u5149\u6e90<\/li>\n<li>\u2705 \u66f4\u9ad8\u6548\u7684\u6df7\u5408\u8ba1\u7b97&#xff1a;\u51cf\u5c11\u4e00\u6b21\u4e58\u6cd5<\/li>\n<li>\u2705 GPU\u7eb9\u7406\u683c\u5f0f\u7684\u6807\u51c6&#xff1a;\u7eb9\u7406\u8fc7\u6ee4\u76f4\u63a5\u6b63\u786e<\/li>\n<\/ul>\n<h4>3.2 \u4f3d\u9a6c\u7a7a\u95f4 (Gamma Space)<\/h4>\n<p>Color32\u7684\u6240\u6709\u64cd\u4f5c\u90fd\u5728\u4f3d\u9a6c\u7a7a\u95f4\u8fdb\u884c&#xff0c;\u8fd9\u662f\u7ecf\u8fc7\u6df1\u601d\u719f\u8651\u7684\u8bbe\u8ba1&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ \u4e3a\u4ec0\u4e48\u7528\u4f3d\u9a6c\u7a7a\u95f4&#xff1f;<\/span><br \/>\n<span class=\"token comment\">\/\/ 1. \u5bf9\u4eba\u773c&#xff1a;\u6570\u503c\u53d8\u5316 &#061; \u611f\u77e5\u53d8\u5316<\/span><br \/>\n<span class=\"token keyword\">let<\/span> dark <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_gray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">64<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>   <span class=\"token comment\">\/\/ \u89c6\u89c9\u4e0a25%\u7070<\/span><br \/>\n<span class=\"token keyword\">let<\/span> mid <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_gray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>   <span class=\"token comment\">\/\/ \u89c6\u89c9\u4e0a50%\u7070<\/span><br \/>\n<span class=\"token keyword\">let<\/span> light <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_gray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">192<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u89c6\u89c9\u4e0a75%\u7070<\/span><\/p>\n<p><span class=\"token comment\">\/\/ 2. \u5bf9\u663e\u793a\u5668&#xff1a;\u6570\u503c\u76f4\u63a5\u5bf9\u5e94\u7535\u538b<\/span><br \/>\n<span class=\"token comment\">\/\/ \u663e\u793a\u5668\u4eae\u5ea6 &#061; (\u5b58\u50a8\u503c\/255)^2.2<\/span><br \/>\n<span class=\"token comment\">\/\/ \u5b58\u50a8\u503c128 \u2192 \u4eae\u5ea6 \u2248 22% (\u521a\u597d\u662f\u7269\u7406\u4e0a\u768450%&#xff1f;\u4e0d&#xff0c;\u662f\u611f\u77e5\u4e0a\u768450%)<\/span><\/p>\n<p><span class=\"token comment\">\/\/ 3. \u5bf9\u6574\u4e2a\u7cfb\u7edf&#xff1a;\u5b8c\u7f8e\u95ed\u73af<\/span><br \/>\n<span class=\"token comment\">\/\/ \u7269\u7406\u5149\u5f3a \u2192 \u4f3d\u9a6c\u7f16\u7801 \u2192 \u5b58\u50a8 \u2192 \u663e\u793a\u5668 \u2192 \u4eba\u773c\u611f\u77e5<\/span><br \/>\n<span class=\"token comment\">\/\/     \u2191                                   \u2193<\/span><br \/>\n<span class=\"token comment\">\/\/     \u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500 \u4e92\u76f8\u8865\u507f \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518<\/span><\/p>\n<h4>3.3 \u52a0\u6cd5\u989c\u8272 (Additive Color)\u2014\u2014\u7edf\u4e00\u6846\u67b6\u4e2d\u7684\u7279\u4f8b<\/h4>\n<p>\u52a0\u6cd5\u989c\u8272\u662f\u9884\u4e58Alpha\u683c\u5f0f\u7684\u81ea\u7136\u5ef6\u4f38&#xff0c;\u4e0d\u662f\u53e6\u7c7b&#xff0c;\u800c\u662f\u540c\u4e00\u6570\u5b66\u6846\u67b6\u4e0b\u7684\u4f18\u96c5\u7279\u4f8b&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ \u5728\u9884\u4e58Alpha\u7684\u7edf\u4e00\u6846\u67b6\u4e2d&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u666e\u901a\u989c\u8272&#xff1a;alpha &gt; 0&#xff0c;RGB &#061; \u989c\u8272 \u00d7 alpha<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u52a0\u6cd5\u989c\u8272&#xff1a;alpha &#061; 0&#xff0c;RGB &#061; \u5149\u6e90\u5f3a\u5ea6<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u521b\u5efa\u52a0\u6cd5\u989c\u8272<\/span><br \/>\n<span class=\"token keyword\">let<\/span> additive_red <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb_additive<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u5185\u90e8\u5b58\u50a8&#xff1a;[255, 0, 0, 0]<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u52a0\u6cd5\u989c\u8272\u7684\u7269\u7406\u610f\u4e49&#xff1a;\u5149\u6e90<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u7ea2\u8272\u5149&#xff0c;\u5f3a\u5ea6255<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u4e0d\u906e\u6321\u80cc\u666f&#xff0c;\u53ea\u4f1a\u8ba9\u80cc\u666f\u53d8\u4eae<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u68c0\u67e5\u662f\u5426\u4e3a\u52a0\u6cd5\u989c\u8272<\/span><br \/>\n<span class=\"token keyword\">if<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">is_additive<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token macro property\">println!<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u8fd9\u662f\u5149\u6e90&#xff08;alpha&#061;0&#xff09;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>\u52a0\u6cd5\u989c\u8272\u4e0d\u662f\u7279\u4f8b&#xff0c;\u800c\u662f\u7edf\u4e00\u516c\u5f0f\u7684\u81ea\u7136\u7ed3\u679c&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ \u7edf\u4e00\u7684\u6df7\u5408\u516c\u5f0f&#xff1a;\u7ed3\u679c &#061; \u524d\u666f &#043; \u80cc\u666f * (1-\u03b1_\u524d\u666f)<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u5f53\u524d\u666f\u662f\u52a0\u6cd5\u989c\u8272(\u03b1&#061;0)\u65f6&#xff1a;<\/span><br \/>\n\u7ed3\u679c <span class=\"token operator\">&#061;<\/span> \u524d\u666f <span class=\"token operator\">&#043;<\/span> \u80cc\u666f <span class=\"token operator\">*<\/span> <span class=\"token number\">1<\/span> <span class=\"token operator\">&#061;<\/span> \u524d\u666f <span class=\"token operator\">&#043;<\/span> \u80cc\u666f  <span class=\"token comment\">\/\/ \u76f4\u63a5\u76f8\u52a0&#xff01;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u5f53\u80cc\u666f\u662f\u52a0\u6cd5\u989c\u8272(\u03b1_bg&#061;0)\u65f6&#xff1a;<\/span><br \/>\n\u7ed3\u679c <span class=\"token operator\">&#061;<\/span> \u524d\u666f <span class=\"token operator\">&#043;<\/span> \u80cc\u666f_add <span class=\"token operator\">*<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token operator\">&#8211;<\/span>\u03b1_\u524d\u666f<span class=\"token punctuation\">)<\/span>  <span class=\"token comment\">\/\/ \u80cc\u666f\u88ab\u524d\u666f\u8870\u51cf<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u5f53\u4e24\u8005\u90fd\u662f\u52a0\u6cd5(\u03b1&#061;0)\u65f6&#xff1a;<\/span><br \/>\n\u7ed3\u679c <span class=\"token operator\">&#061;<\/span> \u524d\u666f <span class=\"token operator\">&#043;<\/span> \u80cc\u666f_add  <span class=\"token comment\">\/\/ \u5149\u6e90\u53e0\u52a0<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u6240\u4ee5\u52a0\u6cd5\u989c\u8272\u5b8c\u5168\u878d\u5165\u7edf\u4e00\u516c\u5f0f&#xff0c;\u4e0d\u9700\u8981\u7279\u6b8a\u5904\u7406&#xff01;<\/span><\/p>\n<h4>3.4 \u4f3d\u9a6c\u7a7a\u95f4 vs \u7ebf\u6027\u7a7a\u95f4<\/h4>\n<p><span class=\"token comment\">\/\/ Color32&#xff08;\u4f3d\u9a6c\u7a7a\u95f4&#xff09;- \u7528\u4e8e\u663e\u793a\u548c\u611f\u77e5\u5747\u5300\u7684\u64cd\u4f5c<\/span><br \/>\n<span class=\"token keyword\">let<\/span> darker <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0.5<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u611f\u77e5\u4e0a\u53d8\u6697\u4e00\u534a<\/span><\/p>\n<p><span class=\"token comment\">\/\/ Rgba&#xff08;\u7ebf\u6027\u7a7a\u95f4&#xff09;- \u7528\u4e8e\u7269\u7406\u6b63\u786e\u7684\u8ba1\u7b97<\/span><br \/>\n<span class=\"token keyword\">let<\/span> rgba <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>color<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>             <span class=\"token comment\">\/\/ \u8f6c\u6362\u4e3a\u7ebf\u6027\u7a7a\u95f4<\/span><br \/>\n<span class=\"token keyword\">let<\/span> linear_result <span class=\"token operator\">&#061;<\/span> rgba <span class=\"token operator\">*<\/span> <span class=\"token number\">0.5<\/span><span class=\"token punctuation\">;<\/span>           <span class=\"token comment\">\/\/ \u7269\u7406\u4e0a\u51cf\u534a\u5149\u5f3a<\/span><br \/>\n<span class=\"token keyword\">let<\/span> back <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>linear_result<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u8f6c\u56de\u4f3d\u9a6c\u7a7a\u95f4<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u9009\u62e9\u6307\u5357&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u8c03\u8272\u3001UI\u3001\u7b80\u5355\u4eae\u5ea6\u8c03\u6574 \u2192 \u7528Color32&#xff08;\u4f3d\u9a6c\u7a7a\u95f4&#xff09;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u5149\u7167\u3001\u7269\u7406\u6a21\u62df\u3001\u7cbe\u786e\u6df7\u5408 \u2192 \u8f6cRgba&#xff08;\u7ebf\u6027\u7a7a\u95f4&#xff09;<\/span><\/p>\n<hr \/>\n<h3>\u56db\u3001\u6784\u9020\u65b9\u6cd5\u8be6\u89e3<\/h3>\n<h4>4.1 \u57fa\u7840\u6784\u9020\u51fd\u6570<\/h4>\n<table>\n<tr>\u65b9\u6cd5\u63cf\u8ff0\u793a\u4f8b<\/tr>\n<tbody>\n<tr>\n<td align=\"left\">from_rgb(r, g, b)<\/td>\n<td align=\"left\">\u4e0d\u900f\u660eRGB<\/td>\n<td align=\"left\">Color32::from_rgb(255, 128, 0)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">from_rgba_premultiplied(r, g, b, a)<\/td>\n<td align=\"left\">\u9884\u4e58RGBA&#xff08;\u76f4\u63a5\u5185\u90e8\u683c\u5f0f&#xff09;<\/td>\n<td align=\"left\">Color32::from_rgba_premultiplied(128, 0, 0, 128)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">from_rgba_unmultiplied(r, g, b, a)<\/td>\n<td align=\"left\">\u666e\u901aRGBA&#xff08;\u63a8\u8350&#xff09;<\/td>\n<td align=\"left\">Color32::from_rgba_unmultiplied(255, 0, 0, 128)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">from_gray(l)<\/td>\n<td align=\"left\">\u7070\u5ea6\u4e0d\u900f\u660e<\/td>\n<td align=\"left\">Color32::from_gray(128)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">from_black_alpha(a)<\/td>\n<td align=\"left\">\u9ed1\u8272\u5e26\u900f\u660e\u5ea6<\/td>\n<td align=\"left\">Color32::from_black_alpha(64)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">from_white_alpha(a)<\/td>\n<td align=\"left\">\u767d\u8272\u5e26\u900f\u660e\u5ea6<\/td>\n<td align=\"left\">Color32::from_white_alpha(64)<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">from_additive_luminance(l)<\/td>\n<td align=\"left\">\u52a0\u6cd5\u4eae\u5ea6<\/td>\n<td align=\"left\">Color32::from_additive_luminance(128)<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h4>4.2 \u7279\u6b8a\u6784\u9020\u51fd\u6570<\/h4>\n<p><span class=\"token comment\">\/\/ \u4eceRGB\u521b\u5efa\u52a0\u6cd5\u989c\u8272&#xff08;\u5149\u6e90&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> additive <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb_additive<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4ece\u5df2\u6709\u989c\u8272\u83b7\u53d6\u52a0\u6cd5\u7248\u672c&#xff08;\u8f6c\u4e3a\u5149\u6e90&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> original <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">RED<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> additive_version <span class=\"token operator\">&#061;<\/span> original<span class=\"token punctuation\">.<\/span><span class=\"token function\">additive<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ alpha\u8bbe\u4e3a0&#xff0c;RGB\u4fdd\u6301\u4e0d\u53d8<\/span><\/p>\n<h4>4.3 \u6027\u80fd\u4f18\u5316\u8bf4\u660e<\/h4>\n<p>from_rgba_unmultiplied \u5305\u542b\u7279\u6b8a\u4f18\u5316&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ alpha&#061;0 \u76f4\u63a5\u8fd4\u56de\u900f\u660e<\/span><br \/>\n<span class=\"token comment\">\/\/ alpha&#061;255 \u76f4\u63a5\u8fd4\u56de\u4e0d\u900f\u660eRGB<\/span><br \/>\n<span class=\"token comment\">\/\/ \u5176\u4ed6\u60c5\u51b5\u4f7f\u7528\u67e5\u627e\u8868\u52a0\u901f\u8ba1\u7b97<\/span><br \/>\n<span class=\"token keyword\">let<\/span> color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<hr \/>\n<h3>\u4e94\u3001\u989c\u8272\u8bbf\u95ee\u65b9\u6cd5<\/h3>\n<h4>5.1 \u83b7\u53d6\u901a\u9053\u503c<\/h4>\n<p><span class=\"token keyword\">let<\/span> color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">150<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">180<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u83b7\u53d6\u9884\u4e58\u540e\u7684\u5404\u901a\u9053<\/span><br \/>\n<span class=\"token keyword\">let<\/span> r <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">r<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u9884\u4e58\u540e\u7684\u7ea2\u8272\u503c<\/span><br \/>\n<span class=\"token keyword\">let<\/span> g <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">g<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u9884\u4e58\u540e\u7684\u7eff\u8272\u503c<\/span><br \/>\n<span class=\"token keyword\">let<\/span> b <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">b<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u9884\u4e58\u540e\u7684\u84dd\u8272\u503c<\/span><br \/>\n<span class=\"token keyword\">let<\/span> a <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">a<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ Alpha\u503c&#xff08;\u672a\u9884\u4e58&#xff09;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u68c0\u67e5\u4e0d\u900f\u660e\u5ea6<\/span><br \/>\n<span class=\"token keyword\">if<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">is_opaque<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token macro property\">println!<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u5b8c\u5168\u4e0d\u900f\u660e (alpha&#061;255)&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u68c0\u67e5\u662f\u5426\u4e3a\u52a0\u6cd5\u989c\u8272&#xff08;\u5149\u6e90&#xff09;<\/span><br \/>\n<span class=\"token keyword\">if<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">is_additive<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token macro property\">println!<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u8fd9\u662f\u5149\u6e90 (alpha&#061;0)&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h4>5.2 \u8f6c\u6362\u4e3a\u6570\u7ec4\/\u5143\u7ec4<\/h4>\n<p><span class=\"token comment\">\/\/ \u8f6c\u6570\u7ec4&#xff08;\u9884\u4e58\u683c\u5f0f&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> array <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_array<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ [r, g, b, a]<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u8f6c\u5143\u7ec4&#xff08;\u9884\u4e58\u683c\u5f0f&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> tuple <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_tuple<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ (r, g, b, a)<\/span><\/p>\n<h4>5.3 \u8f6c\u6362\u4e3a\u975e\u9884\u4e58RGBA<\/h4>\n<p><span class=\"token comment\">\/\/ \u83b7\u53d6\u666e\u901aRGBA\u503c&#xff08;\u7528\u4e8e\u989c\u8272\u9009\u62e9\u5668\u663e\u793a\u7b49&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> <span class=\"token punctuation\">[<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> a<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_srgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u6ce8\u610f&#xff1a;\u900f\u660e\u989c\u8272\u53ef\u80fd\u6709\u5fae\u5c0f\u8bef\u5dee&#xff08;\u00b13\u4ee5\u5185&#xff09;<\/span><\/p>\n<h4>5.4 \u8f6c\u6362\u4e3a\u6d6e\u70b9\u503c<\/h4>\n<p><span class=\"token comment\">\/\/ \u76f4\u63a5\u8f6c\u6362\u4e3a0-1\u6d6e\u70b9&#xff08;\u65e0\u4f3d\u9a6c\u8f6c\u6362&#xff0c;\u8c28\u614e\u4f7f\u7528&#xff01;&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> <span class=\"token punctuation\">[<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> a<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_normalized_gamma_f32<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ \u901a\u5e38\u5e94\u8be5\u7528 Rgba::from(color) \u4ee3\u66ff<\/span><\/p>\n<hr \/>\n<h3>\u516d\u3001\u989c\u8272\u8fd0\u7b97<\/h3>\n<h4>6.1 \u989c\u8272\u6df7\u5408\u2014\u2014\u7edf\u4e00\u7684\u516c\u5f0f<\/h4>\n<p><span class=\"token keyword\">let<\/span> background <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_gray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">200<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> foreground <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u7edf\u4e00\u7684\u6df7\u5408\u516c\u5f0f&#xff1a;\u7ed3\u679c &#061; \u524d\u666f &#043; \u80cc\u666f * (1-\u03b1_\u524d\u666f)<\/span><br \/>\n<span class=\"token keyword\">let<\/span> result <span class=\"token operator\">&#061;<\/span> foreground<span class=\"token punctuation\">.<\/span><span class=\"token function\">blend<\/span><span class=\"token punctuation\">(<\/span>background<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u8fd9\u4e2a\u516c\u5f0f\u7edf\u4e00\u5904\u7406\u6240\u6709\u60c5\u51b5&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u666e\u901a\u524d\u666f &#043; \u666e\u901a\u80cc\u666f<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u52a0\u6cd5\u524d\u666f (\u03b1&#061;0) &#043; \u666e\u901a\u80cc\u666f \u2192 \u76f4\u63a5\u76f8\u52a0<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u666e\u901a\u524d\u666f &#043; \u52a0\u6cd5\u80cc\u666f \u2192 \u80cc\u666f\u88ab\u524d\u666f\u8870\u51cf<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u53cc\u52a0\u6cd5 \u2192 \u5149\u6e90\u53e0\u52a0<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u7b49\u4ef7\u4e8e&#xff1a;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> result <span class=\"token operator\">&#061;<\/span> background<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply_u8<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span> <span class=\"token operator\">&#8211;<\/span> foreground<span class=\"token punctuation\">.<\/span><span class=\"token function\">a<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#043;<\/span> foreground<span class=\"token punctuation\">;<\/span><\/p>\n<h4>6.2 \u4eae\u5ea6\u8c03\u6574<\/h4>\n<p><span class=\"token keyword\">let<\/span> color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">RED<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4f3d\u9a6c\u7a7a\u95f4\u53d8\u6697&#xff08;\u611f\u77e5\u5747\u5300&#xff0c;\u901f\u5ea6\u5feb&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> darker <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0.5<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>      <span class=\"token comment\">\/\/ \u611f\u89c9\u4e0a\u6697\u4e86\u4e00\u534a<\/span><br \/>\n<span class=\"token keyword\">let<\/span> darker_u8 <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply_u8<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">127<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ u8\u7248\u672c&#xff08;127\u22480.5&#xff09;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u7ebf\u6027\u7a7a\u95f4\u53d8\u6697&#xff08;\u7269\u7406\u6b63\u786e&#xff0c;\u4f46\u901f\u5ea6\u6162&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> linear_darker <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">linear_multiply<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0.5<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u5149\u5f3a\u51cf\u534a<\/span><\/p>\n<h4>6.3 \u989c\u8272\u63d2\u503c<\/h4>\n<p><span class=\"token keyword\">let<\/span> start <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">RED<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> end <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">BLUE<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u5728\u4f3d\u9a6c\u7a7a\u95f4\u63d2\u503c&#xff08;\u611f\u77e5\u5747\u5300&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> t <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">0.3<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ 0.0&#061;start, 1.0&#061;end<\/span><br \/>\n<span class=\"token keyword\">let<\/span> mid <span class=\"token operator\">&#061;<\/span> start<span class=\"token punctuation\">.<\/span><span class=\"token function\">lerp_to_gamma<\/span><span class=\"token punctuation\">(<\/span>end<span class=\"token punctuation\">,<\/span> t<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<h4>6.4 \u83b7\u53d6\u4e0d\u900f\u660e\u7248\u672c<\/h4>\n<p><span class=\"token keyword\">let<\/span> transparent <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">150<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> opaque <span class=\"token operator\">&#061;<\/span> transparent<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_opaque<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u8f6c\u4e3a\u4e0d\u900f\u660e\u7248\u672c<\/span><\/p>\n<h4>6.5 \u4eae\u5ea6\u8ba1\u7b97<\/h4>\n<p><span class=\"token keyword\">let<\/span> color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">150<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> intensity <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">intensity<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u8fd4\u56de0-1\u4e4b\u95f4\u7684\u611f\u77e5\u4eae\u5ea6<\/span><br \/>\n<span class=\"token comment\">\/\/ \u4f7f\u7528\u6807\u51c6\u7070\u5ea6\u516c\u5f0f&#xff1a;0.299R &#043; 0.587G &#043; 0.114B<\/span><\/p>\n<hr \/>\n<h3>\u4e03\u3001\u8fd0\u7b97\u7b26\u91cd\u8f7d<\/h3>\n<h4>7.1 \u52a0\u6cd5&#xff08;\u9971\u548c\u76f8\u52a0&#xff09;<\/h4>\n<p><span class=\"token comment\">\/\/ \u901a\u9053\u503c\u9971\u548c\u76f8\u52a0&#xff08;\u4e0d\u4f1a\u6ea2\u51fa&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> c1 <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">50<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> c2 <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">220<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> sum <span class=\"token operator\">&#061;<\/span> c1 <span class=\"token operator\">&#043;<\/span> c2<span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u6bcf\u4e2a\u901a\u9053\u9971\u548c\u76f8\u52a0<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u52a0\u6cd5\u5bf9\u666e\u901a\u989c\u8272\u548c\u52a0\u6cd5\u989c\u8272\u4e00\u89c6\u540c\u4ec1<\/span><br \/>\n<span class=\"token keyword\">let<\/span> light <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb_additive<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">50<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">20<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> background <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_gray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> lit <span class=\"token operator\">&#061;<\/span> background <span class=\"token operator\">&#043;<\/span> light<span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u5149\u6e90\u53e0\u52a0\u5230\u80cc\u666f<\/span><\/p>\n<h4>7.2 \u4e58\u6cd5&#xff08;\u4f3d\u9a6c\u7a7a\u95f4&#xff09;<\/h4>\n<p><span class=\"token comment\">\/\/ \u4f3d\u9a6c\u7a7a\u95f4\u901a\u9053\u76f8\u4e58&#xff08;\u9664\u4ee5255\u5f52\u4e00\u5316&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> c1 <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">50<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> c2 <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">220<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> product <span class=\"token operator\">&#061;<\/span> c1 <span class=\"token operator\">*<\/span> c2<span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u7528\u4e8e\u6ee4\u955c\u6548\u679c\u7b49<\/span><\/p>\n<h4>7.3 \u7d22\u5f15\u8bbf\u95ee<\/h4>\n<p><span class=\"token keyword\">let<\/span> color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">150<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">let<\/span> r <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">[<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u7b49\u4ef7\u4e8e color.r()<\/span><br \/>\n<span class=\"token keyword\">let<\/span> g <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">[<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u7b49\u4ef7\u4e8e color.g()<\/span><br \/>\n<span class=\"token keyword\">let<\/span> b <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">[<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u7b49\u4ef7\u4e8e color.b()<\/span><br \/>\n<span class=\"token keyword\">let<\/span> a <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">[<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u7b49\u4ef7\u4e8e color.a()<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u4e5f\u53ef\u4ee5\u4fee\u6539&#xff08;\u9700\u8981mut&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> <span class=\"token keyword\">mut<\/span> color <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">;<\/span><br \/>\ncolor<span class=\"token punctuation\">[<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">255<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u4fee\u6539\u7ea2\u8272\u901a\u9053<\/span><\/p>\n<hr \/>\n<h3>\u516b\u3001\u4e0eRgba\u7684\u4e92\u64cd\u4f5c<\/h3>\n<h4>8.1 Color32 \u2192 Rgba<\/h4>\n<p><span class=\"token keyword\">let<\/span> color32 <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">RED<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u8f6c\u6362\u4e3a\u7ebf\u6027\u7a7a\u95f4Rgba&#xff08;\u81ea\u52a8\u4f3d\u9a6c\u6821\u6b63&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> rgba <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>color32<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u73b0\u5728\u53ef\u4ee5\u5728\u7ebf\u6027\u7a7a\u95f4\u8fdb\u884c\u590d\u6742\u8ba1\u7b97<\/span><br \/>\n<span class=\"token keyword\">let<\/span> multiplied <span class=\"token operator\">&#061;<\/span> rgba <span class=\"token operator\">*<\/span> <span class=\"token number\">0.5<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> blended <span class=\"token operator\">&#061;<\/span> rgba<span class=\"token punctuation\">.<\/span><span class=\"token function\">lerp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">WHITE<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0.3<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<h4>8.2 Rgba \u2192 Color32<\/h4>\n<p><span class=\"token keyword\">let<\/span> rgba <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0.5<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0.3<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0.8<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u8f6c\u56de\u4f3d\u9a6c\u7a7a\u95f4Color32&#xff08;\u81ea\u52a8\u4f3d\u9a6c\u6821\u6b63&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> color32 <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>rgba<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<h4>8.3 \u4f55\u65f6\u8f6c\u6362<\/h4>\n<table>\n<tr>\u573a\u666f\u4f7f\u7528\u683c\u5f0f\u539f\u56e0<\/tr>\n<tbody>\n<tr>\n<td align=\"left\">\u8bbe\u7f6eUI\u989c\u8272<\/td>\n<td align=\"left\">Color32<\/td>\n<td align=\"left\">\u76f4\u63a5\u663e\u793a&#xff0c;\u611f\u77e5\u5747\u5300<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u989c\u8272\u52a8\u753b<\/td>\n<td align=\"left\">Rgba \u2192 \u8ba1\u7b97 \u2192 Color32<\/td>\n<td align=\"left\">\u7ebf\u6027\u63d2\u503c\u7269\u7406\u6b63\u786e<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u5149\u7167\u8ba1\u7b97<\/td>\n<td align=\"left\">Rgba<\/td>\n<td align=\"left\">\u7269\u7406\u6b63\u786e\u6027\u8981\u6c42<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u590d\u6742\u989c\u8272\u6df7\u5408<\/td>\n<td align=\"left\">Rgba<\/td>\n<td align=\"left\">\u7ebf\u6027\u7a7a\u95f4\u6df7\u5408\u6b63\u786e<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u5b58\u50a8\u7eb9\u7406<\/td>\n<td align=\"left\">Color32<\/td>\n<td align=\"left\">\u8282\u7701\u5185\u5b58&#xff0c;\u5339\u914d\u786c\u4ef6<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<hr \/>\n<h3>\u4e5d\u3001\u5b9e\u7528\u6280\u5de7<\/h3>\n<h4>9.1 \u8c03\u8bd5\u8f93\u51fa<\/h4>\n<p><span class=\"token keyword\">let<\/span> color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">150<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token macro property\">println!<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;{:?}&#034;<\/span><span class=\"token punctuation\">,<\/span> color<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u8f93\u51fa: #64_96_C8_80<\/span><br \/>\n<span class=\"token comment\">\/\/ \u683c\u5f0f&#xff1a;\u5341\u516d\u8fdb\u5236 RR_GG_BB_AA&#xff08;\u9884\u4e58\u503c&#xff01;&#xff09;<\/span><\/p>\n<h4>9.2 \u7279\u6b8a\u989c\u8272\u6807\u8bb0<\/h4>\n<p><span class=\"token comment\">\/\/ DEBUG_COLOR&#xff1a;\u7528\u4e8e\u8c03\u8bd5&#xff0c;\u9192\u76ee\u4f46\u4e0d\u523a\u773c<\/span><br \/>\n<span class=\"token keyword\">let<\/span> debug <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">DEBUG_COLOR<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ (0, 200, 0, 128)<\/span><\/p>\n<p><span class=\"token comment\">\/\/ PLACEHOLDER&#xff1a;\u5360\u4f4d\u7b26&#xff0c;\u8868\u793a&#034;\u65e0\u989c\u8272&#034;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> placeholder <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">PLACEHOLDER<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ (64, 254, 0, 128)<\/span><\/p>\n<h4>9.3 \u6027\u80fd\u6700\u4f73\u5b9e\u8df5<\/h4>\n<p><span class=\"token comment\">\/\/ \u2705 \u597d&#xff1a;\u4f7f\u7528\u9884\u5b9a\u4e49\u5e38\u91cf<\/span><br \/>\n<span class=\"token keyword\">let<\/span> red <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">RED<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u2705 \u597d&#xff1a;\u4f7f\u7528from_rgba_unmultiplied&#xff08;\u6709\u4f18\u5316&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> semi <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u2705 \u597d&#xff1a;\u6279\u91cf\u64cd\u4f5c\u5728Rgba\u7a7a\u95f4\u8fdb\u884c<\/span><br \/>\n<span class=\"token keyword\">let<\/span> colors<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Vec<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token class-name\">Color32<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">&#8230;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> rgbs<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Vec<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token class-name\">Rgba<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token operator\">&#061;<\/span> colors<span class=\"token punctuation\">.<\/span><span class=\"token function\">iter<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token closure-params\"><span class=\"token closure-punctuation punctuation\">|<\/span><span class=\"token operator\">&amp;<\/span>c<span class=\"token closure-punctuation punctuation\">|<\/span><\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>c<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">collect<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8230; \u6279\u91cf\u8ba1\u7b97 &#8230;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> results<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Vec<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token class-name\">Color32<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token operator\">&#061;<\/span> rgbs<span class=\"token punctuation\">.<\/span><span class=\"token function\">into_iter<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">map<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span>from<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">collect<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u274c \u4e0d\u597d&#xff1a;\u9891\u7e41\u5728Color32\u548cRgba\u95f4\u8f6c\u6362<\/span><br \/>\n<span class=\"token keyword\">for<\/span> color <span class=\"token keyword\">in<\/span> colors <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">let<\/span> result <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>color<span class=\"token punctuation\">)<\/span> <span class=\"token operator\">*<\/span> <span class=\"token number\">0.5<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u5faa\u73af\u5185\u8f6c\u6362<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<hr \/>\n<h3>\u5341\u3001\u5b8c\u6574\u793a\u4f8b<\/h3>\n<h4>10.1 \u989c\u8272\u9009\u62e9\u5668\u503c\u5904\u7406<\/h4>\n<p><span class=\"token keyword\">use<\/span> <span class=\"token namespace\">ecolor<span class=\"token punctuation\">::<\/span><\/span><span class=\"token punctuation\">{<\/span><span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">struct<\/span> <span class=\"token type-definition class-name\">ColorPicker<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token keyword\">impl<\/span> <span class=\"token class-name\">ColorPicker<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">new<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">128<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">255<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u4eceUI\u63a7\u4ef6\u63a5\u6536\u975e\u9884\u4e58RGBA\u503c<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">set_from_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">mut<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> r<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span> a<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> a<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u83b7\u53d6\u7528\u4e8e\u663e\u793a\u7684\u975e\u9884\u4e58RGBA\u503c<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">get_for_display<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token punctuation\">[<\/span><span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token number\">4<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_srgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u8c03\u6574\u900f\u660e\u5ea6&#xff08;\u611f\u77e5\u5747\u5300&#xff09;<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">set_opacity<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">mut<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> opacity<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u4fdd\u6301\u989c\u8272\u4e0d\u53d8&#xff0c;\u53ea\u6539\u900f\u660e\u5ea6<\/span><br \/>\n        <span class=\"token keyword\">let<\/span> <span class=\"token punctuation\">[<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> _<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_srgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> opacity<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u53d8\u6697&#xff08;\u611f\u77e5\u5747\u5300&#xff09;<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">darken<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">mut<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> factor<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply<\/span><span class=\"token punctuation\">(<\/span>factor<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u6df7\u5408\u4e24\u4e2a\u989c\u8272<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">blend_with<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> other<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token class-name\">Color32<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        other<span class=\"token punctuation\">.<\/span><span class=\"token function\">blend<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color<span class=\"token punctuation\">)<\/span>  <span class=\"token comment\">\/\/ other\u5728\u4e0a&#xff0c;self\u5728\u4e0b<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h4>10.2 \u6e10\u53d8\u52a8\u753b<\/h4>\n<p><span class=\"token keyword\">use<\/span> <span class=\"token namespace\">ecolor<span class=\"token punctuation\">::<\/span><\/span><span class=\"token punctuation\">{<\/span><span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">struct<\/span> <span class=\"token type-definition class-name\">GradientAnimation<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    start<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    end<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    progress<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ 0.0 \u5230 1.0<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token keyword\">impl<\/span> <span class=\"token class-name\">GradientAnimation<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">new<\/span><span class=\"token punctuation\">(<\/span>start<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span> end<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            start<span class=\"token punctuation\">,<\/span><br \/>\n            end<span class=\"token punctuation\">,<\/span><br \/>\n            progress<span class=\"token punctuation\">:<\/span> <span class=\"token number\">0.0<\/span><span class=\"token punctuation\">,<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u83b7\u53d6\u5f53\u524d\u989c\u8272&#xff08;\u5728\u4f3d\u9a6c\u7a7a\u95f4\u63d2\u503c&#xff09;- \u611f\u77e5\u5747\u5300<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">current_gamma<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token class-name\">Color32<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>start<span class=\"token punctuation\">.<\/span><span class=\"token function\">lerp_to_gamma<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>end<span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>progress<span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u83b7\u53d6\u5f53\u524d\u989c\u8272&#xff08;\u5728\u7ebf\u6027\u7a7a\u95f4\u63d2\u503c&#xff09;- \u7269\u7406\u6b63\u786e<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">current_linear<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token class-name\">Color32<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">let<\/span> start_rgba <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>start<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">let<\/span> end_rgba <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>end<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">let<\/span> current_rgba <span class=\"token operator\">&#061;<\/span> start_rgba<span class=\"token punctuation\">.<\/span><span class=\"token function\">lerp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span>end_rgba<span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>progress<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>current_rgba<span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u52a8\u753b\u66f4\u65b0<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">update<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">mut<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> delta<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>progress <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>progress <span class=\"token operator\">&#043;<\/span> delta<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">clamp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0.0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1.0<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h4>10.3 \u4e3b\u9898\u989c\u8272\u7cfb\u7edf<\/h4>\n<p><span class=\"token keyword\">use<\/span> <span class=\"token namespace\">ecolor<span class=\"token punctuation\">::<\/span><\/span><span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">struct<\/span> <span class=\"token type-definition class-name\">Theme<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    primary<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    secondary<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    background<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    text<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    error<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    disabled<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token keyword\">impl<\/span> <span class=\"token class-name\">Theme<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">light<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            primary<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0x42<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xA5<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xF5<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u4eae\u84dd<\/span><br \/>\n            secondary<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0x66<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x66<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x66<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token comment\">\/\/ \u4e2d\u7070<\/span><br \/>\n            background<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">WHITE<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            text<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">BLACK<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            error<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">RED<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            disabled<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0xCC<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xCC<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xCC<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">dark<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            primary<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0x90<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xCA<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xF9<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u6d45\u84dd<\/span><br \/>\n            secondary<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0xB0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xB0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0xB0<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token comment\">\/\/ \u6d45\u7070<\/span><br \/>\n            background<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0x33<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x33<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x33<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            text<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token constant\">WHITE<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            error<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0xFF<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x6B<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x6B<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>    <span class=\"token comment\">\/\/ \u6d45\u7ea2<\/span><br \/>\n            disabled<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0x66<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x66<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0x66<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u521b\u5efa\u5e26\u900f\u660e\u5ea6\u7684\u7248\u672c<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">with_opacity<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span> opacity<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token class-name\">Color32<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">let<\/span> <span class=\"token punctuation\">[<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> _<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_srgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> opacity<span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u60ac\u505c\u6548\u679c&#xff08;\u611f\u77e5\u5747\u5300\u7684\u4eae\u5316&#xff09;<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">hover<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token class-name\">Color32<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        color<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1.2<\/span><span class=\"token punctuation\">)<\/span>  <span class=\"token comment\">\/\/ \u611f\u89c9\u4e0a\u4eae20%<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u70b9\u51fb\u6548\u679c&#xff08;\u611f\u77e5\u5747\u5300\u7684\u6697\u5316&#xff09;<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">active<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token class-name\">Color32<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        color<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0.8<\/span><span class=\"token punctuation\">)<\/span>  <span class=\"token comment\">\/\/ \u611f\u89c9\u4e0a\u669720%<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h4>10.4 \u5149\u6e90\u7cfb\u7edf\u793a\u4f8b\u2014\u2014\u52a0\u6cd5\u989c\u8272\u7684\u5b9e\u9645\u5e94\u7528<\/h4>\n<p><span class=\"token keyword\">use<\/span> <span class=\"token namespace\">ecolor<span class=\"token punctuation\">::<\/span><\/span><span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">struct<\/span> <span class=\"token type-definition class-name\">LightSource<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    position<span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n    color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u52a0\u6cd5\u989c\u8272<\/span><br \/>\n    intensity<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">,<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token keyword\">impl<\/span> <span class=\"token class-name\">LightSource<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">new<\/span><span class=\"token punctuation\">(<\/span>x<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">,<\/span> y<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">,<\/span> r<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span> intensity<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">Self<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            position<span class=\"token punctuation\">:<\/span> <span class=\"token punctuation\">(<\/span>x<span class=\"token punctuation\">,<\/span> y<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb_additive<\/span><span class=\"token punctuation\">(<\/span><br \/>\n                <span class=\"token punctuation\">(<\/span>r <span class=\"token keyword\">as<\/span> <span class=\"token keyword\">f32<\/span> <span class=\"token operator\">*<\/span> intensity<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">as<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                <span class=\"token punctuation\">(<\/span>g <span class=\"token keyword\">as<\/span> <span class=\"token keyword\">f32<\/span> <span class=\"token operator\">*<\/span> intensity<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">as<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                <span class=\"token punctuation\">(<\/span>b <span class=\"token keyword\">as<\/span> <span class=\"token keyword\">f32<\/span> <span class=\"token operator\">*<\/span> intensity<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">as<\/span> <span class=\"token keyword\">u8<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            intensity<span class=\"token punctuation\">,<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u5149\u7167\u8ba1\u7b97&#xff1a;\u5149\u6e90\u53e0\u52a0\u5230\u573a\u666f<\/span><br \/>\n    <span class=\"token keyword\">fn<\/span> <span class=\"token function-definition function\">illuminate<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&amp;<\/span><span class=\"token keyword\">self<\/span><span class=\"token punctuation\">,<\/span> scene_color<span class=\"token punctuation\">:<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">,<\/span> distance<span class=\"token punctuation\">:<\/span> <span class=\"token keyword\">f32<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">-&gt;<\/span> <span class=\"token class-name\">Color32<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u8ddd\u79bb\u8870\u51cf<\/span><br \/>\n        <span class=\"token keyword\">let<\/span> attenuation <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">1.0<\/span> <span class=\"token operator\">\/<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token number\">1.0<\/span> <span class=\"token operator\">&#043;<\/span> distance <span class=\"token operator\">*<\/span> <span class=\"token number\">0.1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">let<\/span> attenuated <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">self<\/span><span class=\"token punctuation\">.<\/span>color<span class=\"token punctuation\">.<\/span><span class=\"token function\">gamma_multiply<\/span><span class=\"token punctuation\">(<\/span>attenuation<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u5149\u6e90\u53e0\u52a0&#xff08;\u52a0\u6cd5\u6df7\u5408&#xff09;- \u7edf\u4e00\u516c\u5f0f\u7684\u81ea\u7136\u7ed3\u679c<\/span><br \/>\n        scene_color <span class=\"token operator\">&#043;<\/span> attenuated<br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u591a\u4e2a\u5149\u6e90\u53e0\u52a0<\/span><br \/>\n<span class=\"token keyword\">let<\/span> <span class=\"token keyword\">mut<\/span> scene <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_gray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">50<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u6df1\u7070\u8272\u80cc\u666f<\/span><\/p>\n<p><span class=\"token keyword\">let<\/span> lights <span class=\"token operator\">&#061;<\/span> <span class=\"token macro property\">vec!<\/span><span class=\"token punctuation\">[<\/span><br \/>\n    <span class=\"token class-name\">LightSource<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">new<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">10.0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">10.0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">50<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1.0<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>   <span class=\"token comment\">\/\/ \u6696\u8272\u5149<\/span><br \/>\n    <span class=\"token class-name\">LightSource<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">new<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">50.0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">30.0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0.8<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u51b7\u8272\u5149<\/span><br \/>\n    <span class=\"token class-name\">LightSource<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">new<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">80.0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">80.0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0.5<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u6de1\u9ec4\u5149<\/span><br \/>\n<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u6240\u6709\u5149\u6e90\u53e0\u52a0 &#8211; \u6bcf\u4e2a\u90fd\u662f\u52a0\u6cd5\u989c\u8272&#xff0c;\u81ea\u7136\u5730\u76f8\u52a0<\/span><br \/>\n<span class=\"token keyword\">for<\/span> light <span class=\"token keyword\">in<\/span> <span class=\"token operator\">&amp;<\/span>lights <span class=\"token punctuation\">{<\/span><br \/>\n    scene <span class=\"token operator\">&#061;<\/span> light<span class=\"token punctuation\">.<\/span><span class=\"token function\">illuminate<\/span><span class=\"token punctuation\">(<\/span>scene<span class=\"token punctuation\">,<\/span> <span class=\"token number\">20.0<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token comment\">\/\/ \u6700\u7ec8 scene \u662f\u591a\u4e2a\u5149\u6e90\u53e0\u52a0\u7684\u6548\u679c<\/span><\/p>\n<hr \/>\n<h3>\u5341\u4e00\u3001\u5e38\u89c1\u95ee\u9898<\/h3>\n<h4>Q1: \u4e3a\u4ec0\u4e48\u989c\u8272\u6df7\u5408\u7ed3\u679c\u4e0d\u7b26\u5408\u9884\u671f&#xff1f;<\/h4>\n<p>\u53ef\u80fd\u539f\u56e0&#xff1a;Color32\u5728\u4f3d\u9a6c\u7a7a\u95f4\u6df7\u5408&#xff0c;\u8fd9\u662f\u4e3a\u4e86\u5339\u914d\u4eba\u773c\u611f\u77e5\u3002\u5982\u679c\u9700\u8981\u7269\u7406\u6b63\u786e\u7684\u6df7\u5408&#xff0c;\u8f6cRgba&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ \u4f3d\u9a6c\u7a7a\u95f4\u6df7\u5408&#xff08;\u9ed8\u8ba4&#xff09;- \u611f\u77e5\u5747\u5300<\/span><br \/>\n<span class=\"token keyword\">let<\/span> gamma_blend <span class=\"token operator\">&#061;<\/span> fg<span class=\"token punctuation\">.<\/span><span class=\"token function\">blend<\/span><span class=\"token punctuation\">(<\/span>bg<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u7ebf\u6027\u7a7a\u95f4\u6df7\u5408&#xff08;\u7269\u7406\u6b63\u786e&#xff09;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> fg_rgba <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>fg<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> bg_rgba <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Rgba<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>bg<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> linear_blend <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from<\/span><span class=\"token punctuation\">(<\/span>fg_rgba <span class=\"token operator\">*<\/span> fg_alpha <span class=\"token operator\">&#043;<\/span> bg_rgba <span class=\"token operator\">*<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span> <span class=\"token operator\">&#8211;<\/span> fg_alpha<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<h4>Q2: \u52a0\u6cd5\u989c\u8272\u9700\u8981\u7279\u6b8a\u5904\u7406\u5417&#xff1f;<\/h4>\n<p>\u4e0d\u9700\u8981&#xff01; \u52a0\u6cd5\u989c\u8272\u5b8c\u5168\u878d\u5165\u7edf\u4e00\u7684\u9884\u4e58\u6846\u67b6&#xff1a;<\/p>\n<p><span class=\"token comment\">\/\/ \u52a0\u6cd5\u989c\u8272\u548c\u666e\u901a\u989c\u8272\u4f7f\u7528\u5b8c\u5168\u76f8\u540c\u7684API<\/span><br \/>\n<span class=\"token keyword\">let<\/span> light <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb_additive<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> normal <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgb<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">150<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">200<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u6df7\u5408\u65f6\u81ea\u52a8\u5904\u7406<\/span><br \/>\n<span class=\"token keyword\">let<\/span> result <span class=\"token operator\">&#061;<\/span> light<span class=\"token punctuation\">.<\/span><span class=\"token function\">blend<\/span><span class=\"token punctuation\">(<\/span>normal<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u6839\u636ealpha\u81ea\u52a8\u9009\u62e9\u884c\u4e3a<\/span><br \/>\n<span class=\"token keyword\">let<\/span> sum <span class=\"token operator\">&#061;<\/span> light <span class=\"token operator\">&#043;<\/span> normal<span class=\"token punctuation\">;<\/span>           <span class=\"token comment\">\/\/ \u52a0\u6cd5\u8fd0\u7b97\u7b26\u540c\u6837\u9002\u7528<\/span><\/p>\n<h4>Q3: from_rgba_unmultiplied \u548c from_rgba_premultiplied \u533a\u522b&#xff1f;<\/h4>\n<ul>\n<li>from_rgba_unmultiplied&#xff1a;\u4f20\u5165\u666e\u901aRGBA&#xff08;\u5982\u989c\u8272\u9009\u62e9\u5668\u7684\u503c&#xff09;&#xff0c;\u5185\u90e8\u81ea\u52a8\u8f6c\u6362\u4e3a\u9884\u4e58\u683c\u5f0f<\/li>\n<li>from_rgba_premultiplied&#xff1a;\u76f4\u63a5\u4f20\u5165\u9884\u4e58\u683c\u5f0f&#xff08;\u901a\u5e38\u4e0d\u9700\u8981\u76f4\u63a5\u8c03\u7528&#xff09;<\/li>\n<\/ul>\n<h4>Q4: \u5982\u4f55\u7cbe\u786e\u63a7\u5236\u900f\u660e\u5ea6&#xff1f;<\/h4>\n<p><span class=\"token comment\">\/\/ \u521b\u5efa\u6307\u5b9a\u900f\u660e\u5ea6\u7684\u989c\u8272<\/span><br \/>\n<span class=\"token keyword\">let<\/span> color <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">255<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">128<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u8c03\u6574\u5df2\u6709\u989c\u8272\u7684\u900f\u660e\u5ea6<\/span><br \/>\n<span class=\"token keyword\">let<\/span> <span class=\"token punctuation\">[<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> _<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;<\/span> color<span class=\"token punctuation\">.<\/span><span class=\"token function\">to_srgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">let<\/span> new_opacity <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Color32<\/span><span class=\"token punctuation\">::<\/span><span class=\"token function\">from_rgba_unmultiplied<\/span><span class=\"token punctuation\">(<\/span>r<span class=\"token punctuation\">,<\/span> g<span class=\"token punctuation\">,<\/span> b<span class=\"token punctuation\">,<\/span> <span class=\"token number\">64<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<h4>Q5: \u4e3a\u4ec0\u4e48 to_srgba_unmultiplied \u8fd4\u56de\u7684\u503c\u6709\u5c0f\u8bef\u5dee&#xff1f;<\/h4>\n<p>\u56e0\u4e3a\u9884\u4e58\u548c\u53cd\u9884\u4e58\u8fc7\u7a0b\u4e2d\u6709\u53d6\u6574\u8fd0\u7b97&#xff0c;\u900f\u660e\u989c\u8272\u7684RGB\u503c\u5728\u5f80\u8fd4\u8f6c\u6362\u65f6\u4f1a\u6709\u00b13\u4ee5\u5185\u7684\u8bef\u5dee&#xff0c;\u8fd9\u662f\u6b63\u5e38\u73b0\u8c61\u3002<\/p>\n<h4>Q6: \u4f3d\u9a6c\u7a7a\u95f4\u548c\u7ebf\u6027\u7a7a\u95f4&#xff0c;\u4ec0\u4e48\u65f6\u5019\u7528\u54ea\u4e2a&#xff1f;<\/h4>\n<p><span class=\"token comment\">\/\/ \u7528Color32&#xff08;\u4f3d\u9a6c\u7a7a\u95f4&#xff09;&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; UI\u989c\u8272\u8bbe\u7f6e<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u4e3b\u9898\u5b9a\u4e49<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u611f\u77e5\u5747\u5300\u7684\u4eae\u5ea6\u8c03\u6574<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u7b80\u5355\u7684\u989c\u8272\u6df7\u5408&#xff08;\u5982\u6309\u94ae\u60ac\u505c\u6548\u679c&#xff09;<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u8f6cRgba&#xff08;\u7ebf\u6027\u7a7a\u95f4&#xff09;&#xff1a;<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u7269\u7406\u5149\u7167\u8ba1\u7b97<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u7cbe\u786e\u7684\u989c\u8272\u6df7\u5408<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; HDR\u989c\u8272\u5904\u7406<\/span><br \/>\n<span class=\"token comment\">\/\/ &#8211; \u9700\u8981\u6570\u5b66\u6b63\u786e\u6027\u7684\u573a\u666f<\/span><\/p>\n<hr \/>\n<h3>\u5341\u4e8c\u3001\u6027\u80fd\u63d0\u793a<\/h3>\n<li>\u4f18\u5148\u4f7f\u7528\u9884\u5b9a\u4e49\u5e38\u91cf&#xff1a;Color32::RED \u6bd4 Color32::from_rgb(255,0,0) \u66f4\u5feb<\/li>\n<li>\u6279\u91cf\u64cd\u4f5c\u8f6cRgba&#xff1a;\u5927\u91cf\u989c\u8272\u8ba1\u7b97\u65f6&#xff0c;\u5148\u8f6cRgba\u6279\u91cf\u5904\u7406<\/li>\n<li>\u907f\u514d\u9891\u7e41\u8f6c\u6362&#xff1a;Color32 \u2194 Rgba \u8f6c\u6362\u6709\u5f00\u9500<\/li>\n<li>\u4f7f\u7528gamma_multiply_u8&#xff1a;u8\u7248\u672c\u6bd4f32\u7248\u672c\u66f4\u5feb<\/li>\n<li>\u5229\u7528\u67e5\u627e\u8868&#xff1a;from_rgba_unmultiplied \u5185\u90e8\u5df2\u4f18\u5316<\/li>\n<hr \/>\n<h3>\u5341\u4e09\u3001API\u901f\u67e5\u8868<\/h3>\n<table>\n<tr>\u7c7b\u522b\u65b9\u6cd5\u63cf\u8ff0<\/tr>\n<tbody>\n<tr>\n<td align=\"left\">\u6784\u9020<\/td>\n<td align=\"left\">from_rgb<\/td>\n<td align=\"left\">\u4e0d\u900f\u660eRGB<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">from_rgba_unmultiplied<\/td>\n<td align=\"left\">\u666e\u901aRGBA&#xff08;\u63a8\u8350&#xff09;<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">from_rgb_additive<\/td>\n<td align=\"left\">\u52a0\u6cd5\u989c\u8272&#xff08;\u5149\u6e90&#xff09;<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">from_gray<\/td>\n<td align=\"left\">\u7070\u5ea6<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u8f6c\u6362<\/td>\n<td align=\"left\">to_srgba_unmultiplied<\/td>\n<td align=\"left\">\u8f6c\u666e\u901aRGBA<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">to_array\/to_tuple<\/td>\n<td align=\"left\">\u8f6c\u6570\u7ec4\/\u5143\u7ec4<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">to_opaque<\/td>\n<td align=\"left\">\u8f6c\u4e0d\u900f\u660e<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">additive<\/td>\n<td align=\"left\">\u8f6c\u52a0\u6cd5\u989c\u8272<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u67e5\u8be2<\/td>\n<td align=\"left\">r\/g\/b\/a<\/td>\n<td align=\"left\">\u83b7\u53d6\u901a\u9053<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">is_opaque<\/td>\n<td align=\"left\">\u662f\u5426\u4e0d\u900f\u660e<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">is_additive<\/td>\n<td align=\"left\">\u662f\u5426\u52a0\u6cd5\u989c\u8272<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">intensity<\/td>\n<td align=\"left\">\u8ba1\u7b97\u4eae\u5ea6<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u8fd0\u7b97<\/td>\n<td align=\"left\">blend<\/td>\n<td align=\"left\">\u989c\u8272\u6df7\u5408&#xff08;\u7edf\u4e00\u516c\u5f0f&#xff09;<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">gamma_multiply<\/td>\n<td align=\"left\">\u4f3d\u9a6c\u7a7a\u95f4\u4e58\u6cd5<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">linear_multiply<\/td>\n<td align=\"left\">\u7ebf\u6027\u7a7a\u95f4\u4e58\u6cd5<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">lerp_to_gamma<\/td>\n<td align=\"left\">\u4f3d\u9a6c\u7a7a\u95f4\u63d2\u503c<\/td>\n<\/tr>\n<tr>\n<td align=\"left\">\u8fd0\u7b97\u7b26<\/td>\n<td align=\"left\">&#043;<\/td>\n<td align=\"left\">\u9971\u548c\u76f8\u52a0&#xff08;\u7edf\u4e00\u5904\u7406&#xff09;<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">*<\/td>\n<td align=\"left\">\u4f3d\u9a6c\u7a7a\u95f4\u76f8\u4e58<\/td>\n<\/tr>\n<tr>\n<td align=\"left\"><\/td>\n<td align=\"left\">[]<\/td>\n<td align=\"left\">\u7d22\u5f15\u8bbf\u95ee<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<hr \/>\n<h3>\u5341\u56db\u3001\u7ed3\u8bed<\/h3>\n<p>Color32 \u662fegui UI\u6846\u67b6\u7684\u6838\u5fc3\u989c\u8272\u7c7b\u578b&#xff0c;\u5b83\u7684\u8bbe\u8ba1\u57fa\u4e8e\u4e24\u4e2a\u6df1\u523b\u6d1e\u5bdf&#xff1a;<\/p>\n<li>\u4f3d\u9a6c\u7a7a\u95f4&#xff1a;\u8ba9\u5b58\u50a8\u503c\u540c\u65f6\u5339\u914d\u4eba\u773c\u611f\u77e5\u548c\u663e\u793a\u5668\u786c\u4ef6&#xff0c;\u5f62\u6210\u5b8c\u7f8e\u95ed\u73af<\/li>\n<li>\u9884\u4e58Alpha&#xff1a;\u7528\u7edf\u4e00\u7684\u6570\u5b66\u6846\u67b6\u540c\u65f6\u8868\u8fbe\u666e\u901a\u989c\u8272\u548c\u52a0\u6cd5\u989c\u8272<\/li>\n<p>\u7406\u89e3\u8fd9\u4e24\u70b9&#xff0c;\u5c31\u80fd\u660e\u767d\u4e3a\u4ec0\u4e48Color32\u53ef\u4ee5\u5982\u6b64\u7b80\u6d01\u800c\u5f3a\u5927\u3002\u8bb0\u4f4f\u6838\u5fc3\u539f\u5219&#xff1a;\u663e\u793a\u548c\u611f\u77e5\u7528Color32&#xff0c;\u7269\u7406\u8ba1\u7b97\u8f6cRgba&#xff0c;\u5c31\u80fd\u5145\u5206\u53d1\u6325\u4e24\u79cd\u683c\u5f0f\u7684\u4f18\u52bf\u3002<\/p>\n<p>\u52a0\u6cd5\u989c\u8272\u4e0d\u662f\u53e6\u7c7b&#xff0c;\u800c\u662f\u8fd9\u4e2a\u7edf\u4e00\u6846\u67b6\u7684\u81ea\u7136\u5ef6\u4f38\u2014\u2014\u5f53alpha&#061;0\u65f6&#xff0c;RGB\u81ea\u7136\u6210\u4e3a\u5149\u6e90\u5f3a\u5ea6&#xff0c;\u5b8c\u7f8e\u878d\u5165\u6240\u6709\u8fd0\u7b97\u800c\u65e0\u9700\u7279\u5224\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Color32 \u4f7f\u7528\u624b\u518c&#xff08;\u4fee\u8ba2\u7248&#xff09;<br \/>\n\u4e00\u3001\u7b80\u4ecb<br \/>\nColor32 \u662f egui\/ecolor \u4e2d\u6700\u5e38\u7528\u7684\u989c\u8272\u7c7b\u578b&#xff0c;\u91c7\u752832\u4f4d\u5b58\u50a8\u7684\u9884\u4e58Alpha sRGBA\u683c\u5f0f\u3002\u5b83\u662f\u9762\u5411\u663e\u793a\u8bbe\u5907\u7684\u989c\u8272\u683c\u5f0f&#xff0c;\u6240\u6709\u64cd\u4f5c\u90fd\u5728\u4f3d\u9a6c\u7a7a\u95f4\u8fdb\u884c\u2014\u2014\u8fd9\u610f\u5473\u7740\u5b83\u7684\u6570\u503c\u53d8\u5316\u4e0e\u4eba\u773c\u611f\u77e5\u4e00\u81f4&#xff0c;\u540c\u65f6\u5b8c\u7f8e\u5339\u914d\u663e\u793a\u5668\u7684\u7269\u7406\u7279\u6027\u3002<br \/>\n\u4ec0\u4e48\u662f\u4f3d\u9a6c\u7a7a\u95f4&#xff1f;<br \/>\n\/\/ \u4f3d\u9a6c\u7a7a\u95f4\u662f\u8fde\u63a5\u7269\u7406\u4e16\u754c\u548c\u4eba\u773c\u611f\u77e5\u7684\u6865\u6881<br \/>\n\u7269\u7406\u5149\u5f3a(\u7ebf\u6027) \u2190(\u03b3\u22482.2)\u2192 \u4f3d\u9a6c\u503c(\u5b58\u50a8<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[8423,206],"topic":[],"class_list":["post-77016","post","type-post","status-publish","format-standard","hentry","category-server","tag-egui","tag-rust"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/77016.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"Color32 \u4f7f\u7528\u624b\u518c&#xff08;\u4fee\u8ba2\u7248&#xff09; \u4e00\u3001\u7b80\u4ecb Color32 \u662f egui\/ecolor \u4e2d\u6700\u5e38\u7528\u7684\u989c\u8272\u7c7b\u578b&#xff0c;\u91c7\u752832\u4f4d\u5b58\u50a8\u7684\u9884\u4e58Alpha sRGBA\u683c\u5f0f\u3002\u5b83\u662f\u9762\u5411\u663e\u793a\u8bbe\u5907\u7684\u989c\u8272\u683c\u5f0f&#xff0c;\u6240\u6709\u64cd\u4f5c\u90fd\u5728\u4f3d\u9a6c\u7a7a\u95f4\u8fdb\u884c\u2014\u2014\u8fd9\u610f\u5473\u7740\u5b83\u7684\u6570\u503c\u53d8\u5316\u4e0e\u4eba\u773c\u611f\u77e5\u4e00\u81f4&#xff0c;\u540c\u65f6\u5b8c\u7f8e\u5339\u914d\u663e\u793a\u5668\u7684\u7269\u7406\u7279\u6027\u3002 \u4ec0\u4e48\u662f\u4f3d\u9a6c\u7a7a\u95f4&#xff1f; \/\/ \u4f3d\u9a6c\u7a7a\u95f4\u662f\u8fde\u63a5\u7269\u7406\u4e16\u754c\u548c\u4eba\u773c\u611f\u77e5\u7684\u6865\u6881 \u7269\u7406\u5149\u5f3a(\u7ebf\u6027) \u2190(\u03b3\u22482.2)\u2192 \u4f3d\u9a6c\u503c(\u5b58\u50a8\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/77016.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2026-02-23T12:42:42+00:00\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"8 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/77016.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/77016.html\",\"name\":\"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2026-02-23T12:42:42+00:00\",\"dateModified\":\"2026-02-23T12:42:42+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/77016.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/77016.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/77016.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/77016.html","og_locale":"zh_CN","og_type":"article","og_title":"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"Color32 \u4f7f\u7528\u624b\u518c&#xff08;\u4fee\u8ba2\u7248&#xff09; \u4e00\u3001\u7b80\u4ecb Color32 \u662f egui\/ecolor \u4e2d\u6700\u5e38\u7528\u7684\u989c\u8272\u7c7b\u578b&#xff0c;\u91c7\u752832\u4f4d\u5b58\u50a8\u7684\u9884\u4e58Alpha sRGBA\u683c\u5f0f\u3002\u5b83\u662f\u9762\u5411\u663e\u793a\u8bbe\u5907\u7684\u989c\u8272\u683c\u5f0f&#xff0c;\u6240\u6709\u64cd\u4f5c\u90fd\u5728\u4f3d\u9a6c\u7a7a\u95f4\u8fdb\u884c\u2014\u2014\u8fd9\u610f\u5473\u7740\u5b83\u7684\u6570\u503c\u53d8\u5316\u4e0e\u4eba\u773c\u611f\u77e5\u4e00\u81f4&#xff0c;\u540c\u65f6\u5b8c\u7f8e\u5339\u914d\u663e\u793a\u5668\u7684\u7269\u7406\u7279\u6027\u3002 \u4ec0\u4e48\u662f\u4f3d\u9a6c\u7a7a\u95f4&#xff1f; \/\/ \u4f3d\u9a6c\u7a7a\u95f4\u662f\u8fde\u63a5\u7269\u7406\u4e16\u754c\u548c\u4eba\u773c\u611f\u77e5\u7684\u6865\u6881 \u7269\u7406\u5149\u5f3a(\u7ebf\u6027) \u2190(\u03b3\u22482.2)\u2192 \u4f3d\u9a6c\u503c(\u5b58\u50a8","og_url":"https:\/\/www.wsisp.com\/helps\/77016.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2026-02-23T12:42:42+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"8 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/77016.html","url":"https:\/\/www.wsisp.com\/helps\/77016.html","name":"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2026-02-23T12:42:42+00:00","dateModified":"2026-02-23T12:42:42+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/77016.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/77016.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/77016.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"\u3010egui\u3011Color32 \u4f7f\u7528\u624b\u518c"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/77016","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=77016"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/77016\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=77016"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=77016"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=77016"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=77016"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}