30 Kasım 2013 Cumartesi

Sylvester.js Kütüphanesi


 Herkese merhabalar.

    Bir hafta aradan sonra sizlerle tekrardan beraberiz. Bu hafta sizlere sylvester.js isimli JavaScript kütüphanesinden bahsetmek istiyorum. Sylvester kütüphanesi; vektör, matris ve geometri kütüphanesidir. İstediğimiz boyutta matris ve vektör modelleyebilmemizi sağlayan sınıfları içeriyor. Örneğin; iki vektörü çarpacaksınız ve bunun için bir sürü döngü yazmanız gerekecek, sizi bu zahmetten kurtaracak olan çözüm sylvester.js JavaScript kütüphanesi olacaktır. Kütüphaneyi kullanmadan önce bu siteden indirebilirsiniz. Şimdi ise sizlere bu kütüphanedeki sınıfların metotlarından bahsetmek istiyorum. Çok fazla metot olduğundan dolayı sıkılacağınızı düşündüğüm için tüm metotları açıklamayacağım. Detaylı bilgiye bu siteden ulaşabilirsiniz.

Class(Sınıf): Vector

1) Vector.create(elements)
     Array elementlerinden vektör yaratır ve bu vektörü geriye döndüren bir metottur. Örnek kullanımı:

var v = Vector.create([5,2,8]);

2) add(vector)

     Eğer alıcı ile vektör aynı sayıda elementi içeriyorsa, bunlar toplanır ve bu metot tarafından geriye döndürülür. Eğer alıcı ile vektör aynı sayıda elementi içermiyorsa null geriye döndürülür.

3) distanceFrom(vector)

       Alıcıdan vektöre olan mesafeyi  pozitif değerde geriye döndürür.

a.distanceFrom(b) // |a-b| demektir..

4) isPerpendicular(vector)
     Eğer iki vektör arasındaki açı doksan derece ise yani bu iki vektör birbirine dik ise, metot geriye "true" değerini döndürür.

Class(Sınıf): Matrix(Matris)


1) Matrix.create(elements)
     Array elementlerinden matris yaratır ve bu matrisi geriye döndüren bir metottur. Elementler nested (iç içe) array olmalıdır.

var M = $M([
  [6,1,9],
  [2,4,8],
  [4,5,3]
]);

2) Matrix.Diagonal(elements)
     Array elementlerindeki diyagonal elementleri içeren kare matrisi geriye döndüren metottur.
      
var M = Matrix.Diagonal([7,1,2,5]);

// M MATRİSİ
//    7 0 0 0
//    0 1 0 0
//    0 0 2 0
//    0 0 0 5

3) Matrix.Zero(n, m)

      Bu metot, n tane satır m tane sütun içeren tüm elementleri sıfır olan bir matrisi geriye döndürür.

4) Matrix.I(n)
     Geriye nxn özdeş matrisini döndürür. 

Class(Sınıf): Line

1) intersectionWith(obj)
      "obj" ile birlikte receiver'ın (alıcının) kesişim noktasını gösteren vektörü geriye döndüren metottur. Eğer kesişim noktası yok ise geriye "null" değeri döndürülür.

2) liesIn(plane)
     Eğer line(çizgi) parametrede verilen düzlemin içerisinde ise metot, "true" değerini geriye döndürür.

3) contains(point)
     Vektör noktası receiver(alıcı) üzerindeki noktanın konumunda ise metot "true" değerini döndürür.

4) rotate(angle, axis)
    Line(çizgi)  ya da vektör olabilen alıcının(receiver), verilen eksene ve radyan cinsinden açıya göre döndürülmüş olan sonucu geriye döndüren metottur.


var L = Line.X.rotate(Math.PI/2, $V([5,0]));

var test = L.eql(Line.create([5,0], [0,1]));
//  true değerini döndürür- 90 derecelik döndürülme ile y eksenine pararlel olan Line.X parallel 

Class(Sınıf): Plane(Düzlem)

1) pointClosestTo(point)
    Verilen noktaya en yakın olan vektörü geriye döndüren metottur. 

2) distanceFrom(obj)
     Düzlem, vektör veya çizgi olabilen obj ile receiver(alıcı) arasındaki en kısa mesafeyi geriye döndüren metottur.

