{"id":12198,"date":"2026-05-25T14:12:57","date_gmt":"2026-05-25T05:12:57","guid":{"rendered":"https:\/\/code-plus.jp\/gp\/?page_id=12198"},"modified":"2026-06-04T22:12:29","modified_gmt":"2026-06-04T13:12:29","slug":"imagetone-converter","status":"publish","type":"page","link":"https:\/\/code-plus.jp\/gp\/tools\/imagetone-converter\/","title":{"rendered":"\u753b\u50cf\u30c8\u30fc\u30f3\u88dc\u6b63\u30c4\u30fc\u30eb | \u660e\u5ea6\u30fb\u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\u30fb\u8272\u8abf\u30fb\u5f69\u5ea6\u3092\u4e00\u62ec\u8abf\u6574"},"content":{"rendered":"<!-- \u25bc.page -->\r\n\r\n<!-- .mezzala\uff08\u4f59\u767d\u8abf\u6574\uff1apage\u4e0a\uff09 -->\r\n<hr class=\"adj-cnvtVkaA-mezzalaA\" \/>\r\n\r\n<hr id=\"ch-TextConverter\" anchor \/>\r\n<div class=\"pg-saracnvtvkaa\">\r\n\r\n  <header class=\"page-header mx-auto\">\r\n    <!-- \u30d1\u30f3\u304f\u305a\u30ea\u30b9\u30c8 --><div><!-- breadcrumb.php -->\n<style>\n\/* .breadcrumb.leckermaul\uff08\u30d1\u30f3\u304f\u305a\u30ea\u30b9\u30c8\uff09\n\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500 *\/\n.zaratan .breadcrumb.leckermaul {\n\twidth: 100%;\n\tmax-width: 92.5vw;\n\tmargin-inline: auto;\n}\n\n.zaratan .breadcrumb.leckermaul :is(ul, ol) {\n\tmin-height: 3rem;\n\tline-height: initial;\n\tfont-size: 0;\n\tletter-spacing: 0;\n\toverflow: hidden;\n}\n\n.zaratan .breadcrumb.leckermaul li {\n\tdisplay: inline;\n\tline-height: 1.55;\n\tfont-size: clamp(0.775rem, calc(0.775rem + ((1vw - 0.225rem) * 0.1563)), 0.8750rem);\n}\n\n.zaratan .breadcrumb.leckermaul li>*,\n.zaratan .breadcrumb.leckermaul li::before {\n\tposition: relative;\n\ttop: 0.125em;\n\tdisplay: inline-flex;\n\talign-items: center;\n}\n\n.zaratan .breadcrumb.leckermaul a {\n\tdisplay: inline;\n\tcolor: var(--c-text-300, hsl(233, 6%, 74%));\n\tmargin-right: .5em;\n}\n\n.zaratan .breadcrumb.leckermaul li:nth-of-type(n+2) a {\n\tmargin-left: .5em;\n}\n\n.zaratan .breadcrumb.leckermaul .current_page_item a {\n\tpointer-events: none;\n\tcolor: var(--c-text-300, hsl(233, 6%, 74%));\n}\n\n@media (any-hover:hover) {\n\t.zaratan .breadcrumb.leckermaul a:hover {\n\t\tcolor: var(--c-text-300, hsl(233, 6%, 74%));\n\t}\n}\n\n\/* .separator *\/\n.zaratan .breadcrumb.leckermaul li:nth-of-type(n+2)::before,\n.zaratan .breadcrumb.leckermaul.chevron-right li:nth-of-type(n+2)::before {\n\tcontent: \">\";\n\tcolor: var(--c-text-300, hsl(233, 6%, 74%))\n}\n\n.zaratan .breadcrumb.leckermaul.slash li:nth-of-type(n+2)::before {\n\tcontent: \"\/\";\n}\n\n.zaratan .breadcrumb.leckermaul.trigon-bullet li:nth-of-type(n+2)::before {\n\tcontent: \"\u2023\";\n}\n<\/style>\n\n\n<nav class=\"breadcrumb leckermaul mx-auto py-0.5r\">\n  <ul class=\"breadcrumb-wrapper\">\n    <!-- \u30c8\u30c3\u30d7\u30da\u30fc\u30b8\u3078\u306e\u30ea\u30f3\u30af\u3092\u8868\u793a -->\n    <li><a href=\"https:\/\/code-plus.jp\/gp\/\"><i><\/i>\u30c8\u30c3\u30d7<\/a><\/li>\n\n          <!-- \u56fa\u5b9a\u30da\u30fc\u30b8\uff08\u305d\u308c\u4ee5\u5916\uff09\uff1a \u5148\u7956\u30da\u30fc\u30b8\u540d\u3068\u3001\u73fe\u5728\u306e\u30da\u30fc\u30b8\u540d\u3092\u8868\u793a -->\n      <li><a href=\"https:\/\/code-plus.jp\/gp\/tools\/\">TOOLS\uff08\u30c4\u30fc\u30eb\u4e00\u89a7\uff09<\/a><\/li><li class=\"current_page_item\"><a>\u30c4\u30fc\u30eb<\/a><\/li>    <!-- \/\/\/if (is_page()) -->\n\n  <\/ul>\n<\/nav><\/div>\r\n  <\/header><!-- \/\/\/.inheader -->\r\n\r\n  <!-- .section -->\r\n  <section class=\"sect-cnvtVkaA-Intro contvis-auto\" style=\"contain-intrinsic-size:800px;\">\r\n    <header class=\"section__inheader innerA mx-auto scroll-fadeIn\">\r\n      <div class=\"hgroup-wrapper d-iblock mb-0.5r\">\r\n        <h1 class=\"fz-xxl hdg-page mb-0.25pc\"><span>\u753b\u50cf\u30c8\u30fc\u30f3\u88dc\u6b63\u30c4\u30fc\u30eb | \u660e\u5ea6\u30fb\u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\u30fb\u8272\u8abf\u30fb\u5f69\u5ea6\u3092\u4e00\u62ec\u8abf\u6574<\/span><\/h1>\r\n        <p class=\"page-foreword fz-ss\">\r\n          \u8907\u6570\u306e\u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u3092\u30c9\u30e9\u30c3\u30b0&amp;\u30c9\u30ed\u30c3\u30d7\u3059\u308b\u3060\u3051\u3067\u3001\u660e\u5ea6\u30fb\u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\u30fb\u8272\u8abf\u30fb\u5f69\u5ea6\u3092\u500b\u5225\u306b\u30d7\u30ec\u30d3\u30e5\u30fc\u8abf\u6574\u3002\u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\u306b\u3082\u5bfe\u5fdc\u3002JPG \/ PNG \/ WebP \u5f62\u5f0f\u3067\u4e00\u62ec\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3002\r\n        <\/p>\r\n      <\/div><!-- \/\/\/.hgroup -->\r\n\r\n      <a class=\"fl-right badge is-outlined is-gray fz-xs bdrs-0.25r\" href=\"#ch-Explanation\">\r\n        <i class=\"icon mas ma-help\"><\/i>&nbsp;<span>\u4f7f\u3044\u65b9<\/span>\r\n      <\/a>\r\n    <\/header><!-- \/\/\/.inheader -->\r\n  <\/section>\r\n\r\n\r\n  <!-- .section -->\r\n  <hr id=\"ch-Converter\" anchor \/>\r\n  <section class=\"sect-cnvtVkaA-Converter contvis-auto\" style=\"contain-intrinsic-size:800px;\">\r\n    <div class=\"section__interior innerA fxd-row mx-auto\">\r\n      <figure class=\"section__leftlane\">\r\n        <div class=\"hgroup-wrapper\">\r\n          <h3 class=\"fz-rg hdg-section mb-0.25pc\"><span>\u25bc\u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u3092\u30c9\u30ed\u30c3\u30d7\u3057\u3066\u304f\u3060\u3055\u3044<\/span><\/h3>\r\n        <\/div><!-- \/\/\/.hgroup -->\r\n\r\n        <div class=\"chest-wrapper relatived\">\r\n          <div id=\"endropArea\" class=\"endrop-area\" style=\"height:17.5pc;\">\r\n            <div class=\"endrop-inner\">\r\n              <i class=\"endrop-icon\"><\/i>\r\n              <p class=\"endrop-text\">\u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u3092\u30c9\u30e9\u30c3\u30b0&amp;\u30c9\u30ed\u30c3\u30d7<\/p>\r\n              <small class=\"endrop-smock\">\u307e\u305f\u306f \u30af\u30ea\u30c3\u30af\u3057\u3066\u9078\u629e\uff08\u8907\u6570\u53ef\uff09<\/small>\r\n            <\/div>\r\n            <input type=\"file\" id=\"fileInput\" class=\"file-input\" accept=\"image\/jpeg,image\/png,image\/webp,image\/svg+xml\" multiple>\r\n          <\/div>\r\n          <ins id=\"decodedMessage\"><\/ins>\r\n        <\/div><!-- \/\/\/.chest -->\r\n\r\n        <!-- \u30aa\u30d7\u30b7\u30e7\u30f3 -->\r\n        <div class=\"colgroup w-full mt-1r\">\r\n          <h4 class=\"title is-outlined fz-sm\">\u5909\u63db\u5148\u30d5\u30a9\u30fc\u30de\u30c3\u30c8<\/h4>\r\n          <label class=\"label is-outlined fz-sm\"><input type=\"checkbox\" class=\"checkbox\" id=\"convertToJpg\" checked>JPG \u306b\u5909\u63db<\/label>\r\n          <label class=\"label is-outlined fz-sm\"><input type=\"checkbox\" class=\"checkbox\" id=\"convertToPng\">PNG \u306b\u5909\u63db<\/label>\r\n          <label class=\"label is-outlined fz-sm\"><input type=\"checkbox\" class=\"checkbox\" id=\"convertToWebp\">WebP \u306b\u5909\u63db<\/label>\r\n        <\/div><!-- \/\/\/.colgroup -->\r\n\r\n        <div class=\"colgroup w-full mt-1r\">\r\n          <h4 class=\"title is-outlined fz-sm\">\u54c1\u8cea\u8a2d\u5b9a<\/h4>\r\n          <label class=\"label is-outlined fz-sm\">\r\n            <p class=\"fz-sm\">JPG \/ WebP \u54c1\u8cea\uff1a<\/p>\r\n            <select id=\"qualitySelect\" class=\"select w-10e\">\r\n              <option value=\"1.0\">100%\uff08\u6700\u9ad8\u753b\u8cea\uff09<\/option>\r\n              <option value=\"0.92\" selected>92%\uff08\u9ad8\u753b\u8cea\uff09<\/option>\r\n              <option value=\"0.85\">85%\uff08\u6a19\u6e96\uff09<\/option>\r\n              <option value=\"0.75\">75%\uff08\u3084\u3084\u5727\u7e2e\uff09<\/option>\r\n              <option value=\"0.60\">60%\uff08\u5727\u7e2e\u512a\u5148\uff09<\/option>\r\n            <\/select>\r\n          <\/label>\r\n          <label class=\"label is-outlined fz-sm\">\r\n            <p class=\"fz-sm\">JPG \u80cc\u666f\u8272\uff08\u900f\u904e\u753b\u50cf\u7528\uff09\uff1a<\/p>\r\n            <select id=\"jpgBgColor\" class=\"select w-10e\">\r\n              <option value=\"#ffffff\" selected>\u767d\uff08#ffffff\uff09<\/option>\r\n              <option value=\"#000000\">\u9ed2\uff08#000000\uff09<\/option>\r\n              <option value=\"#f5f5f5\">\u30e9\u30a4\u30c8\u30b0\u30ec\u30fc\uff08#f5f5f5\uff09<\/option>\r\n            <\/select>\r\n          <\/label>\r\n        <\/div><!-- \/\/\/.colgroup -->\r\n      <\/figure><!-- \/\/\/.leftlane -->\r\n\r\n      <figure class=\"section__centerlane\">\r\n        <aside class=\"sticky-sidebar fxd-column pc-center\" style=\"height:22rem;\">\r\n        <\/aside>\r\n      <\/figure><!-- \/\/\/.centerlane -->\r\n\r\n\r\n      <figure class=\"section__rightlane\">\r\n        <div class=\"chest-wrapper relatived\">\r\n          <h3 class=\"fz-rg hdg-section mb-0.25pc\"><span>\u25bc\u30d7\u30ec\u30d3\u30e5\u30fc<\/span><\/h3>\r\n          <div id=\"previewArea\" style=\"overflow-y:auto;background:var(--color-bg-input,#f7f8f9);border:1px solid var(--color-border,#ddd);border-radius:4px;padding:0;\">\r\n            <div id=\"previewPlaceholder\" style=\"height:17.5pc;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted,#aaa);font-size:14px;\">\r\n              \u753b\u50cf\u3092\u30c9\u30ed\u30c3\u30d7\u3059\u308b\u3068\u30d7\u30ec\u30d3\u30e5\u30fc\u304c\u8868\u793a\u3055\u308c\u307e\u3059\r\n            <\/div>\r\n            <div id=\"previewList\" style=\"display:none;\"><\/div>\r\n          <\/div>\r\n          <ins id=\"encodedMessage\"><\/ins>\r\n        <\/div><!-- \/\/\/.chest -->\r\n\r\n        <div id=\"downloadControls\" style=\"display:none;\" class=\"colgroup w-full mt-1r\">\r\n          <div id=\"processingList\"><\/div>\r\n          <p class=\"ta-center mt-1r\">\r\n            <a id=\"downloadBtn\" class=\"button is-solided is-primary\" href=\"javascript:void(0);\" onclick=\"startDownload()\">\u753b\u50cf\u3092\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9<\/a>\r\n          <\/p>\r\n        <\/div>\r\n      <\/figure><!-- \/\/\/.rightlane -->\r\n    <\/div><!-- \/\/\/.interior.fxd-row -->\r\n  <\/section>\r\n\r\n\r\n  <!-- .section -->\r\n  <hr id=\"ch-Explanation\" anchor \/>\r\n  <section class=\"sect-cnvtVkaA-Explanation pt-3r contvis-auto\" style=\"contain-intrinsic-size:800px;\">\r\n    <div class=\"section__interior innerA mx-auto scroll-fadeIn\">\r\n      <div class=\"box is-broad is-solided c-text\">\r\n        <h4 class=\"hdg-explanation fz-md mb-0.25pc\">\u4f7f\u3044\u65b9<\/h4>\r\n        <p class=\"fz-ss mb-1r\">\r\n          \u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u3092\u30c9\u30e9\u30c3\u30b0&amp;\u30c9\u30ed\u30c3\u30d7\u3059\u308b\u3068\u3001\u5168\u753b\u50cf\u306e\u30d7\u30ec\u30d3\u30e5\u30fc\u304c\u8868\u793a\u3055\u308c\u307e\u3059\u3002\u5404\u753b\u50cf\u306e\u30b9\u30e9\u30a4\u30c0\u30fc\u3067\u30c8\u30fc\u30f3\u3092\u500b\u5225\u306b\u8abf\u6574\u3057\u3001\u300c\u753b\u50cf\u3092\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u300d\u30dc\u30bf\u30f3\u3067\u4e00\u62ec\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3057\u307e\u3059\u3002\r\n        <\/p>\r\n\r\n        <h5 class=\"fz-ss hdg-explanation mb-0.25pc mt-1r\">\ud83c\udf9b\ufe0f \u8abf\u6574\u3067\u304d\u308b\u9805\u76ee<\/h5>\r\n        <ul class=\"fz-ss mb-1r\">\r\n          <li><b class=\"bold\">\u660e\u5ea6\uff1a<\/b> \u753b\u50cf\u306e\u660e\u308b\u3055\u3092\u8abf\u6574\uff08\u6697\u3044\u5199\u771f\u3092\u660e\u308b\u304f\u3001\u660e\u308b\u3059\u304e\u308b\u5199\u771f\u3092\u6697\u304f\u3059\u308b\u7b49\uff09<\/li>\r\n          <li><b class=\"bold\">\u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\uff1a<\/b> \u660e\u6697\u5dee\u3092\u8abf\u6574\uff0850%\u301c200%\uff09\u3002\u4e0a\u3052\u308b\u3068\u30e1\u30ea\u30cf\u30ea\u304c\u51fa\u308b<\/li>\r\n          <li><b class=\"bold\">\u8272\u8abf\uff08Hue\uff09\uff1a<\/b> \u8272\u5408\u3044\u3092 -180\u00b0\u301c+180\u00b0 \u3067\u30b7\u30d5\u30c8\u3002\u30db\u30ef\u30a4\u30c8\u30d0\u30e9\u30f3\u30b9\u306e\u5fae\u8abf\u6574\u306b<\/li>\r\n          <li><b class=\"bold\">\u5f69\u5ea6\uff1a<\/b> \u9bae\u3084\u304b\u3055\u3092\u8abf\u6574\uff080%\u3067\u30e2\u30ce\u30af\u30ed\u3001200%\u3067\u9bae\u3084\u304b\u306b\uff09<\/li>\r\n          <li><b class=\"bold\">\u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\uff1a<\/b> \u30d2\u30b9\u30c8\u30b0\u30e9\u30e0\u3092\u5206\u6790\u3057\u3001\u6700\u6697\u30fb\u6700\u660e\u90e8\u3092\u81ea\u52d5\u3067\u30b9\u30c8\u30ec\u30c3\u30c1\u3002Photoshop\u306e\u300c\u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\u300d\u3068\u540c\u7b49\u306e\u51e6\u7406<\/li>\r\n        <\/ul>\r\n\r\n        <h5 class=\"fz-ss hdg-explanation mb-0.25pc\">\ud83c\udfaf \u6d3b\u7528\u4f8b<\/h5>\r\n        <ul class=\"fz-ss mb-1r\">\r\n          <li><b class=\"bold\">\u7269\u4ef6\u5199\u771f\u306e\u7d71\u4e00\uff1a<\/b> \u5929\u5019\u3084\u6642\u9593\u5e2f\u3067\u660e\u308b\u3055\u304c\u30d0\u30e9\u30d0\u30e9\u306a\u5199\u771f\u3092\u3001Photoshop\u3092\u958b\u304b\u305a\u306b\u63c3\u3048\u308b<\/li>\r\n          <li><b class=\"bold\">\u66c7\u5929\u5199\u771f\u306e\u88dc\u6b63\uff1a<\/b> \u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63 + \u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\u3092\u4e0a\u3052\u3066\u3001\u304f\u3059\u3093\u3060\u5199\u771f\u3092\u304f\u3063\u304d\u308a\u3068<\/li>\r\n          <li><b class=\"bold\">\u30dd\u30fc\u30c8\u30d5\u30a9\u30ea\u30aa\u4f5c\u6210\uff1a<\/b> \u8907\u6570\u306e\u4f5c\u54c1\u5199\u771f\u306e\u30c8\u30fc\u30f3\u3092\u7d71\u4e00\u3057\u3066\u3001\u4e00\u8cab\u3057\u305f\u898b\u305f\u76ee\u306b<\/li>\r\n          <li><b class=\"bold\">SNS\u6295\u7a3f\u7528\uff1a<\/b> \u5f69\u5ea6\u3092\u4e0a\u3052\u3066\u9bae\u3084\u304b\u306b\u3001\u307e\u305f\u306f\u30e2\u30ce\u30af\u30ed\u5316\u3057\u3066\u96f0\u56f2\u6c17\u306e\u3042\u308b\u753b\u50cf\u306b<\/li>\r\n        <\/ul>\r\n\r\n        <h5 class=\"fz-ss hdg-explanation mb-0.25pc\">\u2699\ufe0f \u51fa\u529b\u8a2d\u5b9a<\/h5>\r\n        <ul class=\"fz-ss mb-1r\">\r\n          <li><b class=\"bold\">\u5bfe\u5fdc\u5165\u529b\u5f62\u5f0f\uff1a<\/b> JPG \/ PNG \/ WebP \/ SVG<\/li>\r\n          <li><b class=\"bold\">\u5bfe\u5fdc\u51fa\u529b\u5f62\u5f0f\uff1a<\/b> JPG \/ PNG \/ WebP\uff08\u8907\u6570\u540c\u6642\u9078\u629e\u53ef\uff09<\/li>\r\n          <li><b class=\"bold\">\u54c1\u8cea\u8a2d\u5b9a\uff1a<\/b> JPG \/ WebP \u306e\u5727\u7e2e\u54c1\u8cea\u30925\u6bb5\u968e\u3067\u9078\u629e\u53ef\u80fd<\/li>\r\n          <li><b class=\"bold\">\u900f\u904e\u753b\u50cf\uff1a<\/b> PNG \u306e\u900f\u904e\u90e8\u5206\u306fJPG\u5909\u63db\u6642\u306b\u6307\u5b9a\u3057\u305f\u80cc\u666f\u8272\u3067\u5857\u308a\u3064\u3076\u3057<\/li>\r\n        <\/ul>\r\n\r\n        <h5 class=\"fz-ss hdg-explanation mb-0.25pc\">\u26a0\ufe0f \u6ce8\u610f\u4e8b\u9805<\/h5>\r\n        <ul class=\"fz-ss\">\r\n          <li><b class=\"bold\">\u30d6\u30e9\u30a6\u30b6\u51e6\u7406\uff1a<\/b> \u3059\u3079\u3066\u306e\u51e6\u7406\u306f\u30d6\u30e9\u30a6\u30b6\u5185\u3067\u5b8c\u7d50\u3057\u307e\u3059\uff08\u30b5\u30fc\u30d0\u30fc\u306b\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3055\u308c\u307e\u305b\u3093\uff09<\/li>\r\n          <li><b class=\"bold\">\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u30d7\u30ec\u30d3\u30e5\u30fc\uff1a<\/b> \u30b9\u30e9\u30a4\u30c0\u30fc\u64cd\u4f5c\u3067\u5373\u5ea7\u306b\u30d7\u30ec\u30d3\u30e5\u30fc\u304c\u66f4\u65b0\u3055\u308c\u307e\u3059<\/li>\r\n          <li><b class=\"bold\">\u975e\u7834\u58ca\u7de8\u96c6\uff1a<\/b> \u5143\u753b\u50cf\u306f\u5909\u66f4\u3055\u308c\u307e\u305b\u3093\u3002\u300c\u30ea\u30bb\u30c3\u30c8\u300d\u3067\u521d\u671f\u72b6\u614b\u306b\u623b\u305b\u307e\u3059<\/li>\r\n        <\/ul>\r\n      <\/div>\r\n    <\/div><!-- \/\/\/.interior -->\r\n  <\/section><!-- \/\/\/.section -->\r\n\r\n\r\n  <!-- .section -->\r\n  <hr id=\"ch-Relation\" anchor \/>\r\n  <section class=\"sect-cnvtVkaA-Relation pt-3r contvis-auto\" style=\"contain-intrinsic-size:800px;\">\r\n    <div class=\"section__interior innerA mx-auto scroll-fadeIn\">\r\n      <div class=\"hgroup-wrapper hgroupA mb-0.5pc\">\r\n        <h5 class=\"hdg-relation fz-rg\"><span>\u95a2\u9023\u30c4\u30fc\u30eb<\/span><\/h5>\r\n      <\/div><!-- \/\/\/.hgroup -->\r\n\r\n      <ul class=\"shelf-wrapper_pc shelfA\" data-cols_pc=\"2\">\r\n        <li class=\"slide\">\r\n          <a href=\"https:\/\/code-plus.jp\/gp\/tools\/imgtag-converter\/\" class=\"linkbox\">\r\n            <h4 class=\"linkbox-title fz-md\">&lt;img&gt; \u30bf\u30b0\u5909\u63db\u30c4\u30fc\u30eb<\/h4>\r\n            <span class=\"linkbox-excerpt\">img\u30bf\u30b0\u306e\u5c5e\u6027\u7de8\u96c6\u3001picture\/source \u30bf\u30b0\u306e\u81ea\u52d5\u751f\u6210\u3002<\/span>\r\n          <\/a>\r\n        <\/li>\r\n        <li class=\"slide\">\r\n          <a href=\"https:\/\/code-plus.jp\/gp\/tools\/colorcode-converter\/\" class=\"linkbox\">\r\n            <h4 class=\"linkbox-title fz-md\">\u30ab\u30e9\u30fc\u30b3\u30fc\u30c9\u5909\u63db\u30c4\u30fc\u30eb<\/h4>\r\n            <span class=\"linkbox-excerpt\">RGB \/ RGBA \/ HSL \u30ab\u30e9\u30fc\u30b3\u30fc\u30c9\u3092HEX\u306b\u4e00\u62ec\u5909\u63db\u3002<\/span>\r\n          <\/a>\r\n        <\/li>\r\n      <\/ul><!-- \/\/\/.shelf -->\r\n    <\/div><!-- \/\/\/.interior -->\r\n  <\/section><!-- \/\/\/.section -->\r\n\r\n\r\n  <!-- .department -->\r\n  <hr id=\"ch-Relation2\" anchor \/>\r\n  <section class=\"sect-cnvtVkaA-Relation2 pt-3r contvis-auto\" style=\"contain-intrinsic-size:800px;\">\r\n    <div class=\"section__interior innerA mx-auto scroll-fadeIn\">\r\n      <div class=\"hgroup-wrapper hgroupA mb-0.5pc\">\r\n        <h5 class=\"hdg-relation fz-rg\"><span>\u30c4\u30fc\u30eb\u4e00\u89a7<\/span><\/h5>\r\n      <\/div><!-- \/\/\/.hgroup -->\r\n\r\n      <div class=\"pt-cv-wrapper\"><div class=\"pt-cv-view pt-cv-grid pt-cv-colsys\" id=\"pt-cv-view-2f67d27xgo\"><div data-id=\"pt-cv-page-1\" class=\"pt-cv-page\" data-cvc=\"3\"><div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"5957\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/markdown-converter\/\" class=\"_self\" target=\"_self\" >Markdown\u8a18\u6cd5\u21c4HTML \u30aa\u30f3\u30e9\u30a4\u30f3\u5909\u63db\u30c4\u30fc\u30eb | \u53cc\u65b9\u5411\u5909\u63db\u30b5\u30a4\u30c8<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"12124\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/en\/markdown-converter\/\" class=\"_self\" target=\"_self\" >Markdown \u21c4 HTML Online Converter | Bidirectional Conversion Tool<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"12223\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/colorpalette-generator\/\" class=\"_self\" target=\"_self\" >colorpalette-generator<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"12542\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/imageupscale-converter\/\" class=\"_self\" target=\"_self\" >\u753b\u50cfLanczos\u62e1\u5927\u30c4\u30fc\u30eb | AI\u3092\u4f7f\u308f\u305a Lanczos\u3067\u62e1\u5927\u3057\u3001\u30a8\u30c3\u30b8\u3092\u7de0\u3081\u3066\u304f\u3063\u304d\u308a\u4ed5\u4e0a\u3052\u307e\u3059<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"12198\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/imagetone-converter\/\" class=\"_self\" target=\"_self\" >\u753b\u50cf\u30c8\u30fc\u30f3\u88dc\u6b63\u30c4\u30fc\u30eb | \u660e\u5ea6\u30fb\u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\u30fb\u8272\u8abf\u30fb\u5f69\u5ea6\u3092\u4e00\u62ec\u8abf\u6574<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"12171\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/imageext-converter\/\" class=\"_self\" target=\"_self\" >\u753b\u50cf\u5f62\u5f0f\u5909\u63db\u30c4\u30fc\u30eb | JPG \/ PNG \/ WebP \/ SVG \u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u3092\u3001\u6307\u5b9a\u3057\u305f\u5f62\u5f0f\u306b\u4e00\u62ec\u5909\u63db<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"11549\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/responsive-clamp-calculator\/\" class=\"_self\" target=\"_self\" >\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u306a\u30d5\u30a9\u30f3\u30c8\u30b5\u30a4\u30ba\u30b8\u30a7\u30cd\u30ec\u30fc\u30bf\u30fc - \u8907\u6570\u30d7\u30ed\u30d1\u30c6\u30a3\/\u30b9\u30de\u30db\u306e\u65b9\u304c\u6587\u5b57\u30b5\u30a4\u30ba\u304c\u5927\u304d\u3044\u5834\u5408\u306b\u3082\u5bfe\u5fdc<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"11746\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/specificity-calculator\/\" class=\"_self\" target=\"_self\" >CSS\u30bb\u30ec\u30af\u30bf \u8a73\u7d30\u5ea6\u8a08\u7b97\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"11509\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/textchar-encoder\/\" class=\"_self\" target=\"_self\" >\u6587\u5b57\u30b3\u30fc\u30c9\u5909\u63db\u30c4\u30fc\u30eb | Shift_JIS \/ EUC-JP \u306e\u30c6\u30ad\u30b9\u30c8\u30d5\u30a1\u30a4\u30eb\u3092 UTF-8 \u306b\u4e00\u62ec\u5909\u63db<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"10981\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/colorcode-converter\/\" class=\"_self\" target=\"_self\" >\u30ab\u30e9\u30fc\u30b3\u30fc\u30c9\u4e00\u62ec\u5909\u63db\u30c4\u30fc\u30eb | RGBA, HSL\u21c4HEX\u5909\u63db\u30b5\u30a4\u30c8<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"9062\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/dirtree-generator\/\" class=\"_self\" target=\"_self\" >DirTree Generator\uff08\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u30c4\u30ea\u30fc\u751f\u6210\u30c4\u30fc\u30eb\uff09 -\u30d5\u30a9\u30eb\u30c0\u69cb\u9020\u3092\u8996\u899a\u5316-<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6032\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/eyecatch-generator\/\" class=\"_self\" target=\"_self\" >\u30bf\u30a4\u30c8\u30eb\u4ed8\u304d\u306e\u30a2\u30a4\u30ad\u30e3\u30c3\u30c1\u753b\u50cf\u751f\u6210\u30c4\u30fc\u30eb | \u30aa\u30f3\u30e9\u30a4\u30f3\u4e0a\u3067\u6587\u5b57\u3092\u753b\u50cf\u306b\u5909\u63db<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"10460\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/markitdown-converter\/\" class=\"_self\" target=\"_self\" >pptx\/docx\/pdf\u2192Markdown \u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6384\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/breaks-converter\/\" class=\"_self\" target=\"_self\" >\u6539\u884c\u30fb\u30bf\u30d6\u5909\u63db\u30c4\u30fc\u30eb - &amp;#13;&amp;#10; &lt;br&gt; \\A HTML\u30a8\u30f3\u30c6\u30a3\u30c6\u30a3\u30fbbr\u30bf\u30b0\u4e00\u62ec\u5909\u63db<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6207\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/text-replacer-rem-calc\/\" class=\"_self\" target=\"_self\" >\u8907\u6570\u30eb\u30fc\u30eb\u304b\u3089\u30c6\u30ad\u30b9\u30c8\u4e00\u62ec\u7f6e\u63db\u30c4\u30fc\u30eb\u3010rem \u2194 calc\u3011<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"10814\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/text-replacer-em-rem\/\" class=\"_self\" target=\"_self\" >\u8907\u6570\u30eb\u30fc\u30eb\u304b\u3089\u30c6\u30ad\u30b9\u30c8\u4e00\u62ec\u7f6e\u63db\u30c4\u30fc\u30eb\u3010em \u2194 rem\u3011<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6140\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/text-replacer-pc-rem\/\" class=\"_self\" target=\"_self\" >\u8907\u6570\u30eb\u30fc\u30eb\u304b\u3089\u30c6\u30ad\u30b9\u30c8\u4e00\u62ec\u7f6e\u63db\u30c4\u30fc\u30eb\u3010pc \u2194 rem\u3011<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7055\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/text-replacer-px-em\/\" class=\"_self\" target=\"_self\" >\u8907\u6570\u30eb\u30fc\u30eb\u304b\u3089\u30c6\u30ad\u30b9\u30c8\u4e00\u62ec\u7f6e\u63db\u30c4\u30fc\u30eb\u3010px \u2194 em\u3011<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6124\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/text-replacer-px-rem\/\" class=\"_self\" target=\"_self\" >\u8907\u6570\u30eb\u30fc\u30eb\u304b\u3089\u30c6\u30ad\u30b9\u30c8\u4e00\u62ec\u7f6e\u63db\u30c4\u30fc\u30eb\u3010px \u2194 rem\u3011<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"10161\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/linebounds-converter\/\" class=\"_self\" target=\"_self\" >\u30d1\u30a4\u30d7\u8a18\u53f7(|)\u968e\u5c64\u30ea\u30b9\u30c8\u3092 \u2192 \u7f6b\u7dda\u56f2\u307f\u306b\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6964\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/table-converter\/\" class=\"_self\" target=\"_self\" >&nbsp;|\uff08\u30d1\u30a4\u30d7\uff09\u3092Table\u30bf\u30b0\u306b\u5909\u63db\u30c4\u30fc\u30eb | Markdown\u8868\u5f62\u5f0f\u2192HTML\u81ea\u52d5\u5909\u63db<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7062\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/deline-converter\/\" class=\"_self\" target=\"_self\" >&nbsp;|\uff08\u30d1\u30a4\u30d7\uff09\u3092Dl\u30bf\u30b0\u306b\u5909\u63db\u30c4\u30fc\u30eb - \u5b9a\u7fa9\u30ea\u30b9\u30c8\u30fb\u7528\u8a9e\u96c6HTML\u81ea\u52d5\u751f\u6210<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"10028\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/font-metrics-analyzer\/\" class=\"_self\" target=\"_self\" >\u30d5\u30a9\u30f3\u30c8\u30e1\u30c8\u30ea\u30af\u30b9\u89e3\u6790\u30c4\u30fc\u30eb - 2\u3064\u306e\u30d5\u30a9\u30f3\u30c8\u3092\u6bd4\u8f03\u3057\u3066\u3001size-adjust\u306e\u6700\u9069\u5024\u3092\u8a08\u7b97<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"8636\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/imgtag-converter\/\" class=\"_self\" target=\"_self\" >\u753b\u50cf\u2192img\u30bf\u30b0\u5909\u63db\u30c4\u30fc\u30eb | \u753b\u50cf\u30b5\u30a4\u30ba\u30fb\u30a2\u30b9\u30da\u30af\u30c8\u6bd4\u81ea\u52d5\u8a08\u7b97\u30b5\u30a4\u30c8<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"9036\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/svg2gif-converter\/\" class=\"_self\" target=\"_self\" >svg2gif-converter<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7615\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/charbase36-converter\/\" class=\"_self\" target=\"_self\" >10\u9032\u6570\u3092 26\u9032\u6570\u306b\u3001\u30a8\u30f3\u30b3\u30fc\u30c9 \u2194 \u30c7\u30b3\u30fc\u30c9\u3059\u308b\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"9585\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/list2trees-converter\/\" class=\"_self\" target=\"_self\" >\u30d7\u30e9\u30b9\u8a18\u53f7(+)\u968e\u5c64\u30ea\u30b9\u30c8\u3092 \u2192 \u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u30c4\u30ea\u30fc\u306b\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"8005\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/page-8005\/\" class=\"_self\" target=\"_self\" >\u884c\u3092 \u2192 \u6307\u5b9a\u5217\u306e\u30bf\u30d6\u533a\u5207\u308a\u884c\u306b\u5909\u63db\u3059\u308b\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7816\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/lines-converter\/\" class=\"_self\" target=\"_self\" >\u884c\u3092\u9006\u9806\u306b\u4e26\u3073\u66ff\u3048\u308b\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7187\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/charurl-converter\/\" class=\"_self\" target=\"_self\" >\u30c6\u30ad\u30b9\u30c8\u3092 URL\u30a8\u30f3\u30b3\u30fc\u30c9\u306b\u3001\u30a8\u30f3\u30b3\u30fc\u30c9 \u2194 \u30c7\u30b3\u30fc\u30c9\u3059\u308b\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7362\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/updatetags-converter\/\" class=\"_self\" target=\"_self\" >HTML\u30bf\u30b0\u4e00\u62ec\u5909\u63db\u30c4\u30fc\u30eb | \u30aa\u30f3\u30e9\u30a4\u30f3\u4e0a\u3067\u30bf\u30b0\u8a18\u6cd5\u3092\u77ac\u6642\u306b\u5909\u63db<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7151\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/addclases-converter\/\" class=\"_self\" target=\"_self\" >\u6307\u5b9a\u306e\u30bf\u30b0\u306b \u2192 \u4efb\u610f\u306e\u30af\u30e9\u30b9\u3092\u8ffd\u52a0\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7178\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/renumber-converter\/\" class=\"_self\" target=\"_self\" >Markdown\u5f62\u5f0f\u306e\u756a\u53f7\u3092\u4e0a\u304b\u3089\u4ed8\u3051\u76f4\u3059\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7148\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/multiwords-converter\/\" class=\"_self\" target=\"_self\" >JSON\u5f62\u5f0f\u3067\u8907\u6570\u306e\u8a9e\u53e5\u3092\u307e\u3068\u3081\u3066\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7107\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/multiwords-remover\/\" class=\"_self\" target=\"_self\" >JSON\u5f62\u5f0f\u3067\u8907\u6570\u306e\u8a9e\u53e5\u3092\u307e\u3068\u3081\u3066\u524a\u9664\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7127\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/zenkakumasu-converter\/\" class=\"_self\" target=\"_self\" >\u5168\u89d2\u6587\u5b57\u3092 \u2192 \u303c \u306b\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"7079\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/number0-converter\/\" class=\"_self\" target=\"_self\" >\u3059\u3079\u3066\u306e\u6570\u5b57\u3092 \u2192 \u00f8 \u306b\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6766\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/imagemap-converter\/\" class=\"_self\" target=\"_self\" >SVG\u304b\u3089ImageMap\uff08\u30a4\u30e1\u30fc\u30b8\u30de\u30c3\u30d7\uff09\u306b\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6747\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/fullparenthesis-converter\/\" class=\"_self\" target=\"_self\" >\u534a\u89d2\u62ec\u5f27()\u3092\u3001\u5168\u89d2\u62ec\u5f27\uff08\uff09\u306b\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6691\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/tags-remover\/\" class=\"_self\" target=\"_self\" >\u3059\u3079\u3066\u306eHTML\u30bf\u30b0\u3092\u524a\u9664\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"6019\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/ltgt-converter\/\" class=\"_self\" target=\"_self\" >&lt; &gt; \u3092 &amp;lt; &amp;gt; \u306b\u5909\u63db\u30c4\u30fc\u30eb<\/a><\/h5><\/div><\/div>\n<div class=\"col-md-4 col-sm-6 col-xs-12 pt-cv-content-item pt-cv-2-col\"  data-pid=\"170\"><div class='pt-cv-ifield'><h5 class=\"pt-cv-title\"><a href=\"https:\/\/code-plus.jp\/gp\/tools\/deepl-charcounter\/\" class=\"_self\" target=\"_self\" >DeepL\u7ffb\u8a33 &#038; \u6587\u5b57\u6570\u30ab\u30a6\u30f3\u30bf\u30fc<\/a><\/h5><\/div><\/div><\/div><\/div><\/div>\t\t\t<style type=\"text\/css\" id=\"pt-cv-inline-style-4e029636u8\">#pt-cv-view-2f67d27xgo .pt-cv-title a, #pt-cv-view-2f67d27xgo  .panel-title { font-weight: 600 !important; }\n#pt-cv-view-2f67d27xgo .pt-cv-carousel-caption  { background-color: rgba(51,51,51,.6) !important; }\n#pt-cv-view-2f67d27xgo .pt-cv-specialp { background-color: #CC3333 !important }\n#pt-cv-view-2f67d27xgo .pt-cv-specialp * { color: #fff !important; }\n#pt-cv-view-2f67d27xgo .pt-cv-pficon  { color: #bbb !important; }\n#pt-cv-view-2f67d27xgo .pt-cv-readmore  { color: #ffffff !important; background-color: #00aeef !important; }\n#pt-cv-view-2f67d27xgo .pt-cv-readmore:hover  { color: #ffffff !important; background-color: #00aeef !important; }\n#pt-cv-view-2f67d27xgo  + .pt-cv-pagination-wrapper .pt-cv-more , #pt-cv-view-2f67d27xgo  + .pt-cv-pagination-wrapper .pagination .active a, .pt-cv-pagination[data-sid='2f67d27xgo'] .active a { color: #ffffff !important; background-color: #00aeef !important; }<\/style>\r\n\t\t\t\r\n    <\/div><!-- \/\/\/.interior -->\r\n  <\/section><!-- \/\/\/.section -->\r\n\r\n\r\n  <!-- .mediano\uff08\u4f59\u767d\u8abf\u6574\uff1apage\u4e0b\uff09 -->\r\n  <hr class=\"adj-cnvtVkaA-medianoA\" \/>\r\n\r\n<\/div><!-- \/\/\/\u25b2.page  -->\r\n\r\n\r\n<script>\r\nlet storedImages = []; \/\/ { file, img, brightness, brightnessMultiplier, hue, saturation, contrast, autoToneLevels }\r\n\r\nfunction startDownload() {\r\n  if (window._imageExtApp) window._imageExtApp.doDownload();\r\n}\r\n\r\ndocument.addEventListener('DOMContentLoaded', function() {\r\n  const endropArea = document.getElementById('endropArea');\r\n  const fileInput = document.getElementById('fileInput');\r\n  const previewPlaceholder = document.getElementById('previewPlaceholder');\r\n  const previewList = document.getElementById('previewList');\r\n  const downloadControls = document.getElementById('downloadControls');\r\n  const processingList = document.getElementById('processingList');\r\n  const encodedMessage = document.getElementById('encodedMessage');\r\n\r\n  if (!endropArea) return;\r\n\r\n  fileInput.style.display = 'none';\r\n  endropArea.style.cursor = 'pointer';\r\n\r\n  endropArea.addEventListener('click', function() { fileInput.click(); });\r\n  fileInput.addEventListener('change', function(e) {\r\n    if (e.target.files.length > 0) handleFiles(e.target.files);\r\n    fileInput.value = '';\r\n  });\r\n\r\n  \/\/ \u30c9\u30e9\u30c3\u30b0&\u30c9\u30ed\u30c3\u30d7\r\n  endropArea.addEventListener('dragover', function(e) { e.preventDefault(); e.stopPropagation(); this.style.backgroundColor = '#f0f0f0'; this.style.borderColor = '#999'; });\r\n  endropArea.addEventListener('dragleave', function(e) { e.preventDefault(); e.stopPropagation(); this.style.backgroundColor = ''; this.style.borderColor = ''; });\r\n  endropArea.addEventListener('dragenter', function(e) { e.preventDefault(); e.stopPropagation(); });\r\n  endropArea.addEventListener('drop', function(e) {\r\n    e.preventDefault(); e.stopPropagation();\r\n    this.style.backgroundColor = ''; this.style.borderColor = '';\r\n    if (e.dataTransfer.files.length > 0) handleFiles(e.dataTransfer.files);\r\n  });\r\n\r\n\r\n  \/\/ ====================================\r\n  \/\/ \u30d5\u30a1\u30a4\u30eb\u51e6\u7406\uff08\u30c9\u30ed\u30c3\u30d7\u6642\uff1a\u5168\u753b\u50cf\u30d7\u30ec\u30d3\u30e5\u30fc\u8868\u793a\uff09\r\n  \/\/ ====================================\r\n\r\n  function handleFiles(files) {\r\n    const imageFiles = Array.from(files).filter(isImageFile);\r\n    if (imageFiles.length === 0) {\r\n      alert('\u5bfe\u5fdc\u3059\u308b\u753b\u50cf\u30d5\u30a1\u30a4\u30eb\uff08JPG \/ PNG \/ WebP \/ SVG\uff09\u3092\u30c9\u30ed\u30c3\u30d7\u3057\u3066\u304f\u3060\u3055\u3044\u3002');\r\n      return;\r\n    }\r\n\r\n    storedImages = [];\r\n    previewList.innerHTML = '';\r\n    processingList.innerHTML = '';\r\n\r\n    const dropInner = endropArea.querySelector('.endrop-inner');\r\n    dropInner.innerHTML =\r\n      '<div style=\"padding:20px;\">' +\r\n      '<p style=\"color:#4CAF50;font-weight:bold;\">' + imageFiles.length + '\u500b\u306e\u753b\u50cf\u3092\u8aad\u307f\u8fbc\u307f\u307e\u3057\u305f<\/p>' +\r\n      '<small style=\"color:#666;\">\u30d7\u30ec\u30d3\u30e5\u30fc\u3092\u78ba\u8a8d\u3057\u3066\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3057\u3066\u304f\u3060\u3055\u3044<\/small><\/div>';\r\n\r\n    previewPlaceholder.style.display = 'none';\r\n    previewList.style.display = '';\r\n    downloadControls.style.display = '';\r\n\r\n    \/\/ \u5404\u753b\u50cf\u3092\u8aad\u307f\u8fbc\u3093\u3067\u30d7\u30ec\u30d3\u30e5\u30fc\u30ab\u30fc\u30c9\u3092\u4f5c\u6210\r\n    imageFiles.forEach(function(file, index) {\r\n      loadImageFromFile(file).then(function(img) {\r\n        const brightness = calculateBrightness(img);\r\n        storedImages[index] = { file: file, img: img, brightness: brightness, brightnessMultiplier: 1.0, hue: 0, saturation: 1.0, contrast: 1.0, autoToneLevels: null };\r\n        createPreviewCard(index, file.name, img, brightness);\r\n      }).catch(function(err) {\r\n        console.error('\u8aad\u307f\u8fbc\u307f\u30a8\u30e9\u30fc:', err);\r\n        storedImages[index] = null;\r\n      });\r\n    });\r\n  }\r\n\r\n\r\n  \/\/ ====================================\r\n  \/\/ \u30d7\u30ec\u30d3\u30e5\u30fc\u30ab\u30fc\u30c9\u4f5c\u6210\uff08\u753b\u50cf\u3054\u3068\uff09\r\n  \/\/ ====================================\r\n\r\n  function createPreviewCard(index, fileName, img, brightness) {\r\n    const card = document.createElement('div');\r\n    card.style.cssText = 'padding:12px;border-bottom:1px solid #e0e0e0;';\r\n    card.id = 'previewCard_' + index;\r\n\r\n    \/\/ \u30d5\u30a1\u30a4\u30eb\u540d\r\n    const nameEl = document.createElement('p');\r\n    nameEl.style.cssText = 'font-size:12px;font-weight:500;color:#555;margin:0 0 4px;word-break:break-all;';\r\n    nameEl.textContent = fileName;\r\n    card.appendChild(nameEl);\r\n\r\n    \/\/ Canvas\r\n    const canvas = document.createElement('canvas');\r\n    canvas.id = 'canvas_' + index;\r\n    canvas.style.cssText = 'max-width:100%;display:block;border-radius:3px;';\r\n    card.appendChild(canvas);\r\n\r\n    \/\/ \u73fe\u5728\u306e\u8abf\u6574\u5024\u3092\u4fdd\u6301\r\n    let currentBrightness = 1.0;\r\n    let currentHue = 0;\r\n    let currentSaturation = 1.0;\r\n    let currentContrast = 1.0;\r\n    let autoToneLevels = null;\r\n\r\n    \/\/ \u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\u306e\u30ec\u30d9\u30eb\u5024\u3092\u4e8b\u524d\u8a08\u7b97\r\n    const toneLevels = calculateAutoToneLevels(img);\r\n\r\n    function updatePreview() {\r\n      drawCanvas(canvas, img, currentBrightness, currentHue, currentSaturation, currentContrast, autoToneLevels);\r\n      if (storedImages[index]) {\r\n        storedImages[index].brightnessMultiplier = currentBrightness;\r\n        storedImages[index].hue = currentHue;\r\n        storedImages[index].saturation = currentSaturation;\r\n        storedImages[index].contrast = currentContrast;\r\n        storedImages[index].autoToneLevels = autoToneLevels;\r\n      }\r\n    }\r\n\r\n    \/\/ --- \u660e\u5ea6\u30b9\u30e9\u30a4\u30c0\u30fc ---\r\n    var bRow = createSliderRow('\u660e\u5ea6', Math.round(brightness), 40, 220, Math.round(brightness), function(val) {\r\n      currentBrightness = brightness > 0 ? val \/ brightness : 1;\r\n      updatePreview();\r\n    });\r\n    card.appendChild(bRow.row);\r\n\r\n    \/\/ --- \u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\u30b9\u30e9\u30a4\u30c0\u30fc ---\r\n    var cRow = createSliderRow('\u30b3\u30f3\u30c8\u30e9\u30b9\u30c8', 100, 50, 200, 100, function(val) {\r\n      currentContrast = val \/ 100;\r\n      updatePreview();\r\n    });\r\n    card.appendChild(cRow.row);\r\n\r\n    \/\/ --- \u8272\u8abf\uff08Hue\uff09\u30b9\u30e9\u30a4\u30c0\u30fc ---\r\n    var hRow = createSliderRow('\u8272\u8abf', 0, -180, 180, 0, function(val) {\r\n      currentHue = val;\r\n      updatePreview();\r\n    });\r\n    card.appendChild(hRow.row);\r\n\r\n    \/\/ --- \u5f69\u5ea6\u30b9\u30e9\u30a4\u30c0\u30fc ---\r\n    var sRow = createSliderRow('\u5f69\u5ea6', 100, 0, 200, 100, function(val) {\r\n      currentSaturation = val \/ 100;\r\n      updatePreview();\r\n    });\r\n    card.appendChild(sRow.row);\r\n\r\n    \/\/ --- \u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\u30c1\u30a7\u30c3\u30af\u30dc\u30c3\u30af\u30b9 + \u30ea\u30bb\u30c3\u30c8 ---\r\n    const optionRow = document.createElement('div');\r\n    optionRow.style.cssText = 'display:flex;align-items:center;justify-content:space-between;margin-top:6px;font-size:12px;color:#666;';\r\n\r\n    const autoToneLabel = document.createElement('label');\r\n    autoToneLabel.style.cssText = 'display:flex;align-items:center;gap:4px;cursor:pointer;';\r\n    const autoToneCheck = document.createElement('input');\r\n    autoToneCheck.type = 'checkbox';\r\n    autoToneCheck.style.cssText = 'margin:0;';\r\n    autoToneLabel.appendChild(autoToneCheck);\r\n    const autoToneText = document.createElement('span');\r\n    autoToneText.textContent = '\u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63';\r\n    autoToneLabel.appendChild(autoToneText);\r\n    optionRow.appendChild(autoToneLabel);\r\n\r\n    const resetBtn = document.createElement('a');\r\n    resetBtn.textContent = '\u30ea\u30bb\u30c3\u30c8';\r\n    resetBtn.href = 'javascript:void(0);';\r\n    resetBtn.style.cssText = 'font-size:11px;color:#999;text-decoration:underline;';\r\n    optionRow.appendChild(resetBtn);\r\n\r\n    card.appendChild(optionRow);\r\n    previewList.appendChild(card);\r\n\r\n    \/\/ \u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\u30c1\u30a7\u30c3\u30af\u30dc\u30c3\u30af\u30b9\r\n    autoToneCheck.addEventListener('change', function() {\r\n      autoToneLevels = this.checked ? toneLevels : null;\r\n      updatePreview();\r\n    });\r\n\r\n    \/\/ \u30ea\u30bb\u30c3\u30c8\u30dc\u30bf\u30f3\r\n    resetBtn.addEventListener('click', function() {\r\n      bRow.reset(); cRow.reset(); hRow.reset(); sRow.reset();\r\n      autoToneCheck.checked = false;\r\n      currentBrightness = 1.0; currentHue = 0; currentSaturation = 1.0; currentContrast = 1.0;\r\n      autoToneLevels = null;\r\n      updatePreview();\r\n    });\r\n\r\n    \/\/ \u521d\u56de\u63cf\u753b\r\n    drawCanvas(canvas, img, 1.0, 0, 1.0, 1.0, null);\r\n  }\r\n\r\n  \/\/ \u30b9\u30e9\u30a4\u30c0\u30fc\u884c\u3092\u751f\u6210\u3059\u308b\u30d8\u30eb\u30d1\u30fc\r\n  function createSliderRow(labelText, initialDisplay, min, max, initialValue, onChange) {\r\n    const row = document.createElement('div');\r\n    row.style.cssText = 'display:flex;align-items:center;gap:6px;margin-top:4px;font-size:12px;color:#666;';\r\n\r\n    const label = document.createElement('span');\r\n    label.textContent = labelText + ':';\r\n    label.style.cssText = 'min-width:5em;';\r\n    row.appendChild(label);\r\n\r\n    const display = document.createElement('b');\r\n    display.textContent = initialDisplay;\r\n    display.style.cssText = 'min-width:2.5em;text-align:right;';\r\n    row.appendChild(display);\r\n\r\n    const slider = document.createElement('input');\r\n    slider.type = 'range';\r\n    slider.min = min;\r\n    slider.max = max;\r\n    slider.value = initialValue;\r\n    slider.style.cssText = 'flex:1;';\r\n    row.appendChild(slider);\r\n\r\n    slider.addEventListener('input', function() {\r\n      display.textContent = this.value;\r\n      onChange(parseFloat(this.value));\r\n    });\r\n\r\n    return {\r\n      row: row,\r\n      reset: function() {\r\n        slider.value = initialValue;\r\n        display.textContent = initialDisplay;\r\n      }\r\n    };\r\n  }\r\n\r\n  function drawCanvas(canvas, img, brightnessMultiplier, hueDeg, saturateMultiplier, contrastMultiplier, autoToneLevels) {\r\n    const maxW = 500;\r\n    const scale = Math.min(1, maxW \/ img.naturalWidth);\r\n    const w = Math.round(img.naturalWidth * scale);\r\n    const h = Math.round(img.naturalHeight * scale);\r\n    canvas.width = w;\r\n    canvas.height = h;\r\n    const ctx = canvas.getContext('2d');\r\n\r\n    \/\/ \u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\u304cON\u306e\u5834\u5408\uff1a\u307e\u305a\u5143\u753b\u50cf\u3092\u63cf\u753b \u2192 \u30d4\u30af\u30bb\u30eb\u64cd\u4f5c \u2192 CSS filter\u3092\u91cd\u306d\u304c\u3051\r\n    if (autoToneLevels) {\r\n      \/\/ 1. \u5143\u753b\u50cf\u3092\u63cf\u753b\r\n      ctx.drawImage(img, 0, 0, w, h);\r\n      \/\/ 2. \u30d4\u30af\u30bb\u30eb\u64cd\u4f5c\u3067\u30c8\u30fc\u30f3\u88dc\u6b63\r\n      applyAutoTone(ctx, w, h, autoToneLevels);\r\n      \/\/ 3. \u88dc\u6b63\u6e08\u307f\u753b\u50cf\u3092temp\u306b\u4fdd\u5b58\u3057\u3001CSS filter\u3067\u4e0a\u66f8\u304d\r\n      var tempCanvas = document.createElement('canvas');\r\n      tempCanvas.width = w; tempCanvas.height = h;\r\n      tempCanvas.getContext('2d').drawImage(canvas, 0, 0);\r\n      ctx.clearRect(0, 0, w, h);\r\n      ctx.filter = 'brightness(' + brightnessMultiplier + ') contrast(' + contrastMultiplier + ') hue-rotate(' + hueDeg + 'deg) saturate(' + saturateMultiplier + ')';\r\n      ctx.drawImage(tempCanvas, 0, 0);\r\n      ctx.filter = 'none';\r\n    } else {\r\n      ctx.filter = 'brightness(' + brightnessMultiplier + ') contrast(' + contrastMultiplier + ') hue-rotate(' + hueDeg + 'deg) saturate(' + saturateMultiplier + ')';\r\n      ctx.drawImage(img, 0, 0, w, h);\r\n      ctx.filter = 'none';\r\n    }\r\n  }\r\n\r\n\r\n  \/\/ ====================================\r\n  \/\/ \u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\r\n  \/\/ ====================================\r\n\r\n  \/\/ \u753b\u50cf\u306e\u30d2\u30b9\u30c8\u30b0\u30e9\u30e0\u304b\u3089\u88dc\u6b63\u30ec\u30d9\u30eb\u5024\u3092\u4e8b\u524d\u8a08\u7b97\r\n  function calculateAutoToneLevels(img) {\r\n    const canvas = document.createElement('canvas');\r\n    const sampleSize = 300;\r\n    const scale = Math.min(1, sampleSize \/ Math.max(img.naturalWidth, img.naturalHeight));\r\n    canvas.width = Math.round(img.naturalWidth * scale);\r\n    canvas.height = Math.round(img.naturalHeight * scale);\r\n    const ctx = canvas.getContext('2d');\r\n    ctx.drawImage(img, 0, 0, canvas.width, canvas.height);\r\n    const data = ctx.getImageData(0, 0, canvas.width, canvas.height).data;\r\n    const pixelCount = data.length \/ 4;\r\n\r\n    \/\/ R, G, B \u5404\u30c1\u30e3\u30f3\u30cd\u30eb\u306e\u30d2\u30b9\u30c8\u30b0\u30e9\u30e0\r\n    var histR = new Array(256).fill(0);\r\n    var histG = new Array(256).fill(0);\r\n    var histB = new Array(256).fill(0);\r\n\r\n    for (var i = 0; i < data.length; i += 4) {\r\n      histR[data[i]]++;\r\n      histG[data[i + 1]]++;\r\n      histB[data[i + 2]]++;\r\n    }\r\n\r\n    \/\/ \u4e0a\u4e0b0.5%\u3092\u30af\u30ea\u30c3\u30d7\u3057\u3066\u6700\u6697\u30fb\u6700\u660e\u3092\u6c7a\u5b9a\r\n    var clipRatio = 0.005;\r\n    var clipCount = Math.floor(pixelCount * clipRatio);\r\n\r\n    function findLevels(hist) {\r\n      var low = 0, high = 255;\r\n      var sum = 0;\r\n      for (var v = 0; v < 256; v++) { sum += hist[v]; if (sum > clipCount) { low = v; break; } }\r\n      sum = 0;\r\n      for (var v = 255; v >= 0; v--) { sum += hist[v]; if (sum > clipCount) { high = v; break; } }\r\n      if (high <= low) high = low + 1;\r\n      return { low: low, high: high };\r\n    }\r\n\r\n    return {\r\n      r: findLevels(histR),\r\n      g: findLevels(histG),\r\n      b: findLevels(histB)\r\n    };\r\n  }\r\n\r\n  \/\/ \u30d4\u30af\u30bb\u30eb\u64cd\u4f5c\u3067\u30c8\u30fc\u30f3\u88dc\u6b63\u3092\u9069\u7528\r\n  function applyAutoTone(ctx, w, h, levels) {\r\n    var imageData = ctx.getImageData(0, 0, w, h);\r\n    var data = imageData.data;\r\n\r\n    \/\/ \u5404\u30c1\u30e3\u30f3\u30cd\u30eb\u306e\u30eb\u30c3\u30af\u30a2\u30c3\u30d7\u30c6\u30fc\u30d6\u30eb\u3092\u4f5c\u6210\r\n    var lutR = buildLUT(levels.r.low, levels.r.high);\r\n    var lutG = buildLUT(levels.g.low, levels.g.high);\r\n    var lutB = buildLUT(levels.b.low, levels.b.high);\r\n\r\n    for (var i = 0; i < data.length; i += 4) {\r\n      data[i]     = lutR[data[i]];\r\n      data[i + 1] = lutG[data[i + 1]];\r\n      data[i + 2] = lutB[data[i + 2]];\r\n    }\r\n\r\n    ctx.putImageData(imageData, 0, 0);\r\n  }\r\n\r\n  function buildLUT(low, high) {\r\n    var lut = new Uint8Array(256);\r\n    var range = high - low;\r\n    for (var i = 0; i < 256; i++) {\r\n      lut[i] = Math.max(0, Math.min(255, Math.round((i - low) \/ range * 255)));\r\n    }\r\n    return lut;\r\n  }\r\n\r\n\r\n  \/\/ ====================================\r\n  \/\/ \u660e\u5ea6\u8a08\u7b97\r\n  \/\/ ====================================\r\n\r\n  function calculateBrightness(img) {\r\n    const canvas = document.createElement('canvas');\r\n    const sampleSize = 200;\r\n    const scale = Math.min(1, sampleSize \/ Math.max(img.naturalWidth, img.naturalHeight));\r\n    canvas.width = Math.round(img.naturalWidth * scale);\r\n    canvas.height = Math.round(img.naturalHeight * scale);\r\n    const ctx = canvas.getContext('2d');\r\n    ctx.drawImage(img, 0, 0, canvas.width, canvas.height);\r\n    const data = ctx.getImageData(0, 0, canvas.width, canvas.height).data;\r\n    let total = 0;\r\n    const pixelCount = data.length \/ 4;\r\n    for (let i = 0; i < data.length; i += 4) {\r\n      total += data[i] * 0.2126 + data[i+1] * 0.7152 + data[i+2] * 0.0722;\r\n    }\r\n    return total \/ pixelCount;\r\n  }\r\n\r\n\r\n  \/\/ ====================================\r\n  \/\/ \u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u5b9f\u884c\r\n  \/\/ ====================================\r\n\r\n  window._imageExtApp = {\r\n    doDownload: function() {\r\n      const valid = storedImages.filter(function(s) { return s !== null; });\r\n      if (valid.length === 0) { alert('\u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u3092\u30c9\u30ed\u30c3\u30d7\u3057\u3066\u304f\u3060\u3055\u3044\u3002'); return; }\r\n\r\n      const formats = [];\r\n      if (document.getElementById('convertToJpg').checked) formats.push('jpg');\r\n      if (document.getElementById('convertToPng').checked) formats.push('png');\r\n      if (document.getElementById('convertToWebp').checked) formats.push('webp');\r\n      if (formats.length === 0) { alert('\u5909\u63db\u5148\u30d5\u30a9\u30fc\u30de\u30c3\u30c8\u30921\u3064\u4ee5\u4e0a\u9078\u629e\u3057\u3066\u304f\u3060\u3055\u3044\u3002'); return; }\r\n\r\n      const quality = parseFloat(document.getElementById('qualitySelect').value);\r\n      const jpgBgColor = document.getElementById('jpgBgColor').value;\r\n\r\n      \/\/ \u30bf\u30b9\u30af\u4f5c\u6210\r\n      const tasks = [];\r\n      storedImages.forEach(function(item) {\r\n        if (!item) return;\r\n        const ext = getExtension(item.file.name);\r\n        const hasChange = item.brightnessMultiplier !== 1.0 || item.hue !== 0 || item.saturation !== 1.0 || item.contrast !== 1.0 || item.autoToneLevels !== null;\r\n        formats.forEach(function(format) {\r\n          if (isSameFormat(ext, format) && !hasChange) return;\r\n          tasks.push({ file: item.file, format: format, brightnessMultiplier: item.brightnessMultiplier, hue: item.hue, saturation: item.saturation, contrast: item.contrast, autoToneLevels: item.autoToneLevels });\r\n        });\r\n      });\r\n\r\n      if (tasks.length === 0) { showMessage('\u5909\u63db\u5bfe\u8c61\u304c\u3042\u308a\u307e\u305b\u3093\u3002', true); return; }\r\n\r\n      processingList.innerHTML = '';\r\n      let completed = 0, errors = 0;\r\n      const downloadQueue = [], fileItems = [];\r\n\r\n      tasks.forEach(function(task, index) {\r\n        const adjustInfo = [];\r\n        if (task.brightnessMultiplier !== 1) adjustInfo.push('B\u00d7' + task.brightnessMultiplier.toFixed(2));\r\n        if (task.contrast !== 1) adjustInfo.push('C\u00d7' + task.contrast.toFixed(2));\r\n        if (task.hue !== 0) adjustInfo.push('H' + (task.hue > 0 ? '+' : '') + task.hue + '\u00b0');\r\n        if (task.saturation !== 1) adjustInfo.push('S\u00d7' + task.saturation.toFixed(2));\r\n        if (task.autoToneLevels) adjustInfo.push('AutoTone');\r\n        const label = task.file.name + ' \u2192 ' + task.format.toUpperCase() +\r\n          (adjustInfo.length > 0 ? ' (' + adjustInfo.join(' ') + ')' : '');\r\n        fileItems[index] = addFileItem(label, 'processing');\r\n\r\n        convertImageWithHSL(task.file, task.format, quality, jpgBgColor, task.brightnessMultiplier, task.hue, task.saturation, task.contrast, task.autoToneLevels)\r\n          .then(function(result) {\r\n            downloadQueue[index] = result;\r\n            updateFileItem(fileItems[index], 'completed', formatFileSize(result.blob.size));\r\n            completed++; checkDone();\r\n          }).catch(function(err) {\r\n            console.error('\u5909\u63db\u30a8\u30e9\u30fc:', err);\r\n            downloadQueue[index] = null;\r\n            updateFileItem(fileItems[index], 'error', '');\r\n            errors++; checkDone();\r\n          });\r\n      });\r\n\r\n      function checkDone() {\r\n        if (completed + errors !== tasks.length) return;\r\n        var validItems = downloadQueue.filter(function(item) { return item !== null; });\r\n        sequentialDownload(validItems, 0, function() {\r\n          showMessage(completed + '\u500b\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u5909\u63db\u3057\u307e\u3057\u305f' + (errors > 0 ? '\uff08' + errors + '\u500b\u30a8\u30e9\u30fc\uff09' : ''), errors === 0);\r\n        });\r\n      }\r\n    }\r\n  };\r\n\r\n\r\n  \/\/ ====================================\r\n  \/\/ \u753b\u50cf\u5909\u63db\uff08HSL\u8abf\u6574\u4ed8\u304d\uff09\r\n  \/\/ ====================================\r\n\r\n  function convertImageWithHSL(file, format, quality, jpgBgColor, brightnessMultiplier, hue, saturation, contrast, autoToneLevels) {\r\n    return new Promise(function(resolve, reject) {\r\n      loadImageFromFile(file).then(function(img) {\r\n        const canvas = document.createElement('canvas');\r\n        canvas.width = img.naturalWidth;\r\n        canvas.height = img.naturalHeight;\r\n        const ctx = canvas.getContext('2d');\r\n        if (format === 'jpg') { ctx.fillStyle = jpgBgColor; ctx.fillRect(0, 0, canvas.width, canvas.height); }\r\n\r\n        var filterStr = 'brightness(' + brightnessMultiplier + ') contrast(' + contrast + ') hue-rotate(' + hue + 'deg) saturate(' + saturation + ')';\r\n\r\n        if (autoToneLevels) {\r\n          \/\/ \u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\uff1a\u307e\u305a\u5143\u753b\u50cf\u63cf\u753b \u2192 \u30d4\u30af\u30bb\u30eb\u64cd\u4f5c \u2192 CSS filter\u91cd\u306d\u304c\u3051\r\n          ctx.drawImage(img, 0, 0);\r\n          applyAutoTone(ctx, canvas.width, canvas.height, autoToneLevels);\r\n          var tempCanvas = document.createElement('canvas');\r\n          tempCanvas.width = canvas.width; tempCanvas.height = canvas.height;\r\n          tempCanvas.getContext('2d').drawImage(canvas, 0, 0);\r\n          ctx.clearRect(0, 0, canvas.width, canvas.height);\r\n          if (format === 'jpg') { ctx.fillStyle = jpgBgColor; ctx.fillRect(0, 0, canvas.width, canvas.height); }\r\n          ctx.filter = filterStr;\r\n          ctx.drawImage(tempCanvas, 0, 0);\r\n        } else {\r\n          ctx.filter = filterStr;\r\n          ctx.drawImage(img, 0, 0);\r\n        }\r\n        ctx.filter = 'none';\r\n\r\n        const mimeType = getMimeType(format);\r\n        const baseName = file.name.replace(\/\\.[^.]+$\/, '');\r\n        const filename = baseName + '.' + format;\r\n        const useQuality = (format === 'jpg' || format === 'webp') ? quality : undefined;\r\n        canvas.toBlob(function(blob) {\r\n          blob ? resolve({ blob: blob, filename: filename }) : reject(new Error('toBlob failed'));\r\n        }, mimeType, useQuality);\r\n      }).catch(reject);\r\n    });\r\n  }\r\n\r\n  function loadImageFromFile(file) {\r\n    return new Promise(function(resolve, reject) {\r\n      const reader = new FileReader();\r\n      reader.onload = function(e) {\r\n        const img = new Image();\r\n        img.onload = function() { resolve(img); };\r\n        img.onerror = function() { reject(new Error('\u753b\u50cf\u8aad\u307f\u8fbc\u307f\u5931\u6557')); };\r\n        if (file.type === 'image\/svg+xml') {\r\n          img.src = URL.createObjectURL(new Blob([e.target.result], { type: 'image\/svg+xml' }));\r\n        } else { img.src = e.target.result; }\r\n      };\r\n      reader.onerror = function() { reject(new Error('\u30d5\u30a1\u30a4\u30eb\u8aad\u307f\u8fbc\u307f\u5931\u6557')); };\r\n      file.type === 'image\/svg+xml' ? reader.readAsText(file) : reader.readAsDataURL(file);\r\n    });\r\n  }\r\n\r\n  function sequentialDownload(items, index, callback) {\r\n    if (index >= items.length) { if (callback) callback(); return; }\r\n    downloadBlob(items[index].blob, items[index].filename);\r\n    setTimeout(function() { sequentialDownload(items, index + 1, callback); }, 300);\r\n  }\r\n\r\n  \/\/ \u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\r\n  function isImageFile(f) { return \/^image\\\/(jpeg|png|webp|svg\\+xml)$\/.test(f.type) || \/\\.(jpe?g|png|webp|svg)$\/i.test(f.name); }\r\n  function getExtension(fn) { return fn.replace(\/.*\\.\/, '').toLowerCase(); }\r\n  function isSameFormat(ext, fmt) {\r\n    if (fmt==='jpg'&&(ext==='jpg'||ext==='jpeg')) return true;\r\n    if (fmt==='png'&&ext==='png') return true;\r\n    if (fmt==='webp'&&ext==='webp') return true;\r\n    return false;\r\n  }\r\n  function getMimeType(fmt) { return fmt==='jpg'?'image\/jpeg':fmt==='webp'?'image\/webp':'image\/png'; }\r\n  function formatFileSize(b) { return b<1024?b+' B':b<1048576?(b\/1024).toFixed(1)+' KB':(b\/1048576).toFixed(1)+' MB'; }\r\n\r\n  \/\/ UI\r\n  function addFileItem(name) {\r\n    const el = document.createElement('div');\r\n    el.style.cssText = 'padding:6px 12px;border-bottom:1px solid #ecf0f1;display:flex;align-items:center;justify-content:space-between;font-size:13px;';\r\n    el.innerHTML = '<span style=\"font-weight:500;color:#333;word-break:break-all;\">' + escapeHtml(name) + '<\/span><span class=\"file-status\" style=\"white-space:nowrap;margin-left:8px;\">\ud83d\udd52<\/span>';\r\n    processingList.appendChild(el);\r\n    return el;\r\n  }\r\n  function updateFileItem(el, status, info) {\r\n    const s = el.querySelector('.file-status');\r\n    s.innerHTML = status==='completed' ? '<span style=\"color:#27ae60;\">\u2705 '+info+'<\/span>' : '<span style=\"color:#e74c3c;\">\u274c \u30a8\u30e9\u30fc<\/span>';\r\n  }\r\n  function escapeHtml(s) { return s.replace(\/&\/g,'&amp;').replace(\/<\/g,'&lt;').replace(\/>\/g,'&gt;').replace(\/\"\/g,'&quot;'); }\r\n  function downloadBlob(blob, fn) { const u=URL.createObjectURL(blob),a=document.createElement('a');a.href=u;a.download=fn;document.body.appendChild(a);a.click();document.body.removeChild(a);URL.revokeObjectURL(u); }\r\n  function showMessage(msg, ok) {\r\n    if (!encodedMessage) return;\r\n    encodedMessage.innerHTML = '<p class=\"alert is-ghosted '+(ok?'is-primary':'is-error')+' mt-0.5r\"><i class=\"icon mas '+(ok?'ma-check_circle':'ma-error')+' c-'+(ok?'primary':'error')+' mr-0.5r\"><\/i><span>'+msg+'<\/span><\/p>';\r\n    setTimeout(function(){encodedMessage.innerHTML='';},3000);\r\n  }\r\n});\r\n<\/script>","protected":false},"excerpt":{"rendered":"\u8907\u6570\u306e\u753b\u50cf\u30d5\u30a1\u30a4\u30eb\u3092\u30c9\u30e9\u30c3\u30b0&#038;\u30c9\u30ed\u30c3\u30d7\u3059\u308b\u3060\u3051\u3067\u3001\u660e\u5ea6\u30fb\u30b3\u30f3\u30c8\u30e9\u30b9\u30c8\u30fb\u8272\u8abf\u30fb\u5f69\u5ea6\u3092\u500b\u5225\u306b\u30d7\u30ec\u30d3\u30e5\u30fc\u8abf\u6574\u3002\u81ea\u52d5\u30c8\u30fc\u30f3\u88dc\u6b63\u306b\u3082\u5bfe\u5fdc\u3002JPG \/ PNG \/ WebP \u5f62\u5f0f\u3067\u4e00\u62ec\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3002","protected":false},"author":1,"featured_media":12204,"parent":173,"menu_order":9,"comment_status":"closed","ping_status":"closed","template":"templates\/page-converter.php","meta":{"sns_share_botton_hide":"","vkExUnit_sns_title":"","_vk_print_noindex":"","_exclude_from_list_pages":"","footnotes":"","vk-ltc-link":"","vk-ltc-target":"0"},"categories":[21,958],"tags":[],"class_list":["post-12198","page","type-page","status-publish","has-post-thumbnail","category-tool","category-mediaedit"],"veu_head_title_object":{"title":"","add_site_title":""},"_links":{"self":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/pages\/12198","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/pages"}],"about":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/comments?post=12198"}],"version-history":[{"count":5,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/pages\/12198\/revisions"}],"predecessor-version":[{"id":12205,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/pages\/12198\/revisions\/12205"}],"up":[{"embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/pages\/173"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/media\/12204"}],"wp:attachment":[{"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/media?parent=12198"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/categories?post=12198"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/code-plus.jp\/gp\/wp-json\/wp\/v2\/tags?post=12198"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}