css etiketine sahip kayıtlar gösteriliyor. Tüm kayıtları göster
css etiketine sahip kayıtlar gösteriliyor. Tüm kayıtları göster

1 Haziran 2007 Cuma

JavaScript Button Rollover

Merhaba,
Bu yazımda biraz daha dizayn ağırlıklı bir konudan bahsedicez.
Konumuz rollover button'lar. Bilmeyenler için bir hatırlatma yapalım, Rollover bir çok sitede gördüğünüz farenin bir butunun veya bir imajın üzerine gelmesiyle o nesnenin değiştirilmesi işlemine verilen isimdir.

Bu işlem çoğunlukla web sitelerdeki tuşları tanımlamak ve tıklanabilir olduklarını anlatmak için kullanılır.

Aslında birçok kişi bu konuya Dreamweaver'dan aşina. Dreamweaver sizin için otomatik olarak rollover imagelar yaratabiliyor. Ancak yarattığı kod o kadar çirkin ve kullanışsızki, her yeni rollover image eklediğinizde HTML'inize birsürü karışık kodlar ekleyip daha sonra içinden çıkamıyacağınız bir hale getiriyor.
Bu iş için çok basit bir CSS Çözümü var aslında ancak IE herzamanki gibi oyun bozanlık yapıp bunu kullanmamızı engelliyor. Yinede ben %90 lık IE kullanıcılarını umursamıyorum diyorsanız CSS yöntemini bi hatırlatalım



.rollover{
background:url(images/button.gif);
}

.rollover:hover{
background:url(images/button_over.gif);
}

.rollover:active{
background:url(images/button_down.gif);
}

