Görsel Algı ve Estetik

Gölgeler (Ana Konu Giriş)

Gölge, dijital arayüzlerde yalnızca bir efekt değil; derinlik, hiyerarşi ve odak oluşturan görünmez bir tasarım dilidir.
Gerçek dünyadaki ışık algısını dijital ortama taşıyarak, öğelere fiziksel bir varlık hissi kazandırır ve kullanıcıya hangi elementin daha önemli olduğunu sezgisel olarak gösterir.

Ana Konu Felsefi ve Tarihsel Açıklama
Seviye 5

Görsel Algı ve Estetik Gölge (Shadow): Dijital Derinliğin Dili

Giriş - Genel Bakış

Akademik ve fiziksel temellerini incelediğimiz gölge kavramı, tarayıcı dünyasında somut birer CSS özelliğine dönüşür.

Ancak burada geliştiricinin integral hesapları yapmasına, ışık açısını iletkiyle ölçmesine veya Gaussian matrislerini elle kurmasına gerek yoktur.

CSS, bu karmaşık "Render Motoru" süreçlerini mükemmel bir şekilde soyutlayarak, bize insan tarafından okunabilir ve yönetilebilir basit bir kontrol paneli sunar.

Bu panelin bize sunduğu iki temel araç; box-shadow ve text-shadow özellikleridir.

Mühendislikten Sanata Dönüşüm

Bu özellikler, arka planda çalışan o ağır matematiksel yükü ( Konvolüsyon hesaplarını, piksel interpolasyonlarını ve

sigma dağılımlarını) geliştiriciden gizler.

Siz sadece "Bulanıklığı 10 piksel yap" dersiniz; tarayıcı ise bu emri alır, fizik motorunu çalıştırır ve o 10 piksellik yarıçap için gereken milyonlarca matematiksel işlemi saniyenin altmışta birinde tamamlar.

Dolayısıyla bu CSS özellikleri, teknik parametrelerden ziyade, ışığı ve atmosferi yönetmenizi sağlayan birer "Sanatsal Arayüz"dür.

İki Farklı Yüzey, Aynı Fizik: Kutu ve Glif Ayrımı

Web tasarımında gölge mekaniği, ışık kaynağının kuralları değişmese de, ışığın etkileşime girdiği yüzeyin geometrisine göre iki ana disipline ayrılır.

Tarayıcı motoru, ışığı hesaplarken "Neyi gölgelendiriyorum?" sorusuna verdiği cevaba göre iki farklı render yolunu izler: Yapısal ve Tipografik.

Her iki özellik de (box-shadow ve text-shadow) arka planda aynı optik yasaları, aynı Gaussian bulanıklığını ve aynı koordinat sistemini kullanır.

Ancak gölgenin "kaynağı" olan nesnelerin fiziksel yapısı farklı olduğu için, bu araçların kullanım amaçları ve sundukları parametreler (örneğin yayılma yeteneği) stratejik farklılıklar gösterir.

Yapısal Gölgeler (Kutu Modeli) Arayüzün Mimarisi ve İskeleti Bu disiplin, web sayfasının yapıtaşlarını oluşturan blok düzeyindeki öğeleri (div, section, article, button) kapsar.

CSS'in temel yerleşim mantığı olan "Box Model" üzerine kuruludur.

Geometrik Referans: Tarayıcı, öğenin içeriği ne olursa olsun, onun etrafını saran görünmez dikdörtgen sınırları veya border-radius ile bükülmüş sınırları referans alır.

Tasarım Amacı: Yapısal gölgelerin temel amacı "Hacim" ve "İrtifa" yaratmaktır.

Bir kartın zeminden ne kadar yukarıda durduğunu, bir menünün diğer içeriklerin üzerine nasıl bindiğini belirler.

Bu, arayüzün 3 boyutlu haritasını (Z-eksenini) kullanıcıya hissettiren mimari gölgelendirmedir.

Tipografik Gölgeler (Glif Modeli) İletişimin Vurgusu ve Doku Bu disiplin, arayüzün iskeletiyle değil, sesiyle ilgilidir.

Metinleri oluşturan her bir harf (karakter), bilgisayar dilinde "Glif" olarak adlandırılan karmaşık vektörel çizimlerdir.

Geometrik Referans: text-shadow, kutunun dikdörtgen yapısını tamamen görmezden gelir.

Bunun yerine, "A", "S" veya "&" gibi karakterlerin kıvrımlarını, vektörel hatlarını ve boşluklarını takip eder.

Gölge, harfin şekli neyse onu birebir kopyalar.

Tasarım Amacı: Tipografik gölgelerin amacı genellikle nesneyi "havada uçurmak" değildir ( çünkü havada uçan yazılar okumayı zorlaştırır ).

Bunun yerine amaç; metne kontrast (okunabilirlik), doku (kabartma/oyma efekti) veya atmosfer

(neon/parlama efekti) katmaktır.

Kutu gölgesi "mekanı" tanımlarken, metin gölgesi "karakteri" tanımlar.

Box-shadow (Kutu Gölgelendirme) Sanal Katman Mimarisi ve Işık Yönetimi

Giriş - Genel Bakış

CSS'in box-shadow özelliği, web tasarımındaki "Flat" yüzeyleri üç boyutlu bir sahneye dönüştüren birincil araçtır.

HTML'deki tüm blok düzeyindeki öğelerin (div, section, button, card) etrafını saran görünmez sınırlara, yani "Kutu Modeli"ne gölge ekler.

Bu özellik, teknik olarak basit bir boyama işleminden fazlasıdır; tarayıcının render motorunda gerçekleşen bir "Siluet Çoğaltma ve İstifleme" operasyonudur.

Tarayıcı, box-shadow komutunu aldığında, ilgili HTML öğesinin tam boyutlarında ve şeklinde sanal bir kopya oluşturur.

Bu kopyayı belirlediğiniz renge boyar, bulanıklaştırır ve Z-ekseninde ana öğenin arkasına yerleştirir.

Dolayısıyla kullanıcı gölgeyi gördüğünde, aslında öğenin arkasına gizlenmiş ve şekli bozulmuş o "hayalet kopyayı" görmektedir.

Çoklu Işık Kaynağı Simülasyonu (Multiple Shadows)

box-shadow'un en güçlü ve akademik tarafı, tek bir öğeye virgülle ayrılarak birden fazla gölge atanabilmesidir.

Fiziksel dünyada bir nesneye farklı açılardan vuran birden fazla ışık kaynağı olabilir.

CSS, bu karmaşık aydınlatma senaryosunu taklit etmenize olanak tanır.

Profesyonel tasarımcılar genellikle tek bir kaba gölge yerine; biri keskin ve yakın ( Ambient Occlusion ), diğeri yumuşak ve uzak ( Key Light ) olmak üzere iki veya üç katmanlı gölge kombinasyonları kullanarak, yapaylıktan uzak, ultra-gerçekçi derinlik haritaları oluştururlar.

Offset-x ve Offset-y Konum, Vektör ve Işık Kaynağı

Giriş - Genel Bakış

Bu iki parametre, CSS gölgelendirmesinin omurgasını oluşturan ve gölgenin cisimden ne kadar uzağa "öteleneceğini" belirleyen kartezyen koordinat değerleridir.

Teknik olarak tarayıcıya, oluşturduğu siyah kopya katmanını X (yatay) ve Y (dikey) ekseninde kaç piksel kaydırması gerektiğini söylerler.

Ancak tasarım dilinde bu değerler, bir piksel hareketinden çok daha fazlasını; "Sanal Işık Kaynağı"nın konumunu temsil eder.

Beynin Ters Mühendisliği ve Işık Yönü

İnsan beyni görsel veriyi işlerken, gölgenin düştüğü yönün tam tersinde bir ışık kaynağı olduğunu varsayar.

Bu, "Vektörel İzdüşüm" mantığıdır.

Küresel Aydınlatma: Web tasarımında en yaygın ve kabul gören standart, ışığın Sol-Üst köşeden (Saat 10 veya 11 yönünden) geldiği varsayımıdır.

Bu senaryoyu oluşturmak için her iki ofset değerinin de pozitif ( offset-x: 10px , offset-y: 10px ) girilmesi gerekir.

Bu durumda gölge sağ-alt köşeye düşer ve beyin "Güvenli ve Doğal" bir ışıklandırma algılar.

Negatif Değerler: Eğer değerleri negatif girerseniz ( -10px -10px gibi ), gölge sol-üst köşeye düşer.

Bu, ışığın Sağ-Alt köşeden vurduğu anlamına gelir ki bu, doğal dünyada nadir görülen ve genellikle "ürkütücü" veya "hatalı" algılanan bir durumdur.

Mesafe Algısı ve "Elevation" (Yükselti)

Ofset değerlerinin büyüklüğü, cismin zeminden (Z-ekseninde) ne kadar havalandığını belirleyen bir irtifa göstergesidir.

Mikro Ofsetler (1px - 4px): Cisim zemine çok yakındır.

Bu, genellikle tıklanabilir butonlar, kartlar veya giriş alanları ( input ) için kullanılır.

"Ben zemine yapışık değilim, etkileşime girebilirsin" mesajı verir.

Makro Ofsetler (20px+): Ofset değeri arttıkça, gölge cisimden uzaklaşır.

Beyin bunu, cismin zeminden çok yükseğe kalktığı şeklinde yorumlar.

Bu teknik, sayfanın geri kalanının üzerine binen Modal Pencereleri, Açılır Menüler "Sürükle-Bırak" sırasında havaya kaldırılan öğeler için kullanılır. veya

