Mencipta Warna Bertentangan Warna Yang Diberi
Dalam masalah ini, matlamatnya adalah untuk menghasilkan warna yang bertentangan dengan warna yang diberikan warna. Warna bertentangan merujuk kepada aspek gelap/terang. Sebagai contoh, jika warna yang diberikan adalah hitam, warna bertentangan akan menjadi putih.
Untuk mencipta warna bertentangan ini, fungsi bernama create_opp_color() diperlukan. Fungsi ini harus menerima warna semasa sebagai hujah dan mengembalikan warna yang bertentangan. Begini cara untuk mendekati tugasan ini:
Pelaksanaan Fungsi:
Pelaksanaan dalam JavaScript:
function create_opp_color(currentColor) { if (currentColor.indexOf('#') === 0) { currentColor = currentColor.slice(1); } if (currentColor.length === 3) { currentColor = currentColor.repeat(2); } const rgb = hexToRgb(currentColor); const invertedRgb = { r: 255 - rgb.r, g: 255 - rgb.g, b: 255 - rgb.b }; const invertedHex = rgbToHex(invertedRgb); return '#' + invertedHex; } function rgbToHex(rgb) { let hex = ''; for (const key in rgb) { if (rgb.hasOwnProperty(key)) { const component = rgb[key].toString(16); hex += component.length === 1 ? '0' + component : component; } } return hex; } function hexToRgb(hex) { let rgb = {}; ['r', 'g', 'b'].forEach((key, i) => { rgb[key] = parseInt(hex.substr(i * 2, 2), 16); }); return rgb; }
Teknik Lanjutan:
Jika anda memerlukan lebih kontras, anda boleh menggunakan hitam atau putih sebagai warna bertentangan berdasarkan kecerahan warna asal. Berikut ialah fungsi yang diubah suai untuk melakukannya:
function create_opp_color(currentColor) { if (currentColor.indexOf('#') === 0) { currentColor = currentColor.slice(1); } if (currentColor.length === 3) { currentColor = currentColor.repeat(2); } const rgb = hexToRgb(currentColor); const brightness = Math.round((rgb.r * 0.299 + rgb.g * 0.587 + rgb.b * 0.114) / 255 * 100); return brightness > 50 ? '#000000' : '#FFFFFF'; }
Kini, menggunakan fungsi ini, anda boleh menjana warna bertentangan dengan mana-mana warna tertentu, sama ada cerah atau gelap.
Atas ialah kandungan terperinci Bagaimana Menjana Warna Bertentangan Warna Yang Diberikan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!