Kodu biraz tanımlarsak. .rollover{ image'ın normal durumu .rollover:hower image'ın mouseover durumu ve .rollover:active ise image'ın mousedown durumudur. geri kalanı CSS sizin için halledicektir.
Gördüğünüz gibi oldukça basit, ancak iki kusuru var birincisi IE6 asla ne yapmaya çalıştığınızı anlamıyacak ve ikincisi her roll over image için ayrı ayrı bunları yazmanız gerekicek.

Durum böyle olunca bende kendi javascript fonksiyonumu yazmaya karar verdim. heryerde kullanılabilecek oldukça geliştirmeye açık ve anlaşılır olmasını istedim. Sonuçta JotForm üzerinde kullanıyoruz ve oldukça başarılı oldu.

İlk önce fonksiyonun nasıl çalıştığının bir örneğini görelim.



İlk tuş yukarda verdiğim CSS rollover örneğine ait. Alttaki iki tane ise benim javascript ile yaptığım örnekler
birisi normal imaj diğeri ise bir button, yazdığım fonksiyon ikisi arasındaki farkı anlayıp ona göre davranıyor. ayrıca fark ettiyseniz alttaki tuşda mousedown efekti yok buda fonksiyona gönderilen bir argumanla kapatılabiliyor.

evet şimdi fonksiyonu görelim.



function buttonOver(elem,noDown){
var realImage = ""; // Should be empty. veriable to keep original background.
var ext = ".gif"; // Define Extention .gif .png .jpg
var over_ext = "_over" + ext; // Define subfix of images. Such as: image1.gif, image1_over.gif, image1_down.gif
var down_ext = "_down" + ext; // Define subfix of images. Such as: image1.gif, image1_over.gif, image1_down.gif
var regEx = /\.\w+$|\.\w+\)$/; // Remove extention of the image
var preload_img = function(imgToLoad){
var img = new Image;
if(document.imageArray)
document.imageArray.push(img.src = imgToLoad);
else{
document.imageArray = new Array();
document.imageArray.push(img.src = imgToLoad);
}
}

if(elem.style.backgroundImage){ // if object has a background.
realImage = elem.style.backgroundImage.replace(regEx,""); //Take original background and replace with over image.
elem.style.backgroundImage = realImage + over_ext +")";
}else if(elem.src){ // if object has a src .
realImage = elem.src.replace(regEx,""); //Take original background and replace with over image.
elem.src = realImage + over_ext;
}
if(!noDown) preload_img((realImage + down_ext).replace(/^url\(/,"")); // Preload images
elem.onmouseout = function(){ buttonOut(elem); } // Define mouseout event.
elem.onmousedown = function(){ buttonDown(elem); } // Define mousedown event.
elem.onmouseup = function(){ buttonUp(elem); } // Define mouseup event.
var buttonOut = function(elem){ // on mouseOut revert back to original image.
if(elem.style.backgroundImage){
elem.style.backgroundImage = realImage + ext + ")";
}else if(elem.src){
elem.src = realImage + ext;
}
}
var buttonUp = function(elem){ // on mouseUp revert back to mouseover image.
if(elem.style.backgroundImage){
elem.style.backgroundImage = realImage + over_ext +")";
}else if(elem.src){
elem.src = realImage + over_ext;
}
}
var buttonDown = function(elem){ // on mouseDown replace with mouseDown image.
if(noDown) return true;
if(elem.style.backgroundImage){
elem.style.backgroundImage = realImage + down_ext +")";
}else if(elem.src){
elem.src = realImage + down_ext;
}
}
}



buttonOver fonksiyonunu kullanmanız için ilk önce yapmanız gerek bir kaç küçük ayar var.
mesela fonksiyonun ilk satırındaki değerleri ayarlamak gibi.


function buttonOver(elem,noDown){
var realImage = "";
var ext = ".gif";
var over_ext = "_over" + ext;
var down_ext = "_down" + ext;
[...]


Gayet açık kullanacağınız image'ların uzantısı ext, mouseover olduğunda gelicek resmin son eki over_ext, mousedown olduğunda gelicek olan resmin son eki down_ext
resimleriniz için genelde button.gif, button_over.gif, button_down.gif yada button.gif button2.gif button3.gif gibi isimler seçmeye özen gösterirseniz hem işinizde kolaylık sağlar hemde dosyaların yönetimi kolaylaşır.

Fonksiyon artık kullanıma hazır. fonksiyonu çalıştırmak için yapmamız grekende çok basit. Sadece mouseover event'inde buttonOver(this) yazarak çağırıcaz tek yapmamız gereken bu. Fonksiyon sizin verdiğiniz ayarlara göre davranarak diğer bütün eventleri ayarlayacaktır.
Ayrıca mousedown işleminde gelicek olan resim içinde küçük bir preload var.
eğer mousedown event'inin çalışmasını istemiyorsanız da buttonOver(this,true) diyerek çalışmasını engelleyebilirsiniz.

Fonksiyonla ilgili bir sorun yaşarsanız herzaman sorabilirsiniz.
İyi Çalışmalar.

26 Mart 2007 Pazartesi

İnternet Explorer için Alternatif PNG Desteği

Merhabalar,
Eminim Hepiniz IE'nin PNG desteği verememesi sorunuyla uğraşmışsınızdır.
Her nekadar IE7'nin yarım yamalak bir PNG desteği olsa bile IE6 hala bizim müdahelemize ihtiyaç duyuyor.
PNGleri çalıştırmak için bir sürü yöntem var bende size Javascript yardımıyla bu işi yaptırıcam umarım güzel olur başlayalım,
Fonkisoyunumuzun düzgün çalışması için bir dosyaya ihtiyacımız var BLANK.GIF
bu Dosyayı indirdip ulaşabileceğimiz bir yere koyduktan sonra.

şu fonksiyonu kullanıyoruz.



function pngImages(){
var img;
if(document.all){
for(x=0;x < arguments.length;x++){
elm = document.getElementById(arguments[x]);
img = (elm.src)? elm.src : (elm.background)? elm.background : (elm.backgroundImage)? elm.backgroundImage : "";
elm.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true, sizingMethod=scale src='" + img + "')";

if(elm.src)
elm.src = "images/blank.gif";
else if(elm.background)
elm.background = "images/blank.gif";
else(elm.backgroundImage)
elm.backgroundImage = "images/blank.gif";
}
}
}

Fonksiyon bütün ona yolladığımız elementlerin varsa SOURCE'una yada BACKGROUND'una blank.gif yerleştirip CSS sayesinde BACKGROUND-IMAGE'a da PNG resmini koyacak.

Fonksiyonu Sayfa tamamen yüklendikten sonra (onload) bu şekilde çağırmalısınız.


pngImages("logo","faq","forum","blog");

Bir deneyin bakalım birçok yöntemden daha hızlı ve sadece belirli nesneye yönelik olduğudan açılırken sadece ihtiyaç duyulan resimleri çevirerek hız kazanabilirsiniz.
bu avantajların yanında çevirmek istediğiniz her nesneye ID vermek zorunda olmanız ise DEZAVANTAJ.

İyi Çalışmalar..

18 Aralık 2006 Pazartesi

JavaScript Debugger and Trace Tool

Hi, people.
Here is the tool that i wrote it for my self,
i sick of using alert() and i wrote a trace tool.
it can show you the errors also you can use it to prompt any thing on it, just like using alert().
also you don't have to add any code onto your site. just call the trace.js at very top of your page and it will run it by itself.
to promp on screen just use it like alert() but call it as trace("helloworld");
it's quite simple. it work on almost all browsers.
best part is, this tool is in a floating windows so this means you can place it anywhere in your page.
You can see the working version here
-----
There is a watch property I currently added. watch is not perfect but at least you can fallow hidden fields or that kind of thing by just giving their id's.
-----
you can find the code here



6 Aralık 2006 Çarşamba

Rating Stars, Websitenize Yıldız Temalı Rating Ekleyin.

Bir çok sitede gördüğünüz rating yıldızcıklarını artık kendi sitenizede ekleyebilirsiniz.
İşlem oldukça basit.

Öncelikle yıldız resimlerinin içinde bulunacağı bir table yapmalıyız.


<table id="starTable" width="75" height="15" border="0" cellpadding="0" cellspacing="0" background="star0.gif" onMouseOut="resetRate(this)">
<tr>
<td width="15" height="15" onMouseOver="changeRate('1')" onClick="rate(this,'1')"></td>
<td width="15" onMouseOver="changeRate('2')" onClick="rate(this,'2')"></td>
<td width="15" onMouseOver="changeRate('3')" onClick="rate(this,'3')"></td>
<td width="15" onMouseOver="changeRate('4')" onClick="rate(this,'4')"></td>
<td width="15" onMouseOver="change('5')" onClick="rate(this,'5')"></td>
</tr>
</table>

table'a ilk baktığımızda sanki ayrı ayrı yıldızlar varmış gibi gözükmesine rağmen aslında toplamda altı resim var.
Bir tane bütün yıldız ların sönük olduğu resim, ardından bütün yıldızların yanık olduğu resme kadar sırayla artan 5 resim daha. bu mantıkla işlem bir anda bebek işine dönüşüyor.
Şimdi kod'a dikkat ettiyseniz 3 adet function görürsünüz
bunlar
changeRate()
rate()
resetRate()
Ayrıca table'a birde background-image verdim bu image sıfır rating'i temsil ediyor.
functionların Şimdi hepsini bir bir açıklayalım Örnek kodu'da altta

function changeRate(val){
document.getElementById('starTable').style.backgroundImage = "url(star"+val+".gif)";
}

function rate(val){
document.getElementById('rated').value = val;
}

function resetRate(elem){
var val = document.getElementById('rated').value;
if(val == "")
elem.style.backgroundImage="url(star0.gif)";
else
elem.style.backgroundImage="url(star"+val+".gif)";
}
onMouseMove event'inde çağırdığımız changeRate function'ı mouse'u üzerine getirdiğimiz TD'ye göre Table'ın background image'ını değiştiriyor. buda yıldızların dolma boşalma efektini oluşturuyor.
funtion table'ı id'sinden yakalayıp backgraound image olarak daha önceden hazırladığımız ve akıllıca isimlendirdiğimiz yıldız resimlerini atıyor. akıllıca diyorum çünki verdiğimiz isimler şöyle
star0.gif
star1.gif
star2.gif
vs.
hangi rating verildiyse
"star"+val+".gif"
diyerek sadece bir seferde if kullanmadan resimlere ulaşabiliyoruz.
bu tarz dosya isimleri çoğu zaman hayat kurtarır.
---
onMouseClick event'inde çağırdığımız rate function'ı tek değer alıyor. buda rating değeri.
function basitçe kendisine gönderilen değeri bir textbox'ın içine yazıyor. seçilen değeri bir yerlerde tutmalıyızki daha sonra yıldızlarımız kaç seçtiğimizi hatırlayabilsin.
bu function aslında en önemli function çünki oylama burda yapılıyor ve gerçek bir uygulamada bütün içeriği bu function'a yazmanız gerekebilir. isterseniz direk PHP ile istereniz (ki daha uygun) AJAX ile seçili değeri database'inize gönderebilirsiniz. textbox yerine hidden field kullanabilirsiniz ben burda demo olduğu için bir textbox kullandım.
Rating:
<input type="text" id="rated" />

---
Üçüncü ve son functionda resetRate Function'ı mouse'umuzu yıldızların üzerinden çektiğimizde değerlerini unutmamalarını ve göstermeye devam etmelerini sağlayan function. bu function'ı yıldızların tamamını kapsayan table'ın onMouseOut event'ine koyduk ki mouse terk ettiğinde çalışsın.
function direkt textbox'ımızın içindeki değere bakıyor. eğer textboxda hiçbirşey yoksa sıfır nolu resmi eğer bir değer varsada changeRate'de yaptığımız gibi o değerin resmini çağırıyor. bu functionda textbox'ın içindeki değeri doğrulayan herhangi bir kontrol kod'u koymadım çünki zaten büyük olasılıkla hidden kullanıcaksınız.
--
kodlar gayet basit olduğuiçin istediğiniz gibi düzenleyebilirsiniz. Örnek kod için buraya

5 Aralık 2006 Salı

Aktif CSS Değiştirme

Web sitenize eklediğiniz CSS sheet'leri aktif olarak değiştirerek ziyaretçilerinizin farklı temaları sayfa yenilenmeden görebilmelerini sağlamak istermisiniz? bu yazıda bunu nasıl yapabileceğinizi anlatacağım.
Java script, CSS, ve HTML kullanacağımız bu örnek aslında oldukça basit, ancak internette pek örneği yok. O yüzden bunu yaparak ender bulununan bir site yapmış olacaksınız.
Şimdi başlayalım.
Örnek Dosya için buraya

Öncelikle hazırladığınız sayfa için elbete bir css dosyanız olmalı. Sayfanızın bütün style düzeni bu dosya üzerinden yönetiliyor olmalı (her iyi sitede olması gerektiği gibi). şimdi bu style sheet'den belli kopyalar yaratın. kopya derken sadece class isimleri aynı olsa yeter. class isimlerinin aynı olması hiçbir yerde extra kod yazmadan bu işi bitirmemizi sağlayacak.
Style sheet'i sayfaya linklediğimiz tag'e fazladan bir "ID" ekledim böylece javascript ile ona ulaşabileceğiz.

<link href="style1.css" id="stil" rel="stylesheet" type="text/css" />
Şimdi birde basitçe HTML kodumuza bakalım, bu kodu body tag'inin içine yerleştirelim.

<div class="header">Bilgi Formu</div>
<table width="260" border="0" cellpadding="5" cellspacing="0" class="mtable">
<tr>
<td width="70">&#304;sim:</td>
<td width="175"><input name="ism" type="text" class="elem" /></td>
</tr>
<tr>
<td>Soyisim:</td>
<td><input name="soyisim" type="text" class="elem" /></td>
</tr>
<tr>
<td>Tel:</td>
<td><input name="tel" type="text" class="elem" /></td>
</tr>
<tr>
<td valign="top">Adres:</td>
<td><textarea name="adres" rows="5" cols="20" class="elem"></textarea></td>
</tr>
<tr>
<td>Stil:</td>
<td>
<select name="select" class="elem" onchange="changeStyle(this)">
<option>style1</option>
<option>style2</option>
<option>style3</option>
</select> </td>
</tr>
<tr>
<td colspan="2" align="center">
<input type="button" value="Ok" class="btn" />
<input type="reset" value="clear" class="btn" />
</td>
</tr>
</table>

koda dikkat ettiyseniz nerdeyse bütün elementlere bir style atanmış. ayrıca en altlarda bulunan select tag'ınında onChange'inde changeStyle isimli bir function var bu function'a objeyi this kullanarak yolladımki bizi birdaha onu çağırmakla uğraştırmasın
Şimdi bu function kısaca şunu yapıyor select'in seçili değerinin sonuna ".css" ekleyip bir dosya ismine çeviriyor ve style link'inin bunu çağırmasını sağlıyor.
ben kolay olduğu için bu yöntemi seçtim isteyen if ile check edip istediği ismi çağıradabilir yani select'in değerlerini isme dönüştürmek zorunda değilsiniz yada select kullanmak zorundada değilsiniz. bu sadece bir örnek, neyse.
Function'da kısaca şöyle bu function'da sayfanızın HEAD kısmında, Script tag'inin içinde bulunmalı

function changeStyle(elem){
var stylelink = document.getElementById('stil');
stylelink.href = elem.options[elem.selectedIndex].text + ".css";
}


Gördüğünüz gibi Çok kolay. sadece link tag'ini id'sinden yakalayıp href'ine istediğimiz değeri atıyoruz. oda canlı olarak sonuç veriyor.

Bu script Firefox ve IE'de düzgün çalışır. ama CSS'in yeteneklerini görmek istiyorsanız Firefoxdan şaşmayın derim ben.