Cisim ne kadar yüksekteyse, kullanıcıya o kadar yakın algılanır.

Blur-radius Bulanıklık, Odak ve Işık Sertliği

Giriş - Genel Bakış

CSS gölgelendirmesinde offset değerleri ışığın nereden geldiğini belirlerken, blur-radius ışığın ne tür bir kaynaktan geldiğini belirler.

Bu parametre, gölge kenarlarındaki piksellerin ne kadar geniş bir alana dağıtılacağını kontrol eder ve fiziksel dünyadaki

"Işık Kaynağı Boyutu"nu simüle eder.

Bir tasarımın "modern" mi yoksa "retro" mu görüneceğine karar veren anahtar genellikle buradadır.

0px: Dijital Keskinlik ve Grafiksel Tavır

Bulanıklık değerinin sıfıra (0px) eşitlendiği durum, gölgenin sınırlarının bıçakla kesilmiş gibi net olduğu andır.

Fiziksel Anlam: Işık kaynağı son derece küçük ve güçlüdür; veya cisim zemine mikroskobik düzeyde yakındır.

Işık kırılması yoktur, sadece "Var" veya "Yok" durumu vardır.

Tasarım Dili: Bu kullanım, gerçekçilikten bilerek uzaklaşılan stillerin imzasıdır.

Neo-Brütalism, Pop-Art, Retro Windows 95 arayüzleri veya çizgi roman estetiği; objeleri birer "etiket" gibi göstermek için sert gölgeleri kullanır.

Bu teknik, kullanıcıya derinlikten ziyade "grafiksel bir katman" hissi verir.

Yüksek Değerler: Atmosferik Yayılım ve Modern Derinlik

Değer artırıldıkça (örneğin 10px, 20px, 50px), gölge kenarları merkezden dışarıya doğru incelerek dağılır ve fiziksel dünyadaki "Yarı Gölge" alanı genişler.

Fiziksel Anlam: Ortamda tek bir sert ampul değil; pencereden giren gün ışığı veya bulutların arkasındaki güneş gibi geniş ve yumuşak bir ışık kaynağı vardır.

Işık, cismin kenarlarından süzülürken havada dağılır.

Tasarım Dili: Google Material Design, Apple Human Interface ve genel olarak modern "Clean UI" anlayışının temeli budur.

Bulanık gölgeler, öğeleri sayfaya sertçe yapıştırmak yerine, onların zeminle yumuşakça kaynaşmasını sağlar.

Bu, arayüzde "lüks" ve "dingin" bir hava yaratır.

Profesyonel İpucu: Mesafe ve Bulanıklık İlişkisi

Fizik kuralları gereği, bir cisim zeminden uzaklaştıkça ( yani offset veya spread ile havaya kaldırıldıkça ), gölgesi daha fazla ışık alır ve bulanıklaşır.

Hatalı Kullanım: Cisim çok havada ( büyük ofset ), ancak gölge çok keskin (küçük blur).

Bu doğal değildir.

Doğru Oran: offset değeri arttıkça, blur-radius değeri de mutlaka artırılmalıdır.

Cisim yükseldikçe gölge silikleşir ve dağılır.

Spread-radius Yayılma: Stratejik Boyutlandırma ve Işık Hacmi

Giriş - Genel Bakış

CSS'te text-shadow özelliğinde bulunmayan, sadece kutu gölgelerine ( box-shadow ) özgü olan bu süper güç; gölgenin fiziksel boyutunu, bulanıklıktan tamamen bağımsız olarak manipüle etmenizi sağlar.

Bulanıklık gölgeyi "dağıtırken", Yayılma gölgeyi "büyütür veya küçültür".

Bu parametre, ışık kaynağının cisme olan mesafesi ve ışığın kırılma fiziği hakkında tarayıcıya çok kritik veriler sunar.

Pozitif Yayılma (+): Genişleme ve Yoğunluk

Eğer spread değerini pozitif girerseniz, tarayıcı gölge katmanını kutunun dört bir yanından dışarıya doğru 5 piksel genişletir.

Fiziksel Anlam: Işık kaynağı cisme çok yakındır ve cisim, ışığın çok büyük bir kısmını bloklamaktadır.

Bu yüzden cismin arkasında kendisinden daha büyük bir karanlık alan oluşur.

Kullanım Alanı: Genellikle "Outline" veya "Border" efekti yaratmak için kullanılır.

Eğer blur-radius: 0 yapıp spread-radius: 2px verirseniz, kutunun etrafında 2 piksellik keskin bir çizgi oluşur.

Bu yöntem, border özelliğinin aksine kutunun boyutunu etkilemediği için buton tasarımlarında sıkça tercih edilir.

Negatif Yayılma (-): Profesyonel Tasarımın Sırrı

spread değerinin negatif girilmesi (-5px), modern arayüz tasarımının en güçlü hilesidir.

Gölge katmanı, kutunun kenarlarından içeriye doğru çekilir ve küçülür.

Fiziksel Anlam (Optik Daralma): Gerçek dünyada bir cisim zeminden havalandığında ( yükseldiğinde ), ışık huzmeleri cismin kenarlarının altına doğru sızmaya başlar.

Işık her taraftan içeri dolduğu için, gölgenin kapladığı alan cismin kendisinden daha küçük görünmeye başlar.

Kullanım Stratejisi (Realistic Elevation): Bir cisim havaya yükseldikçe, gölgesi hem bulanıklaşmalı ( Blur artmalı ) hem de ufalmalıdır (Spread azalmalı).

Formül: Yüksek Bulanıklık + Negatif Yayılma = Uçan Cisim.

Örneğin: offset-y: 20px, blur-radius: 30px ve spread-radius: -10px kombinasyonu; kullanıcının beyninde

"Bu kart masanın üzerinde durmuyor, masanın 10 santim üzerinde havada süzülüyor" algısını yaratır.

Materyal Tasarımın o meşhur "yumuşak ve derin" gölgelerinin arkasındaki matematik budur.

Inset İç Gölge: Fiziksel Tersine Çevirme ve Oyuk Derinliği

Giriş - Genel Bakış

Varsayılan box-shadow davranışı, gölgeyi kutunun arkasına atarak cismi sayfadan yukarıya doğru "kabartır".

Ancak inset anahtar kelimesi eklendiğinde, tarayıcı bu ışık fiziğini tersine çevirir.

Gölge artık kutunun dışına değil, sınırlarından içeriye doğru düşer.

Bu, tasarımda Z-ekseninin yön değiştirdiği andır.

Mekansal Anlam: Negatif Z-Ekseni

Fiziksel dünyada bir yüzeyin üzerine gölge düşmesi için o yüzeyin diğerlerinden daha alçakta olması gerekir.

inset kullanımı, kullanıcıya şu mesajı verir: "Bu alan yüzeyin üzerine konulmadı, yüzeyin içine oyuldu."

Oyuk ve Hazne İllüzyonu: Işık artık cismin arkasına değil, çerçevenin iç kenarlarına vurur.

Bu, cismin yüzeyden yukarıda değil, yüzeyin içinde olduğunu; yani bir havuz, bir kutu içi veya yumuşak bir çöküntü olduğunu gösterir.

Kullanıcıda "içine bir şey koyabilirim" veya "parmağımla bastırdım" hissiyatı yaratır.

Kullanım Alanı ve Tasarım Stratejisi

İç gölgeler, estetikten ziyade işlevsel durumları belirtmek için kullanılır.

Veri Giriş Alanları (Inputs): Form elemanlarında iç gölge kullanımı klasiktir.

Bu, o alanın bir "kap" olduğunu ve kullanıcının oraya bir veri "doldurması" gerektiğini bilinçaltına işler.

Tıklama Geri Bildirimi (:active State): Bir butona tıklandığı o mikrosaniyelik anda box-shadow'u dıştan içe çevirmek, butona fiziksel olarak basıldığı ve düğmenin içeri göçtüğü hissini verir.

Bu, dijital dokunma hissini güçlendiren en etkili yöntemdir.

Neumorphism Akımı: Modern tasarımda "Yumuşak Plastik" dokusu yaratmak için kullanılan bu akım, inset gölgelerin ( oyuklar ) ve normal gölgelerin ( çıkıntılar ) aynı yüzeyde birleştirilmesiyle oluşturulur.

Color Renk: Atmosfer ve Dokusal Bütünleşme

Giriş - Genel Bakış

CSS sözdiziminde genellikle en sona yazılan color parametresi, teknik olarak opsiyonel olsa da , gölgenin gerçekçiliğini belirleyen en kritik unsurdur ( yazılmazsa tarayıcı metin rengini kullanır ).

Çünkü gölge, fiziksel olarak "siyah boya" değildir; ışığın azalması sonucu yüzeyin kararmasıdır.

Bu kararma efektini dijitalde taklit etmek için iki altın kural vardır:

Opaklık Kuralı: "Kirli" Gölgeden Kaçınış

Amatör bir tasarım ile profesyonel bir tasarım arasındaki en belirgin fark, gölge rengi seçimindedir.