3) eql(plane)
      Bu metot, verilen plane(düzlem) ile receiver(alanı) aynı bölgedeki alanı gösteriyorsa "true" değerini döndürür.

Şimdi ise sizin için ASP.NET ortamında yapmış olduğum örneği inceleyelim. Öncelikle kütüphanemizi Solution Explorer' a ekliyoruz.



Aşağıda göstermiş olduğum gif uzantılı resme, bu kütüphane sayesinde istediğim nokta ve düzlemlere göre döndürme hızını da ayarlayarak molekül hareketlerine benzeyen hareketler yaptırıyorum ve bu şekilden dilediğim sayı kadar ekleyebiliyorum.




    for (var i = 0; i < 25; i++) {
            dots[i] = Vector.create([h * (Math.random() - 0.5), h * (Math.random() - 0.5), h * (Math.random() - 0.5)]);
            image = document.createElement('img');
            image.id = 'img_' + i;
            image.src = dataImage;
            document.body.appendChild(image);
            images[i] = image;
        } 


Yukarıdaki kod parçacığında, 25 tane yukarıdaki resimden kullandığım için döngümüz 25 defa çalışıyor. Random(rastgele) olarak vektör noktaları ürettim ve bu noktalara göre her resme bir id atadım.

  setInterval(function () {
            for (var i = 0; i < dots.length; i++) {
                f = (dots[i].e(3) + h) / (2 * h) + 0.1;
                images[i].style.opacity = f - 0.1;
                images[i].style.width = (50 * f) + 'px';
                images[i].style.height = (50 * f) + 'px';
                images[i].style.position = 'absolute';
                images[i].style.top = (150 - dots[i].e(2) * f) + 'px';
                images[i].style.left = (300 + dots[i].e(1) * f) + 'px';
                dots[i] = rot.x(dots[i]);
            }
        }, 22);

Yukarıdaki kod parçacığında ise, bir önceki kod parçacığında rastgele üretmiş olduğum vektörlerin noktalarını tutan dots arrayindeki noktaların genişliğini, yüksekliğini, opaklığını, pozisyonunu, tepeden ve soldan uzaklıktaki mesafesini ve şekillerin dönüş hızını ayarladım.

Ekran görüntüsü:

Proje kodları:


 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>  
 <!DOCTYPE html>  
 <html xmlns="http://www.w3.org/1999/xhtml">  
  <head>  
   <meta http-equiv="Content-type" content="text/html; charset=utf-8">  
   <title>sylvester Örnek</title>  
    <script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/sylvester/0.1.3/sylvester.js"></script>  
  </head>  
  <body style="background: #000;">  
   <script type="text/javascript">  
     var dataImage = ""  
     var dots = [], images = [], h = 800;  
     var axis = Vector.create([1.7, 1, 0.7]);  
     var rot = Matrix.Rotation(0.1, axis);  
     for (var i = 0; i < 25; i++) {  
       dots[i] = Vector.create([h * (Math.random() - 0.5), h * (Math.random() - 0.5), h * (Math.random() - 0.5)]);  
       image = document.createElement('img');  
       image.id = 'img_' + i;  
       image.src = dataImage;  
       document.body.appendChild(image);  
       images[i] = image;  
     }  
     setInterval(function () {  
       for (var i = 0; i < dots.length; i++) {  
         f = (dots[i].e(3) + h) / (2 * h) + 0.1;  
         images[i].style.opacity = f - 0.1;  
         images[i].style.width = (50 * f) + 'px';  
         images[i].style.height = (50 * f) + 'px';  
         images[i].style.position = 'absolute';  
         images[i].style.top = (150 - dots[i].e(2) * f) + 'px';  
         images[i].style.left = (300 + dots[i].e(1) * f) + 'px';  
         dots[i] = rot.x(dots[i]);  
       }  
     }, 22);  
   </script>  
  </body>  
 </html>  


Bu haftalık anlatacaklarım bu kadar, bir sonraki yazımda sizlere Reflection.js kütüphanesinden bahsedeceğim. Şimdilik görüşmek üzere, hoşçakalın...

 KAYNAKLAR


Hiç yorum yok:

Yorum Gönder