Hata: Düz, opak siyah ( #000000 veya black ) kullanmak.

Bu, gölgeyi bir ışık oyunu olmaktan çıkarıp, cismin arkasına yapıştırılmış siyah bir kartona dönüştürür.

Doğru Teknik (Alpha Kanalı): Gölge her zaman yarı saydam olmalıdır.

Bunun için RGBA (rgba(0, 0, 0, 0.15)) veya modern HSLA formatları kullanılır.

Fiziksel Neden: Yarı saydam bir gölge, üzerine düştüğü zeminin rengiyle ve dokusuyla etkileşime girer.

Zemin maviyse gölge koyu maviye, zemin ahşapsa gölge koyu ahşap tonuna dönüşür.

Bu "kaynaşma", gölgenin yapay durmasını engeller.

Renkli Gölgeler: Modern Canlılık ve "Glow" Etkisi

Gerçek dünyada ışık, yüzeylerden sekerken o yüzeyin rengini de taşır.

Modern arayüz tasarımında ( özellikle iOS ve yeni nesil web trendlerinde), gri/siyah gölgeler yerini "Renkli Gölgeler"e bırakmıştır.

Teknik: Mavi bir buton için siyah gölge yerine, o mavinin çok daha koyu, satüre ve yarı saydam bir tonunu ( rgba(0, 50, 200, 0.3) ) kullanmak.

Görsel Etki: Bu teknik, gölgenin "kirli gri" görünmesini engeller.

Bunun yerine cisme hafif bir "Parlama" veya "Neon" etkisi katarak enerjisini yükseltir.

Cisim sadece gölge düşürmez, etrafına kendi ışığını da yayıyormuş gibi görünür.

Box Shadow Parametreleri Hızlı Referans ve Kullanım Örnekleri Tablo Gösterimis
Parametre
Tanım ve İşlevi
Kullanım Örneği
offset-x

Yatay kayma.
Pozitif değer gölgeyi sağa, negatif değer sola kaydırır.

box-shadow: 10px 0 5px rgba(0,0,0,0.3);
offset-y

Dikey kayma.
Pozitif değer gölgeyi aşağı, negatif değer yukarı kaydırır.

box-shadow: 0 10px 5px rgba(0,0,0,0.3);
blur-radius

Gölgenin kenarındaki yumuşaklık ve bulanıklık derecesini belirler.

box-shadow: 0 0 15px rgba(0,0,0,0.3);
spread-radius

Gölgenin boyutunu, kutunun orijinal boyutundan bağımsız olarak genişletir veya daraltır.

box-shadow: 0 0 0 5px rgba(0,0,0,0.3);
color

Gölgenin rengi.
Genellikle RGBA veya HSLA formatında saydamlık ile tanımlanır.

box-shadow: 0 0 10px rgba(255,0,0,0.5);
inset

Gölgeyi kutunun içine yerleştirir ve içeriği çerçeveler.

box-shadow: inset 0 0 10px rgba(0,0,0,0.3);
Akademik Detaylar Etkisi, Uygulanması ve Fiziksel Temeller Tablo Gösterimis
Parametre
Etkisi, Uygulanması ve Akademik Detay
offset-x

Bu değer, ışık kaynağının yatay konumunu tersinden belirler.
\(0\) değeri, ışık kaynağının tam merkezde veya tam üstte olduğunu varsayarak gölgenin yatayda hiç kaymamasını sağlar.

offset-y

Bu değer, ışık kaynağının dikey konumunu tersinden belirler.
Çoğu tasarımda ışık kaynağının yukarıdan geldiği varsayıldığı için, pozitif offset-y daha doğal görünür.

blur-radius

Bulanıklık Yarıçapı: Fizikteki yarı gölge alanını taklit eder.
Değer ne kadar yüksekse, ışık kaynağının o kadar dağınık olduğu varsayılır.
Bu alanın hesaplanması tarayıcı için yüksek performans maliyeti oluşturabilir. \(0\) dışında negatif değer almaz.

spread-radius

Pozitif değer gölgeyi kutunun dışına doğru iter ve büyütür.
Negatif değer gölgeyi küçültür ve kutunun kenarlarına doğru içeri çeker.
Bu, gölgenin sadece bulanıklık ile değil, aynı zamanda boyut ile de kontrol edilmesini sağlar.

color

Çoğu zaman rgba(0, 0, 0, 0.1) gibi saydam değerler tercih edilir.
Bu, gölgenin altındaki arka plan rengini yansıtmasını ve böylece ışık koşullarına bağlı olarak renk değiştiren daha doğal bir efekt elde edilmesini sağlar.

inset

Kutunun içe basılmış, çökertilmiş veya çerçeveli görünmesini sağlar.
Bu, bir düğmeye tıklandığında anlık geri bildirim vermek için :active pseudo sınıfıyla birlikte sıkça kullanılır.

</>
Box-shadow: Yapısal Derinlik ve İrtifa (Elevation) Giriş Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Box-shadow: Yapısal Derinlik ve İrtifa (Elevation) Giriş Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="sahne">
        <div class="kart-yuzey">
            <h3>Modern Kart</h3>
            <p>Hafif ofset ve yüksek bulanıklık ile doğal derinlik.</p>
        </div>
    </div>
</body>

</html>
.sahne {
    padding: 50px;
    background-color: #f5f7fa;
}

.kart-yuzey {
    width: 280px;
    padding: 30px;
    background-color: white;
    border-radius: 20px;
    font-family: sans-serif;
    box-shadow: 0 20px 30px -5px rgba(0, 0, 0, 0.15);
}

.kart-yuzey h3 {
    color: #2c3e50;
    margin-bottom: 10px;    
}

Text-shadow (Metin Gölgelendirme) Tipografik Derinlik, Kontrast ve Okunabilirlik

Giriş - Genel Bakış

Web tasarımında box-shadow sayfanın mimarisini, duvarlarını ve mobilyalarını ( yani kutuları ) inşa ederken; text-shadow o mimarinin içindeki "Sesi" ve "Dokuyu" yönetir.

Bu özellik, ışık simülasyonunu basit geometrik dikdörtgenlere değil; harfleri, sayıları ve sembolleri oluşturan karmaşık vektörel çizimlere, yani teknik adıyla "Gliflere" uygular.

Bir div elementine gölge verdiğinizde, tarayıcının işi kolaydır; çünkü şekil bellidir ( bir dikdörtgen ).

Ancak bir yazıya gölge vermek istediğinizde, tarayıcı bir sanatçı gibi davranmak zorundadır.

text-shadow komutu verildiğinde, tarayıcı yazı tipinin (font-family) tüm kıvrımlarını, serifsiz uçlarını, "O" harfinin içindeki boşluğu veya "g" harfinin kuyruğunu milimetrik olarak analiz eder.

Glif Maskeleme ve Silüet Çıkarma

Bu süreçte tarayıcı, harfin şeklini birebir takip eden sanal bir "Gölge Maskesi" (Shadow Mask) oluşturur.

Bu maske, metnin "Kutu Modelini" (etrafındaki görünmez dikdörtgeni) tamamen görmezden gelir.

Fark: Eğer bir yazıya box-shadow verirseniz, yazının arkasında dikdörtgen bir karartı görürsünüz.

text-shadow: Yazının arkasında, harflerin kendi şeklinden oluşan, bulanıklaştırılmış ve kaydırılmış "hayalet kopyalarını" görürsünüz.

Bu, gölgenin kutunun etrafında değil, harfin arkasında ve içinde oluşmasını sağlar.

Matbu Tasarımdan Dijitale Geçiş

Tarihsel olarak bu özellik, matbaa dünyasındaki "Letterpress" veya sokak tabelalarındaki "Neon" efektlerini web'e taşımak için geliştirilmiştir.

text-shadow olmadan metinler "düz mürekkep" gibi görünürken; bu özellik sayesinde metinler kağıda oyulmuş, metalden kabartılmış veya arkasından ışık vuruyormuş gibi dokusal bir nitelik kazanır.

Bu, kullanıcının metni sadece okumasını değil, onu "hissetmesini" sağlar.

</>
Text-shadow: Tipografik Vurgu ve Neon Etkisi Giriş Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Text-shadow: Tipografik Vurgu ve Neon Etkisi Giriş Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="karanlık-oda">
        <h1 class="neon-metin">CSS4 NEON</h1>
    </div>
</body>

</html>
.karanlık-oda {
    background-color: #0a0a0a;
    padding: 60px;
    text-align: center;
}

.neon-metin {
    color: #fff;
    font-size: 3rem;
    font-family: 'Arial Black', sans-serif;
    text-shadow:
        0 0 10px #00d2ff,
        0 0 20px #00d2ff,
        0 0 40px #3a7bd5;
}

Teknik Kısıtlama: "Yayılma" Yokluğu ve Vektörel Zorluklar

Giriş - Genel Bakış

Web geliştiricileri box-shadow özelliğinden text-shadow özelliğine geçtiklerinde genellikle bir sürprizle karşılaşırlar: Kutu gölgelerinde gölgeyi büyütüp küçültmeye yarayan 4. parametre olan "Spread-radius", metin gölgelerinde çalışmaz.

CSS sözdiziminde bu parametreyi yazsanız bile tarayıcı bunu görmezden gelir veya kodu geçersiz sayar.

Bu bir hata değil, tarayıcı motorlarının performansını korumak için alınmış bilinçli bir mühendislik kararıdır.

Neden Yok? (Dikdörtgen vs. Bezier Eğrileri)

Bu kısıtlamanın nedeni, geometrik şekillerin matematiksel hesaplama maliyetindeki uçurumsal farktır.

Kutuların Basitliği: Bir div veya button matematiksel olarak basit bir dikdörtgendir.

Bir dikdörtgenin gölgesini 5px genişletmek (spread) için tarayıcının yapması gereken tek şey, köşe koordinatlarına basit bir toplama işlemi eklemektir (\(Genislik + 10px\)).

Bu, işlemci için mikrosaniyelik, zahmetsiz bir iştir.

Harflerin Karmaşıklığı: Ancak bir "S", "a" veya "&" karakteri, Bezier Eğrileri ve karmaşık vektör yollarından oluşur.

Bir harfin gölgesini "yaymak" (spread etmek), o harfin dış hatlarına paralel yeni bir kontur çizmeyi gerektirir.

Matematiksel Yük: Tarayıcı, harfin her kıvrımında, her köşesinde ve her deliğinde ("O" harfinin içi) dışa doğru matematiksel bir öteleme hesabı yapmak zorundadır.

Bir sayfadaki binlerce harf için bu hesabı yapmak, tarayıcıyı kilitlenme noktasına getirecek kadar ağır bir "Render Maliyeti" yaratır.

Görsel Bozulma Riski (Artifacts)

Performans sorununa ek olarak, harfleri yazılımsal olarak kalınlaştırmak ( stroke eklemek ) görsel hatalara çok açıktır.

Topoloji Sorunu: Keskin köşeli harflerde ( serifli bir "Times New Roman" fontundaki "M" harfinin uçları ), yayılma işlemi yapıldığında gölge köşeleri orantısız şekilde uzayarak "diken" gibi sivrilebilir veya iç içe geçerek garip geometrik şekiller oluşturabilir.

Bu yüzden tarayıcılar, bu riski almayarak yayılma özelliğini metinlerde devre dışı bırakmıştır.

Tasarım Sonucu ve Alternatif Çözümler

Bu kısıtlama nedeniyle, text-shadow ile gölgenin kapladığı alanı fiziksel olarak büyütemezsiniz; sadece yerini değiştirebilir ( Offset ) veya bulanıklaştırabilirsiniz.

Yanlış Yöntem: Metni "kalınlaştırmak" veya "şişmanlatmak" için gölge kullanmaya çalışmak başarısızlıkla sonuçlanır.

Tipografik Çözüm: Eğer daha kalın bir görüntü istiyorsanız, gölge yerine fontun kendi ağırlığını artırmalısınız (font-weight: bold).

Modern Çözüm: Eğer metnin etrafında renkli bir kontur istiyorsanız, gölge yerine bu iş için özel olarak geliştirilmiş olan

-webkit-text-stroke özelliğini kullanmalısınız.

Gölge Hilesi (Stacking): Eğer mutlaka text-shadow ile kalınlık yaratmanız gerekiyorsa, tasarımcılar "Çoklu Gölge" tekniğini kullanır.

Metnin 4 yönüne ( sağ, sol, yukarı, aşağı ) 1 piksellik sert gölgeler eklenerek ( 1px 0 0 black, -1px 0 0 black... ) yapay bir yayılma efekti simüle edilebilir.

</>
Teknik Kısıtlama: "Yayılma" (Spread) Yokluğu ve Çözümü Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Teknik Kısıtlama: "Yayılma" (Spread) Yokluğu ve Çözümü Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="vektorel-cozum">
        <h1 class="sahte-cerceve">STOK YOK</h1>
    </div>
</body>

</html>
.vektorel-cozum {
    padding: 40px;
    background-color: #f1c40f;
    text-align: center;
}

.sahte-cerceve {
    font-family: 'Arial Black', sans-serif;
    font-size: 4rem;
    color: white;
    text-shadow:
        2px 2px 0px #c0392b,
        -2px 2px 0px #c0392b,
        2px -2px 0px #c0392b,
        -2px -2px 0px #c0392b;
}

Tasarım Stratejisi 1 (Okunabilirlik Sigortası) Değişken Zeminlerde Görünürlük Garantisi

Giriş - Genel Bakış

text-shadow özelliğinin web tasarımındaki en hayati kullanım alanı estetik bir süsleme değil, tamamen fonksiyonel bir zorunluluktur.

Matbu tasarım ( dergi, kitap ) aksine, web tasarımı dinamiktir.

Metinler her zaman düz beyaz bir kağıdın üzerinde durmaz; kullanıcı tarafından yüklenen fotoğrafların, oynatılan videoların veya renk değiştiren videoların veya

renk değiştiren gradyanların üzerine gelir.

"Bukalemun Etkisi" ve Kontrast Sorunu

Dinamik bir arka plan üzerinde (Hero Banner veya Video Arka Planı), piksellerin rengi tahmin edilemez.

Koyu renkli bir orman görseli, bir anda aydınlık bir gökyüzü karesine geçebilir.

Sorun: Eğer metniniz beyazsa, arka planın aydınlık olduğu karelerde metin "kamufle" olur ve arka planla kaynaşır.

Kullanıcının gözü, harflerin sınırlarını ayırt edemez hale gelir.

Bu, erişilebilirlik standartlarında en büyük ihlallerden biridir.

Çözüm: Görünmez Koruma Kalkanı

Bu sorunu çözmek için metnin arkasına opak bir kutu ( background-color ) koymak tasarımı kabalaştırabilir.

Bunun yerine, profesyonel çözüm text-shadow kullanmaktır.

Teknik: Metnin arkasına, X ve Y ekseninde çok az kaydırılmış ( veya hiç kaydırılmamış ), ancak bulanıklık değeri yüksek ve opaklığı düşük bir siyah gölge eklenir.

Örnek Değer: 0 2px 10px rgba(0,0,0,0.6)

Sonuç: Bu gölge, harflerin etrafında hafif, puslu ve koyu bir "hale" oluşturur.

Bu hale, metin ile arka plan görseli arasında yarı saydam bir tampon bölge yaratır.

Arka plan ne kadar beyazlaşırsa beyazlaşsın, metnin arkasındaki o ince karanlık katman, harflerin her zaman "öne çıkmasını" ve okunabilir kalmasını garanti eder.

Endüstri Standardı: Altyazı Mantığı Bu tekniğin en somut örneği, YouTube veya Netflix altyazılarıdır.

Videoda patlamalar, beyaz ışıklar veya karanlık sahneler sürekli değişir; ancak beyaz altyazı, arkasındaki o yumuşak siyah gölge ( drop shadow ) sayesinde her karede kusursuzca okunur.

Web tasarımında da "Hero" başlıkları için bu teknik bir endüstri standardıdır.

</>
Teknik Kısıtlama: "Yayılma" (Spread) Yokluğu ve Çözümü Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Tasarım Stratejisi 1: Okunabilirlik Sigortası Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="hero-banner">
        <h2 class="guvenli-metin">Her Zeminde Okunabilir</h2>
    </div>
</body>

</html>
.hero-banner {
    height: 200px;
    background: linear-gradient(to right, #e0e0e0, #ffffff);
    display: grid;
    place-items: center;
}

.guvenli-metin {
    color: white;
    font-size: 2.5rem;
    font-family: sans-serif;
    text-shadow: 0 0 15px rgba(0, 0, 0, 0.8);
}

Tasarım Stratejisi 2 (Materyal Efektler) Aktif Işık Kaynağı ve Dokusal İllüzyon

Giriş - Genel Bakış

Tipografik gölgelerin ikinci büyük kullanım alanı, metni dijital ekranın düzleminden koparıp ona fiziksel bir materyal (cam, metal, kağıt veya taş) hissi kazandırmaktır.

Bu stratejide, gölge parametreleriyle oynayarak metnin ışığı yansıtan pasif bir nesne mi, yoksa ışık saçan aktif bir kaynak mı olduğunu belirlersiniz.

Neon / Glow Efekti (Aktif Işık Kaynağı)

Normalde gölgeler siyahtır çünkü cisim ışığı engeller.

Ancak bir metnin gölgesini, metnin kendi renginde ( veya daha canlı bir tonunda ) ve yüksek bulanıklıkla verirseniz, fizik kurallarını tersine çevirirsiniz.

Fiziksel Simülasyon: Ofset değerlerinin sıfıra ( 0px 0px ) eşitlenmesi, ışığın belirli bir yönden gelmediğini, merkezden dışarıya doğru yayıldığını gösterir.

Bu, metnin artık pasif bir cisim değil, elektrikle çalışan aktif bir ışık kaynağı olduğu illüzyonunu yaratır.

Cyberpunk ve Enerji: Özellikle siyah arka plan üzerinde; metnin kendisine "Beyaz" veya çok açık bir renk, gölgesine ise "Neon Mavisi" veya

"Hot Pink" vererek yapılan bu efekt, siberpunk estetiğinin ve modern "Dark Mode" tasarımların vazgeçilmezidir.

Metin, sanki bir gaz tüpüymüş gibi etrafındaki havayı ( atmosferi ) kendi rengiyle boyar.

Letterpress (Gömme/Oyma) Efekti (Dokusal Derinlik)

Bu teknik, web tasarımındaki en eski ve en zarif optik illüzyonlardan biri olan Skeuomorphism akımının mirasıdır.

Amaç, metnin ekrana "yazıldığını" değil, ekranın yüzeyine "basıldığını" veya "oyulduğunu" hissettirmektir.

Beyaz Gölge Paradoksu: Gölgeler karanlıktır, peki neden bu teknikte Beyaz ( veya açık renk ) gölge kullanılır?

Cevap, ışıktır.

Bir kağıda kalıp bastığınızda ( Letterpress ), oluşan çukurun üst kenarı gölgede kalırken, alt kenarı ışık kaynağından gelen ışığı yakalar ve parlar.

Uygulama Mantığı: Açık renkli bir zemin üzerine koyu gri bir yazı yazıp, yazıya 1px aşağıya kaydırılmış ( 0px 1px 0px ) sert ve Beyaz bir gölge eklenir.

Sonuç: Kullanıcının beyni, harflerin altındaki bu ince beyaz çizgiyi "ışık yansıması" olarak algılar.

Bu yansıma, metnin yüzeyden çukurda olduğu bilgisini verir.

Sonuç; kağıda, taşa veya metale oyulmuş, dokunma hissi uyandıran, son derece "Premium" ve sofistike bir tipografidir.

</>
Tasarım Stratejisi 2: Materyal Efektler (Letterpress) Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Tasarım Stratejisi 2: Materyal Efektler (Letterpress) Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="kagit-yuzey">
        <h1 class="oyma-metin">PREMIUM SERİ</h1>
    </div>
</body>

</html>
.kagit-yuzey {
    padding: 50px;
    background-color: #dcdde1;
    text-align: center;
}

.oyma-metin {
    font-family: 'Georgia', serif;
    font-size: 3.5rem;
    color: #7f8c8d;
    text-shadow: 0px 1px 0px rgba(255, 255, 255, 0.5);
}

Filter: drop-shadow() (Silüet ve Alfa Maskesi Gölgesi) Görsel İçeriğe Duyarlı Akıllı Gölgelendirme

Giriş - Genel Bakış

Web tasarımında gölge hiyerarşisi şimdiye kadar iki keskin sınıfa ayrılmıştı: box-shadow ile mimari blokları text-shadow ile de tipografik karakterleri gölgelendirdik.

Ancak tasarımcılar yıllarca üçüncü ve en karmaşık senaryoda çaresiz kaldılar:

"Ya elimizdeki nesne dikdörtgen değilse ama bir yazı karakteri de değilse?"

Modern web arayüzleri; arka planı şeffaf olan PNG görseller, karmaşık vektörel şekillere sahip SVG logolar veya clip-path ile kesilmiş özel formlarla doludur.

"Kutu Problemi" (The Box Problem)

Bir tasarımcı, arka planı şeffaf olan bir Yıldız İkonuna derinlik katmak için box-shadow kullandığında, tarayıcı teknik bir körlük yaşar.

Yıldızın şeklini görmezden gelir ve yıldızın kapladığı alanı çevreleyen görünmez çerçeveye ( Bounding Box ) standart bir kare gölge atar.

Sonuç: Yıldızın arkasında, görsel estetiği bozan, inandırıcılığı yıkan, çirkin ve kutu şeklinde bir karartı oluşur.

Bu, nesnenin organik yapısına aykırı bir "Karton Kutu" efektidir.

Çözüm: Pikselleri Okuyan Filtre İşte drop-shadow() fonksiyonu, bu geometrik kısıtlamayı aşmak için geliştirilmiş, görselin içeriğini analiz edebilen akıllı bir filtredir.

Bu özellik, CSS'in sadece kenarlara değil, görselin içindeki Alfa Kanalına bakmasını sağlar.

Böylece tarayıcı, dikdörtgen bir gölge çizmek yerine; görselin dolu piksellerinden kusursuz bir silüet çıkarır ve gölgeyi bu silüet üzerinden oluşturur.

</>
filter: drop-shadow() - Akıllı Gölge Analizi Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>filter: drop-shadow() - Akıllı Gölge Analizi Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="sahne">
        <div class="akilli-nesne">
            <div class="halka"></div>
            <p>drop-shadow() Etkisi</p>
        </div>

        <div class="aciklama">
            Gölge, halkanın ortasındaki boşluğu algılar ve oraya düşmez.
        </div>
    </div>
</body>

</html>
.sahne {
    padding: 40px;
    background-color: #f8f9fa;
    text-align: center;
    font-family: sans-serif;
}

.halka {
    width: 100px;
    height: 100px;
    margin: 0 auto 20px;
    border: 15px solid #e67e22;
    border-radius: 50%;
    background-color: transparent;
    filter: drop-shadow(0 10px 8px rgba(0, 0, 0, 0.3));
}

.akilli-nesne p {
    font-weight: bold;
    color: #333;
}

.aciklama {
    margin-top: 20px;
    font-size: 14px;
    color: #666;
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
}

Çalışma Mantığı (Alfa Kanalı Maskelemesi) Piksel Düzeyinde Hassasiyet ve Silüet Yönetimi

Giriş - Genel Bakış

box-shadow özelliği, HTML öğelerinin etrafındaki sanal dikdörtgeni gölgelendirirken "kördür"; kutunun içinde ne olduğuyla ilgilenmez.

Ancak drop-shadow, CSS'in filter ailesinin bir üyesi olarak çok daha sofistike bir çalışma prensibine sahiptir.

Bu fonksiyon, öğenin geometrik sınırlarına değil, doğrudan kimyasına, yani piksellerine odaklanır.

Bu işlem, tarayıcının görseli ekrana basmadan hemen önce gerçekleştirdiği üç aşamalı bir "Görüntü İşleme" sürecidir:

Alfa Analizi: Dijital Röntgen

Tarayıcı, drop-shadow uygulanan bir görseli ( PNG veya SVG ) milisaniyeler içinde piksel piksel tarar.

Bu tarama sırasında renk değerlerini (Kırmızı, Yeşil, Mavi) büyük ölçüde görmezden gelir ve sadece dördüncü veriye, yani Alfa Kanalına odaklanır.

Şeffaflık Haritası: Tarayıcı şu soruyu sorar: "Bu piksel tamamen boş mu, yoksa dolu mu ?"

Ayrıştırma: Şeffaf olan pikselleri "yok" sayar; dolu veya yarı saydam olan pikselleri ise "var" kabul ederek hafızasına alır.

Bu işlem, görselin dijital bir röntgenini çekmek gibidir.

Silüet Çıkarma: Gölge Maskesinin Oluşumu

Alfa analizi sonucunda elde edilen "dolu pikseller" haritası kullanılarak, nesnenin kusursuz bir kopyası, yani silüeti çıkarılır.

Geometrik Sadakat: Eğer görseliniz kanatlarını açmış bir kuş şeklindeyse, çıkarılan silüet de o kuşun tüylerine kadar aynı girintilere sahip olur.

Doku Duyarlılığı: Eğer görseliniz delikli bir İsviçre peyniri veya içi boş bir halka (donut) ise; box-shadow bu delikleri doldurup kapkara bir kare oluştururken, drop-shadow delikleri algılar.

Oluşturulan gölge maskesinin de tam ortasında aynı delikler bulunur.

Sonuç: Görsel İçeriğe Duyarlı (Context-Aware) Gerçekçilik

Elde edilen bu silüet, belirlenen renge boyanır, bulanıklaştırılır ve orijinal görselin arkasına yerleştirilir.

Sonuç, box-shadow'un yarattığı "karton kutu" etkisinden tamamen uzak, nesnenin fiziksel formuna saygı duyan organik bir gölgedir.

Bu özellik, "Görsel İçeriğe Duyarlı" bir işlemdir.

Yani görselin içeriği değiştiğinde (kuş kanat çırptığında veya logo döndüğünde), gölge de anlık olarak şekil değiştirerek bu harekete uyum sağlar.

Box Shadow vs Filter: Drop Shadow Parametreleri Kritik Farklar ve Uygulama Detayları Tablo Gösterimi
Özellik
box-shadow Davranışı
filter: drop-shadow() Davranışı
Referans Noktası

Öğenin Kutu Modeli'ne ( Bounding Box) uygulanır.

Öğenin Alfa Kanalına (Görsel Şekline) uygulanır.

Saydam Görseller

Saydam arka planlı bir PNG'ye uygulandığında, gölgeyi resmin etrafındaki görünmez dikdörtgenin tamamına uygular.

Gölgeyi sadece resmin opak (saydam olmayan) piksellerinin sınırlarına uygun olarak uygular.

Kullanım Amacı

Düğmeler, kartlar ve div gibi blok öğelerine derinlik katmak.

Saydam arka planlı logolara, PNG görsellere, SVG'lere ve clip-path ile şekli değiştirilmiş öğelere doğal gölge vermek.

</>
filter: drop-shadow() vs box-shadow Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>filter: drop-shadow() vs box-shadow Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="test-sahnesi">

        <div class="kutu">
            <div class="elmas kutu-golge"></div>
            <p>box-shadow</p>
            <small>(Kare gölge oluşturur)</small>
        </div>

        <div class="kutu">
            <div class="elmas akilli-golge"></div>
            <p>filter: drop-shadow()</p>
            <small>(Silüeti takip eder)</small>
        </div>

    </div>
</body>

</html>

                            
.test-sahnesi {
    padding: 40px;
    text-align: center;
    font-family: sans-serif;
    background-color: #f0f2f5;
}

.kutu {
    display: inline-block;
    width: 220px;
    margin: 20px;
}

.elmas {
    width: 80px;
    height: 80px;
    background-color: #3498db;
    margin: 0 auto 30px;
    transform: rotate(45deg);
}

.kutu-golge {
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.4);
}

.akilli-golge {
    filter: drop-shadow(0 10px 15px rgba(0, 0, 0, 0.4));
}

p {
    font-weight: bold;
    margin-bottom: 5px;
    color: #2c3e50;
}

small {
    color: #7f8c8d;
    display: block;
}
Seviye 5

Renk Uzayları ve Gölge İlişkisi Algısal Gerçeklik ve Kromatik Derinlik

Giriş - Genel Bakış

Yıllarca web geliştirme standartlarında gölge rengi dendiğinde akla gelen tek formül rgba(0, 0, 0, 0.1) yani "yarı saydam siyah" oldu.

Bu güvenli bir limandı; çünkü siyah her rengin üzerine uyar.

Ancak doğaya baktığımızda gölgelerin aslında "siyah" olmadığını görürüz.

Bir yaprağın gölgesi zifiri siyah değil, koyu yeşildir.

Bir insan teninin gölgesi siyah değil, koyu kahve/kızıldır.

Modern CSS ve gelişmiş renk uzayları, bu "Siyah Gölge Tembelliğini" yıkarak, gölgelerin matematiksel değil, algısal olarak doğru görünmesini sağlayan yeni bir çağ başlatmıştır.

Gölgenin Parlaklık (L) Kanalına Bağımlılığı ve RGB Sorunu

Geleneksel RGB veya HEX renk sistemleri, renkleri ışık kanallarını karıştırarak oluşturur.

Ancak bu sistemin biyolojik bir kusuru vardır: Bir rengi koyulaştırmaya çalıştığınızda, rengin karakteri bozulur.

Algısal Sorun: "Çamurlu" Renkler (Muddy Colors) RGB sisteminde canlı bir turuncuyu alıp, üzerine siyah ekleyerek gölge rengi elde etmeye çalıştığınızda; ortaya çıkan renk canlı bir "Koyu Turuncu" olmaz.

Genellikle kahverengiye çalan, grileşmiş ve matlaşmış, tasarımcıların "Çamurlu" dediği kirli bir ton ortaya çıkar.

Neden? Çünkü RGB'de parlaklığı değiştirmek, istemsizce rengin Tonunu ve Doygunluğunu da kaydırır.

İnsan gözü bu sapmayı "doğallıktan uzaklaşma" olarak algılar.

Çözüm: OkLCH ile Algısal Doğruluk Bu sorunun çözümü, rengi makine mantığıyla (RGB) değil, insan algısıyla işleyen OkLCH veya OkLab renk uzaylarını kullanmaktır.

Bu sistemler, rengi birbirinden tamamen bağımsız üç kanala ayırır: Ton ( H ), Doygunluk ( C ) ve Parlaklık ( L ).

Kromatik Gölge Tekniği: Bir butonun veya kartın gölgesini oluştururken, siyah renk kullanmak yerine ana rengin OkLCH değerleri referans alınır.

Yöntem: Ana rengin Ton ve Doygunluk değerleri sabit tutulur.

Sadece Parlaklık değeri düşürülür.

Sonuç: Ortaya çıkan gölge rengi, ana rengin kirlenmiş hali değil; sadece "ışığı azalmış" halidir.

Mavi bir butonun gölgesi, derin ve zengin bir lacivert olur.

Bu yöntem, gölgenin sanki cismin kendi materyalinden yansıyan bir parçaymış gibi görünmesini sağlar.

Buna "Algısal Olarak Doğru" gölgelendirme denir.

Geniş Gamut (Wide Gamut) ve Neon Gölgeler

Standart gölgeler, 90'lardan kalma sRGB renk uzayına hapsolmuştur.

Bu, özellikle "Glow" veya "Neon" efektleri yaratmak istediğinizde, gölgenin belli bir parlaklık sınırını aşamamasına neden olur.

sRGB Hapishanesinden Çıkış: Display P3 Modern ekranların ( OLED, Retina Display ) desteklediği P3 veya Rec. 2020 gibi Geniş Renk Gamlarını box-shadow içinde kullanmak, tasarımın enerji seviyesini değiştirir.

Neon Etkisi: Özellikle siberpunk veya fütüristik tasarımlarda, bir neon yazının etrafındaki parlamayı sRGB yeşili ile yapmakla, P3 yeşili ( color(display-p3 0 1 0) ) ile yapmak arasında uçurum vardır.

P3 gölgesi, ekrandan dışarı taşıyormuş gibi yoğun, elektrikli ve derin görünür.

Sonuç: CSS'te gölge rengini tanımlamak artık sadece "siyahın opaklığını kısmak" değildir.

Modern bir web geliştiricisi, gölgeyi OkLCH ile saflaştırıp, P3 gamutu ile canlandırarak; akademik düzeyde gerçekçi ve büyüleyici derinlik haritaları oluşturur.

</>
OkLCH ve Algısal Gerçeklik Giriş Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>OkLCH ve Algısal Gerçeklik Giriş Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="renk-uzayi-test">

        <div class="kutu klasik-golge">
            Siyah Gölge (sRGB)
        </div>

        <br>

        <div class="kutu kromatik-golge">
            Renkli Gölge (OkLCH Mantığı)
        </div>

    </div>
</body>

</html>
.kutu {
    width: 250px;
    height: 80px;
    background-color: #3498db;
    color: white;
    margin: 40px auto;
    text-align: center;
    line-height: 80px;
    font-family: sans-serif;
    border-radius: 12px;
}

.klasik-golge {
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.3);
}

.kromatik-golge {
    box-shadow: 0 15px 30px rgba(41, 128, 185, 0.5);
}
</>
sRGB (Klasik) vs. P3 (Neon/Vibrant) Mantığı Örneği (+)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>sRGB (Klasik) vs. P3 (Neon/Vibrant) Mantığı Örneği</title>
    <link rel="stylesheet" href="style.css?v=1.0.150">
</head>

<body>
    <div class="oda">

        <div class="lamba lamba-klasik">
            sRGB
        </div>

        <div class="lamba lamba-modern">
            P3 / Neon
        </div>

    </div>
</body>

</html>
.oda {
    background-color: #0d1117;
    padding: 60px;
    text-align: center;
    font-family: sans-serif;
}

.lamba {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    display: inline-block;
    margin: 20px 40px;
    line-height: 120px;
    color: white;
    font-weight: bold;
}

.lamba-klasik {
    background-color: #2ecc71;
    box-shadow: 0 0 30px rgba(46, 204, 113, 0.4);
}


.lamba-modern {
    background-color: #00ff00;
    box-shadow: 0 0 50px rgba(0, 255, 0, 0.8);
}

🧭 Opsiyonel Okuma Notu

Bilgilendirme: Bu bölüm, konuların arka planına ve düşünsel temellerine daha derin bir bakış sunmak amacıyla hazırlanmıştır.

  • Matematiksel, tarihsel ve felsefî içerikler isteğe bağlı olarak okunabilir.
  • Her bölümün içerik seviyesi ve yoğunluğu farklılık gösterebilir.
  • Temel düzey kullanıcılar için zorunlu değildir, ileri düzey okuma niteliğindedir.
Görsel Algı ve Estetik

Gölgeler (Felsefi ve Tarihsel Açıklama)

Gölge, dijital arayüzlerde yalnızca bir efekt değil; derinlik, hiyerarşi ve odak oluşturan görünmez bir tasarım dilidir.
Gerçek dünyadaki ışık algısını dijital ortama taşıyarak, öğelere fiziksel bir varlık hissi kazandırır ve kullanıcıya hangi elementin daha önemli olduğunu sezgisel olarak gösterir.

Ana Konu Felsefi ve Tarihsel Açıklama
Seviye 4

Görsel Algı ve Estetik Gölge (Shadow): Dijital Derinliğin Dili

Giriş - Genel Bakış

Gölge, dijital arayüz tasarımında yalnızca estetik bir süsleme veya basit bir efekt değildir; derinlik, hiyerarşi ve odak noktası oluşturan görünmez bir tasarım dilidir.

İnsan gözü, evrimsel süreç boyunca nesnelerin dünyadaki konumunu anlamlandırmak için ışık ve gölge ilişkisini kullanmıştır.

Web tasarımında gölge kullanımı, gerçek dünyadaki bu ışık algısını dijital ortama taşıyarak, iki boyutlu düz ekranlarda öğelere fiziksel bir varlık ve hacim kazandırır.

Felsefi ve Tarihsel Bağlam

Web tasarımının ilk yıllarında (Flat Design öncesi ve sonrası dönemler), gölgeler genellikle pikselleşmiş görsellerle ( PNG ) veya hantal Photoshop çıktılarıyla sağlanırdı.

Ancak CSS3 devrimiyle birlikte gelen box-shadow ve text-shadow özellikleri, bu efektleri grafik yazılımlarına gerek kalmadan, tarayıcının kendi motoruyla ve yüksek performansla oluşturma imkanı sundu.

Bu geçiş, tasarımcıların "statik resimler" yerine "dinamik ışık simülasyonları" oluşturmasına olanak tanıdı.

Gölge, kullanıcıya hangi elementin önde, hangisinin arkada olduğunu ve hangi butonun tıklanabilir olduğunu sezgisel olarak fısıldayan bir rehberdir.

Seviye 5

Akademik Temeller Gölgenin Fiziği ve Matematiği: Işık, Mesafe ve Algısal Simülasyon

Giriş - Genel Bakış

Bir web geliştiricisi CSS editöründe box-shadow özelliğine değer girdiğinde, aslında tarayıcıya basit bir boyama komutu vermez; ona anlık bir fizik simülasyonu yapması için emir verir.

Çünkü "gölge" dediğimiz kavram, kendi başına var olan fiziksel bir nesne değildir; ışığın bir cisim tarafından engellenmesi sonucu ortaya çıkan, ışığın "yokluğudur".

Dijital ekranlar doğası gereği iki boyutlu ( 2D ) cam yüzeylerdir.

Ancak beynimiz, evrimsel süreç boyunca dünyayı üç boyutlu ( 3D ) algılamaya programlanmıştır.

Bir nesnenin diğerinden daha önde olduğunu, yere ne kadar uzak olduğunu veya ortamdaki ışığın nereden geldiğini anlamak için beynimiz sürekli olarak gölgeleri referans alır.

CSS gölgelerinin akademik temeli, işte bu "Algısal Derinlik" illüzyonunu matematiksel olarak inşa etmeye dayanır.

Sanal Işık Kaynağı (The Virtual Light Source)

Tasarımcının belirlediği, ancak ekranda asla görünmeyen "Görünmez Güneş"tir.

İnsan beyni, doğada ışığın genellikle yukarıdan (Güneş) veya tavandan geldiğine koşullanmıştır.

Bu evrimsel alışkanlık nedeniyle, CSS gölgelerinde ışık kaynağının konumu hayati önem taşır.

Küresel Işık (Global Light) Prensibi: Tutarlı bir tasarımda, ışık kaynağı genellikle Sol-Üst köşede varsayılır ( Saat 10 veya 11 yönü ).

Bu yüzden gölgeler genellikle sağ-aşağı doğru düşer.

Eğer bir butonda ışık sağdan, diğerinde soldan gelirse; beyin bu tutarsızlığı "hatalı" veya "ürkütücü"

(korku filmlerindeki alttan tutulan fener etkisi gibi) olarak algılar.

Engelleyici Cisim (The Occluding Object)

Bu, gölgeyi oluşturan HTML öğesinin ( div, buton, kart, resim ) kendisidir.

Fiziksel dünyada gölgenin oluşması için ışığın yolunu kesen opak bir maddeye ihtiyaç vardır.

Katılık ve Hacim İllüzyonu: Tarayıcı, bu öğeyi kağıt gibi ince bir düzlem olarak değil; ışık huzmelerini engelleyen, kütlesi olan katı bir cisim olarak simüle eder.

Gölgenin varlığı, kullanıcıya şu mesajı verir:

"Bu buton ekranın camına yapışık değil, ondan daha yukarıda ve havada asılı duruyor."

Yansıtıcı Yüzey (The Reflective Surface)

Gölgenin üzerine düştüğü, öğenin arkasında kalan alandır ( genellikle body arka planı veya bir ebeveyn kapsayıcı).

Mesafe ve Projeksiyon: Gölge aslında bu yüzeyin üzerine çizilen bir resimdir.

Bu yüzey, derinlik algısının referans noktasıdır.

Engelleyici cisim ile yansıtıcı yüzey arasındaki "sanal mesafe" ne kadar fazlaysa, gölge o kadar bulanıklaşır ve uzağa düşer.

Tasarımcı, bu yüzeyi bir tuval gibi kullanarak öğelerin ne kadar yüksekte uçtuğunu belirler.

Tarayıcının "Rendering Engine", bu üç bileşeni alır ve saniyenin binde birinde karmaşık geometrik hesaplamalar yaparak, o öğenin arkasına düşmesi gereken karanlığı hesaplar.

Rönesans ressamlarının "Chiaroscuro" tekniğiyle tuvalde yapmaya çalıştığı derinlik algısını, modern tarayıcılar piksel koordinatları ve matematiksel bulanıklık formülleri ile yapar.

Bu yüzden CSS gölgelerini anlamak, ezbere kod yazmayı değil; ışığın davranışını, açısını ve yayılım fiziğini kavramayı gerektirir.

Basit Seviye Gölgenin Fiziksel Tanımı ve Optik Yasaları

Giriş - Genel Bakış

Fiziksel dünyada gölge, dijital bir boyama işlemi değil, optik bir sonuçtur.

Işık, boşlukta doğrusal bir yol izler ( doğrusal yayılım ).

Bu yolculuk sırasında önüne ışığı geçirmeyen, yani saydam olmayan bir cisim çıktığında, ışık huzmeleri engellenir.

Cismin hemen arkasında oluşan ve ışığın ulaşamadığı bu karanlık hacme "Gölge" denir.

Ancak her gölge simsiyah veya keskin kenarlı değildir.

Bir gölgenin karakterini ( yumuşaklığını veya sertliğini ) belirleyen temel faktör, ışık kaynağının boyutu ve cisme olan uzaklığıdır.

Noktasal Işık Kaynağı (The Point Source)

Eğer ışık kaynağı çok küçükse ( lazer ucu, küçük bir LED veya çok uzaktaki bir yıldız gibi ), ışık ışınları tek bir noktadan çıkarak cisme ulaşır.

Sonuç: Mutlak Karanlık ve Keskin Sınırlar Işık kaynağının tek bir noktadan ibaret olduğu bu senaryoda, ışık ışınları cismin kenarlarından geçerken herhangi bir açılma veya sapma yapmazlar.

Işınların doğrusal yolculuğu cisim tarafından aniden kesildiği için, cismin arkasında Tam Gölge adı verilen alan oluşur.

Bu alanın en belirgin özelliği, sınırlarının bıçakla kesilmiş gibi net olmasıdır.

Aydınlık bölgeden karanlık bölgeye geçişte, gözü hazırlayan hiçbir gri tonlama, bulanıklık veya yumuşak geçiş bulunmaz.

Fiziksel olarak sadece iki durum söz konusudur: Bir nokta ya tam ışık alıyordur ya da tam karanlıktadır.

Web Karşılığı: Dijital Sertlik ve "Flat" Estetik Dijital tasarımda bu katı fiziksel kuralın karşılığı, box-shadow özelliğinde bulanıklık değerinin sıfıra (blur-radius: 0px) eşitlenmesidir.

Bu ayar yapıldığında, tarayıcı gölgenin kenarlarındaki yumuşatma ve dağıtma algoritmalarını devre dışı bırakır.

Sonuç olarak gölge, cismin kopyası olan katı bir blok halinde, piksel piksel ekrana çizilir.

Bu teknik, gerçekçi bir derinlik hissi vermekten ziyade; "Flat Design", 90'ların Retro işletim sistemleri veya Neo-Brütalizm gibi modern akımlarda; objelerin kağıt gibi üst üste yapıştığı, grafiksel ve yapay bir etki yaratmak için bilinçli bir stil tercihi olarak kullanılır.

Geniş (Yaygın) Işık Kaynağı (The Extended Source)

Eğer ışık kaynağı cisimden daha büyükse veya geniş bir yüzeyden yayılıyorsa ( Güneş, bulutlu bir gökyüzü veya fotoğrafçılıktaki

Softbox ışıkları), ışık ışınları cisme tek bir açıdan değil, milyonlarca farklı açıdan çarpar.

Tam Gölge (Umbra): Karanlığın Mutlak Çekirdeği Gölgenin kalbinde yer alan bu bölge, cismin hemen arkasında oluşan en yoğun ve en karanlık alandır.

Burada fiziksel blokaj tamdır; ışık kaynağından gelen hiçbir foton bu alana sızamaz.

Cismin geometrik şeklini ve siluetini koruyan, gölgenin "sert iskeletini" oluşturan kısım burasıdır.

CSS'te gölgenin opaklığının en yüksek olduğu merkez noktası, bu fiziksel olguyu temsil eder.

Yarı Gölge (Penumbra): Bulanık Geçiş ve Yumuşama Tam gölge çekirdeğinden dışarıya doğru uzaklaştıkça, karanlık aniden bitmez; yerini

"Yarı Gölge" denilen gri bir geçiş bölgesine bırakır.

Bu alanda cisim, ışık kaynağının tamamını değil, sadece bir kısmını engeller.

Kaynağın kenarlarından sızan ışık huzmeleri bu bölgeye ulaşabildiği için, gölge uçlara doğru gittikçe açılır, bulanıklaşır ve sonunda zeminle bütünleşerek yok olur.

Bir gölgenin ne kadar "yumuşak" göründüğü, aslında bu yarı gölge alanının ne kadar geniş olduğuyla ilgilidir.

Orta Seviye Matematiksel Prensip (Ofset, Vektörler ve Geometri)

Giriş - Genel Bakış

Fiziksel dünyada ışık karmaşık bir dalga iken, CSS dünyasında gölge tamamen Koordinat Geometrisi üzerine kuruludur.

Tarayıcı, fiziksel ışık-cisim ilişkisini taklit etmek için, ekranı X ve Y eksenlerinden oluşan matematiksel bir düzlem olarak kabul eder.

Bu simülasyonda tarayıcı, geliştiricinin belirlediği değerlere bakarak ışık kaynağının konumunu

"ters mühendislik"yöntemiyle tahmin eder.

Yani siz ışığın yerini belirlemezsiniz; gölgenin yerini belirlersiniz ve beyin buna bakarak ışığın nerede olduğunu hayal eder.

Yatay ve Dikey Ofset (Vektörel Kayma ve Katman Mantığı)

CSS'te bir gölge oluşturulduğunda, tarayıcı arka planda aslında çok basit bir "Kopyala-Yapıştır-Kaydır" işlemi yapar.

Öğenin siluetinin birebir kopyası olan bir katman oluşturulur, siyaha boyanır ve ana öğenin (z-index olarak) arkasına gönderilir.

offset-x ve offset-y değerleri, bu kopya katmanın ana cisimden ne kadar uzağa "öteleneceğini" belirleyen vektörel koordinatlardır.

Ancak bu öteleme işlemini doğru yönetmek için, web dünyasının kendine has haritasını anlamak gerekir.

Koordinat Sistemi Farkı: Lise Matematiğinin Tersine

Web tarayıcılarının çalışma mantığı, kağıt üzerine yazı yazma alışkanlığımıza dayanır.

Bu yüzden lise yıllarında öğrendiğimiz standart Kartezyen koordinat sisteminden kritik bir farkla ayrılır:

Matematik biliminde Y ekseni yukarı doğru artar.

Web'de ise başlangıç noktası \(0,0\) ekranın Sol-Üst köşesidir.

X ekseni sağa doğru artarken, Y ekseni aşağı doğru artar.

Bu terslik, gölge yönlerini belirlerken tasarımcıların en sık hata yaptığı noktadır.

Yatay Ofset (\(x\)): Işığın Yanlamasına Hareketi

Bu değer, gölge katmanının yatay eksendeki hareketini kontrol eder.

Pozitif Değer (+X) Gölgeyi sağa doğru iter.

Beyin, sağ tarafa düşen bir gölge gördüğünde, fizik yasaları gereği ışık kaynağının cismin Solunda olduğunu varsayar.

Negatif Değer (-X) Gölgeyi sola doğru iter.

Bu durumda beyin, ışık kaynağının Sağ taraftan vurduğunu algılar.

Web tasarımlarının %90'ında, okuma yönüne uygunluk (soldan sağa) açısından ışığın soldan gelmesi tercih edilir.

Dikey Ofset (\(y\)): Işığın Yükselip Alçalması Bu değer, gölgenin dikey eksendeki hareketini ve dolayısıyla ışık kaynağının yüksekliğini simüle eder.

Pozitif Değer (+Y) Gölgeyi aşağıya doğru iter.

Bu, en kritik ayardır. Çünkü insan beyni, ışığın ( Güneş veya tavan lambası ) her zaman Yukarıdan gelmesine evrimsel olarak alışkındır.

Cismin altına düşen gölge, "doğallık" ve "güven" hissi verir.

Negatif Değer (-Y) Gölgeyi yukarıya doğru iter.

Bu, ışığın cismin Altından vurduğu anlamına gelir.

Sinema dilinde ve fotoğrafçılıkta alttan gelen ışık "korku", "gizem" veya "doğaüstü" bir atmosfer yaratır.

Bu yüzden web arayüzlerinde (Halloween temaları hariç) negatif dikey ofset neredeyse hiç kullanılmaz; çünkü kullanıcıda bilinçaltı düzeyinde bir huzursuzluk yaratır.

Sonuç: Küresel Işık Standardı En yaygın kullanım olan pozitif X ve pozitif Y kombinasyonu, gölgenin sağ-alt köşeye düşmesini sağlar.

Bu vektörel bileşke, kullanıcıya ışık kaynağının Sol-Üst köşede asılı durduğu mesajını verir.

Bu, Windows masaüstünden Google Material Design'a kadar tüm dijital dünyada kabul görmüş evrensel "Global Işık" modelidir.

Üçgen Benzerliği ve İzdüşüm (Projection) Gölge Uzunluğu ve Yükselti İllüzyonu

Matematiksel olarak bir gölgenin uzunluğu ve cisme olan uzaklığı, Thales'in Üçgen Benzerliği Teoremi ile açıklanan bir "İzdüşüm" problemidir.

Fiziksel dünyada; ışık kaynağı, cisim ve gölgenin düştüğü nokta arasında görünmez bir dik üçgen oluşur.

CSS motoru bu üçgenin hipotenüsünü hesaplamasa da, tasarımcı box-shadow değerlerini girerek bu üçgenin sonucunu manuel olarak taklit eder.

Bu taklit işlemi, kullanıcının beyninde cismin "Z-Ekseninde" nerede durduğuna dair güçlü bir yargı oluşturur.

Işık Açısı Simülasyonu: Ofset Değeri Bir İpucudur CSS'te verdiğiniz ofset değeri ( gölgenin cisme olan piksel uzaklığı ), aslında ışık kaynağının cisme hangi açıyla vurduğunu temsil eder.

Beynimiz bu mesafeyi gördüğü an, milisaniyeler içinde ışığın konumunu ve cismin yüksekliğini hesaplar.

Kısa Mesafe (Küçük Ofset) = Düşük İrtifa Eğer gölge cisme çok yakınsa, beyin şu fiziksel çıkarımı yapar:

"Işık kaynağı çok tepede" ve "cisim zemine çok yakın".

Tasarım Anlamı: Bu ayar, cismin zemine "yapışık" olmasa da, hemen üzerinde durduğunu hissettirir.

Genellikle tıklanabilir butonların pasif hallerinde veya form alanlarında kullanılır.

"Ben buradayım ama henüz havalanmadım" mesajı verir.

Uzun Mesafe (Büyük Ofset) = Yüksek İrtifa (Elevation) Eğer gölge cisimden çok uzağa düşmüşse, beyin iki farklı senaryoyu değerlendirir: Ya ışık kaynağı çok yatık bir açıyla geliyordur ya da cisim zeminden çok yükseğe havalanmıştır.

Tasarım Anlamı: Modern arayüzlerde (özellikle Google Material Design'da) bu durum "High Elevation" olarak adlandırılır.

Cisim, diğer içeriklerin çok üzerinde süzülmektedir.

Bu teknik, genellikle Modal Pencereleri, açılır menüler veya sürükle-bırak işlemi sırasında havaya kaldırılan kartlar için kullanılır.

Gölge ne kadar uzaksa, öğe kullanıcıya o kadar yakın algılanır.

İleri Seviye Gaussian Blur ve Konvolüsyon Bulanıklığın İstatistiği ve Tarayıcı Motoru

Giriş - Genel Bakış

Bir web geliştiricisi blur-radius değerini artırdığında, tarayıcı arka planda basit bir boyama işlemi yapmaz; Gaussian Dağılımı adı verilen karmaşık bir istatistiksel fonksiyonu çalıştırır.

Dijital dünyada bir gölgenin kenarlarının keskinliğini yitirip yumuşaması, rastgele bir "lekeleme" değil, son derece hassas bir olasılık hesabıdır.

Bu süreç, gölgenin yapay durmaması ve doğadaki ışık kırılmalarını taklit edebilmesi için geliştirilmiş bilimsel bir standarttır.

Gaussian Fonksiyonu (Çan Eğrisi)

İstatistikte verilerin ortalamaya göre dağılımını gösteren meşhur "Çan Eğrisi", görüntü işlemede bir pikselin renginin komşularına nasıl dağılacağını belirler.

Merkez Ağırlığı: Tarayıcı bir pikseli işlerken, o pikselin orijinal rengine en yüksek matematiksel ağırlığı verir.

Komşuluk Etkisi: Merkezden dışarıya doğru uzaklaştıkça, komşu piksellerin o noktadaki renk üzerindeki etkisi, çan eğrisinin yamaçları gibi azalarak devam eder.

Sonuç: Bu matematiksel dağılım sayesinde, siyah olan gölge rengi aniden beyaza dönüşmez; pikseller birbirlerinin renk ortalamasını alarak mikroskobik düzeyde yumuşak bir geçiş oluşturur.

Konvolüsyon (Convolution) Matrisi

Tarayıcılar, yukarıdaki Gaussian formülünü ekrana uygulamak için "Konvolüsyon" adı verilen bir teknik kullanır.

Bu, dijital görüntünün üzerinde gezdirilen matematiksel bir filtredir.

Kernel (Çekirdek) Matrisi: Tarayıcı, blur-radius değerine göre küçük bir sayı tablosu oluşturur.

Buna "Kernel" denir.

Kaydırma ve Hesaplama: Bu matris, gölge katmanının sol üst köşesinden başlayarak her bir pikselin üzerine tek tek oturur.

Matrisin içindeki sayılarla, alttaki piksellerin renk değerleri çarpılır ve toplanır.

Ortaya çıkan yeni değer, o pikselin "bulanıklaştırılmış" yeni rengi olur.

Performans Maliyeti: blur-radius değerini ne kadar artırırsanız, tarayıcının oluşturduğu matris o kadar büyür (50x50).

Matris ne kadar büyürse, işlemci her piksel için o kadar çok çarpma işlemi yapmak zorunda kalır.

Büyük bulanıklıkların tarayıcıyı yavaşlatmasının temel sebebi, bu devasa matris hesaplamalarıdır.

CSS ve Sigma (\(\sigma\)) İlişkisi Pikselden İstatistiğe Dönüşüm

CSS kodunda yazdığımız blur-radius (örneğin 10px), aslında tarayıcı motoruna gönderilen bir "Standart Sapma" ( \(\sigma\) - Sigma ) talebidir.

İstatistikte verilerin ortalamadan ne kadar uzaklaştığını gösteren Sigma Değeri, görüntü işlemede rengin merkezden çevreye ne kadar "saçılaçağını" belirler.

Ancak burada kritik bir teknik detay vardır: W3C spesifikasyonlarına göre, CSS'teki piksel değeri ile matematiksel Sigma Değeri birebir aynı değildir.

Tarayıcılar genellikle performans optimizasyonu için Yarıçap ≈ 2σ formülünü kullanır.

Yani sizin girdiğiniz piksel değeri, matematiksel eğrinin genişliğini belirleyen bir girdiye dönüştürülür.

Düşük Sigma (Az Blur):

Çan eğrisi dardır ve sivridir.

Renk bilgisi merkezden uzağa taşınmaz.

Bu, ışık kaynağının cisme çok yakın olduğu veya noktasal olduğu durumları simüle eder.

Gölge, cismin sınırlarını net bir şekilde korur.

Yüksek Sigma (Çok Blur):

Çan eğrisi genişler, yayvanlaşır ve basıklaşır.

Renk bilgisi çok geniş bir alana, incelerek yayılır.

Gölge, bir şekil olmaktan çıkıp bir "atmosfere" veya "buhara" dönüşür.

Bu, ışık kaynağının çok büyük ( Güneş gibi ) veya çok dağınık olduğu senaryolarda, cisme yumuşak bir hacim kazandırmak için kullanılır.