29 Nisan 2010

Kişisel Blog'um Taşındı! (http://ekin.ozcicekciler.com)

Herkese merhaba,

Takip edenler farkedecektir, bir süredir bu adres üzerine herhangi bir post girmiyorum. Sebebi blog sistemini değiştirmiş ve farklı bir adrese taşımış olmamdır. Daha önceleri http://ekin.ozcicekciler.com/ adresini yazdığınızda bu adrese (http://ekinozcicekciler.blogspot.com/) yönlendiriliyordu. Fakat artık yeni blog sistemimi aktif hale getirdim ve bundan sonra BlogSpot üzerine değil sadece yeni sisteme (http://ekin.ozcicekciler.com/) post gireceğim. Yeni yazılarımı ve paylaşımlarımı yeni sistem üzerinden takip edebilirsiniz. Şimdiden ilginize teşekkür ederim.

Yeni Blog' a Gitmek İçin Tıklayınız!

Devamını Oku...

29 Aralık 2009

Mutlu Yıllar !

Merhaba,

Acısıyla, tatlısıyla, teknolojik gelişmeleriyle yorucu bir yılı geride bırakıyoruz. Umarım 2010 yılı sağlık, mutluluk ve başarı bakımından hepiniz için mükemmel bir yıl olur ! 2010' da görüşmek dileğiyle !


Devamını Oku...

18 Kasım 2009

Microsoft Office Mobile 2010 Beta !

Muhteşem bir haberi sizlerle paylaşmak istiyorum. PDC 2009' da Microsoft Office 2010' un Beta' sının anons edilmesinden sonra e-posta kutuma çok güzel bir haber düştü. Microsoft Office Mobile 2010 Beta !

Şu an sadece Windows Marketplace For Mobile üzerinden indirilebilen yeni mobil ofis paket çözümü gerçekten heyecan verici.

http://www.microsoft.com/office/2010/en/mobile/default.aspx adresi üzerinden yeni mobil ofis paketinin ekran görüntülerine ulaşabilirsiniz.



Uygulamayı daha deneme imkanım olmadı, biran önce Marketplace üzerinden indirip izlenimlerimi aktaracağım. Görünen o ki Microsoft Office Mobile 2010 ile ofisimiz artık daha fazla yanımızda. Örneğin Sharepoint 2010 üzerindeki dökümanlarımıza artık mobil cihazımız üzerinden de erişebileceğiz ; direk e-posta olarak gönderebileceğiz. Alttaki ekran görüntüsünün Windows Mobile 7.0' dan alındığını dikkatinizi çekerim ! Bu güzel haber.



Uygulama detayını
http://marketplace.windowsphone.com/details.aspx?appSKU=a226f64c-d514-4d91-85df-a512bc37c1cd&retURL=/search.aspx%3Fkeywords%3D2010 adresinden de inceleyebilirsiniz.

Devamını Oku...

23 Ekim 2009

Visual Studio 2010 - Mobile Development ?!

Merhaba,

Bilindiği üzere geçtiğimiz günlerde Visual Studio 2010 'un Beta 2 sürümü yayınlandı. Fakat, uzun bir indirme süreci ve ardından heyecanlı bir kurulumun ardından mobil uygulama geliştiricileri kötü bir süpriz beklemekteydi : Visual Studio 2010 Beta 2 üzerinde mobil uygulama geliştirebilmek için gereken tüm araçlar kaldırılmış !

Bu konu ile ilgili gelen heyecanlı ve korku dolu sorular ardından minik bir araştırma yaptım ve mobil uygulama geliştiricilerin içini rahatlatacak o güzel haberi sizlerle paylaşmak istiyorum ;

Visual Studio 2010 Beta 2 does not support Smart Device Development.

Microsoft is committed to making Visual Studio a great development tool for the mobile device developer, and will deliver mobile device tools for Visual Studio 2010, but cannot share details now. For existing Visual Studio 2008 mobile developers, Microsoft released the Windows Mobile 6.5 Developer Tool Kit that works with the Windows Mobile 6 SDK.

Because Visual Studio 2010 Beta 2 does not support Smart Device Development, you cannot use the following features: .NET Compact Framework projects, Visual C++ device projects, smart device CAB projects, Device Emulator and Device Emulator Manager, testing tools for device projects, and Device Security Manager.

Smart device development is still supported in earlier versions of Visual Studio, such as Visual Studio 2008. For the more information about smart device projects, see Windows Mobile Developer Center and Smart Device Development in Visual Studio 2008.

Yukarıdaki paragraf MSDN üzerinden alınmıştır.

Kısaca "değişik birşeyler üzerinde çalışıyoruz, daha yetiştiremedik ama az kaldı" demişler. Yani çıkartılan birşey yok. Rahat olun :)

Devamını Oku...

4 Ekim 2009

GPS Framework for .NET ! Ücretsiz !

Merhaba,

Geçen hafta beni hem sevindiren hem de global krizin boyutunun ne derece devam ettiğinin resmini çok açık bir şekilde gösteren bir mail aldım. Device Application Development MVP Mail Grubu üzerinden gelen bir haberden öğrendiğim üzere, uzun zamandır GPS sektöründe şahsımca takip ettiğim ve inanılmaz başarılı bileşenler geliştiren ve binlerce dolara satmasına rağmen bu noktada ihtiyaç duyan birçok firma tarafından bileşenleri satın alınan GeoFrameworks firması Global Kriz' in etkilerine dayanamamış ki kapılarını artık kapatmaya karar vermiş.

Fakat kapılarını kapatırken hatırı
"ciddi" anlamda sayılır bir iz bırakarak ticaret hayatını noktalamış ; bu zamana kadar binlerce dolara satılan GPS üzerine geliştirdiği GPS Framework for .Net paketinin şu ana kadar geliştirilen tüm sürümlerini CodePlex üzerinden "ücretsiz" olarak uygulama geliştiricilerin kullanımına bırakmış ! Süper !

Belki aylarca uğraşılarak hazırlanmış bir paketin ücretsiz olarak uygulama geliştiricilerin kullanımına ve geliştirilmeye bırakmak şahsımca saygı duyulacak bir davranış.

Masaüstü ve mobil cihazlar üzerinde GPS tabanlı uygulamalar geliştiriyor ve hazır bir kütüphaneye ihtiyaç duyuyorsanız kaçırmamanızı tavsiye ederim.

Detayları ;



http://gps3.codeplex.com

adresi üzerinden takip edebilir, paketin tamamını "ücretsiz" olarak bu adres üzerinden indirebilirsiniz.

Devamını Oku...

Windows Mobile Widget Emulator

Merhaba,

Windows Mobile 6.5' un tam olarak piyasaya çıkmamış olması ve bu konu hakkındaki dökümantasyonun çok sınırlı olması sebebiyle muhtemelen Türkiye' de Windows Mobile Widget' ları ile ilgili birtek ben belirli bir efor sarfediyorum. :)

Yakın zamanda ne kadar önemli olduğunu anlayacağımız bu konu ile ilgili yazmaya, türkçe kaynak oluşturmaya devam edeceğim. Ve yine çok yakın zamanda bu konu ile ilgili süpriz bir aktiviteyide buradan bildireceğim.

Yazımızın içeriğine gelirsek bilindiği üzere geliştirilen widget' ları şu aşamada yanlızca Windows Mobile 6.5 emulatörleri üzerinde test edebilmekteyiz. (Eğer Internet üzerinden desteklenmeyen ortamlardan kullanıcıların hazırladığı bir ROM' a sahip değilseniz :) ) Bu test süreci birkaç aşamadan oluşmaktadır. Öncelikle widget için hazırladığınız dosyaları *.zip haline getirmeniz gerekmekte. Bir sonraki aşamada bu *.zip uzantısını *.wgt ya da *.widget olarak değiştirmeniz gerekmekte ve bu dosyayı emulatör üzerinde kopyalayıp (bu kopyalama işleminide emulatör ile paylaşımlı bir klasör üzerinden gerçekleştirebilirsiniz) gerekli kurumları yapmanız gerekmekte. Ayrıca bir önce test' ten kalan kurulumunuzu kaldırmanız ve yeni halini kurmanız test' i daha stabil kılmaktadır.

Her seferinde bu süreç can sıkıcı olabildiğinden geçen hafta tam ihtiyaç duyulan bir çalışmaya CodePlex üzerinde rastladım ; Windows Mobile Widget Emulator !

CodePlex üzerinde açık kaynaklı olarak gelişimine devam eden çalışma, kullanıcılara geliştirdikleri Windows Mobile Widget' ları Emülatör' e kurmaya gerek kalmadan "sanki mobil cihaz üzerinde çalıştırılıyormuş gibi" test imkanı sağlamaktadır.



Örneğin CodePlex üzerinden alınan yukarıdaki ekran görüntüsün, geliştirilen bir widget' ın masaüstü ortamında Windows Mobile Widget Emulator ile çalıştırıldığı görülmektedir. Süper !

Peki Nasıl Kullanacağız ?

http://widgetemulator.codeplex.com/Release/ProjectReleases.aspx?ReleaseId=31211 adresinden gerekli paketi indirdiğimizde aşağıdaki ekran görüntüsündeki dosyalar paketin içinden çıkmaktadır.



  • assests klasörü uygulamanın çalıştırılabilmesi için gereken sistemsel dosyaları içermektedir.
  • widgets klasörü "geliştirdiğimiz widget' ı paketlemeden yerleştireceğimiz" bölgedir.
  • index.htm ise widget' ımızı test edeceğimiz standart bir HTML dosyasıdır.
Yukarıda da belirttiğimiz üzere geliştirdiğimiz widget' ı "paketlemeden" widgets klasörü içerisine yerleştirmemiz gerekmektedir. Sadece bu kadar !

Javascript Widget API ?

Widget' ın masaüstü tarayıcısı içerisinde çalıştırılması sonucunda maalesef Javascript Widget API standart olarak desteklenmemektedir. Javascript Widget API' nin kullanılması durumunda ise yapmanız gereken tek şey Widget' ınızı içerisinde kullanıyor olduğunuz HTML Dosyası içerisinde "assets" klasörü içerisinde bulunan "widget.js" ' ye referans vermeniz olacaktır.



Ve Son Olarak...

Widget' ımızı test etmeye geçmeden son olarak kök klasör içerisinde bulunan Index.htm dosyası içerisinde bulunan IFRAME' in src attribute' unu widget'ımızın kaynak HTML dosyasına işaret edecek şekilde değiştirmemiz gerekmektedir.



Peki bu uygulama vasıtasıyla başka nelere sahip olmaktayız ? Normal şartlarda emülatörler tek çözünürlüğe sahip cihazları simule etmektedir. Windows Mobile Widget Emulator sayesinde widget' larınızı farklı çözünürlüklerde test edebilmektesiniz ! Ayrıca yatay / dikey görünümlerde de test edebilmektesiniz !



İşte Bu Kadar !


Devamını Oku...

28 Eylül 2009

*.widget Uzantısının Tanıtılması

Hali hazırda geliştiriyor olduğumuz widget' ları *.widget uzantılı kaydedip emulatör dışında gerçek bir cihazda test etmeye çalıştığımızda *.widget uzantısının sistem tarafından tanınmadığını, widgetinstaller tarafından çalıştırılmadığını görmekteyiz.

Windows Mobile 6.5 emulatörlerinde bu tanımlama yapılmış olmasına rağmen şu aşamada kurulan ROM' lar üzerinde yapılan denemelerde *.widget uzantısının tanınmadığı görülmektedir.

Bunun önüne geçebilmek için Visual Studio Remote Tools içerisinde bulunan Remote Registry Editor aracı ile takılı olan cihazımıza bağlanmak ve registry' si içerisine aşağıda tanımlı olan key' leri yazmamız gerekmektedir.

[HKEY_CLASSES_ROOT\riapp]
"EditFlags"=dword:00010000
[HKEY_CLASSES_ROOT\riapp\Shell\Open\Command]
@="wmwidgetinstaller.exe %1"

(@ İşareti Default Key olarak isimlendirilen key' i temsil etmektedir)



(EditFlags dword Değeri)



riapp altında sırasıyla Shell -> Open -> Command key' i altında tanımlı olan Default Key değeri.


Devamını Oku...

Windows Mobile 6.5 – Widget System State

Windows Mobile 6.5 üzerinde geliştirilen widget’ larda yararlanılabilecek bir başka nokta ise bir önceki yazımızda ifade ettiğimiz “widget” javascript objesi üzerinden oluşturulabilecek SystemState objesidir. SystemState objesi vasıtasıyla geliştirdiğiniz widget’ lar içerisinden “bazı belirli” sistemsel özelliklerin değerlerine ulaşabilir, bu değerlerin değiştiğini algılayabilir ve istenilen kod bloklarını çalıştırabilmektesiniz. Aşağıdaki listede SystemState objesi üzerinden ulaşılabilecek değerlerin bir listesi listelenmiştir.

CradlePresent – Cihazın “cradle” (cihazın bilgisayarınız ile olan fiziksel bağlantısı) üzerine takılıp takılmadığının değerini döndürür.

DisplayRotation – Ekranın anlık görüntüsünün kaç derecelik bir açıyla gösterildiğinin değerini döndürür. (0 – 360 Derece Arası)

PhoneHomeService – Cihazın anlık network ile kayıtlı olup olmadığının değerini döndürür.

PhoneOperatorName – Cihazın anlık network (operatör) isim değerini döndürür.

PhoneRomaing – Cihazın anlık olarak “Roaming (Yurtdışında farklı bir operatör üzerinden bağlantı)” içerisinde olup olmadığının değerini döndürür.

PhoneSignalStrength – Cihazın operatör ile arasındaki bağlantı kalitesinin değerini yüzdelik olarak döndürür.

PowerBatteryState – Cihazın anlık batarya güç değerini düşük, güçlü, orta şeklinde tanımlı değerlerinin numerik karşılıklarını döndürür.

PowerBatteryStrength – Cihazın anlık batarya güç değerini yüzdelik değer olarak döndürür.

Sıra geldi widget’ ı çalıştıracak olduğumuz fiziksel mobil cihazımız üzerinde widget üzerinden bu değerlerin alınmasına. Konfigurasyon dosyamız daha önceki yazımızda olduğu gibi aşağıdaki şekilde tanımlanmış, config.xml isim ve dosya uzantısıyla kaydedilmiştir. Konfigürasyon (manifest) dosyasının dışında, bu dosya içerisinde belirlenen ikon (*.png uzantılı) ve kaynak HTML dosyası da konfigürasyon dosyası ile birlikte aynı lokasyona yerleştirilmiştir.

(Resimlerin büyük halleri için üzerilerine tıklayınız)



Hiç vakit kaybetmeden kaynak olarak kullanılacak olan HTML dosyasının içeriğini hazırlıyoruz. Yukarıda bahsedildiği üzere amacımız geliştirdiğimiz widget içerisinden bize izin verilen ölçüde bazı sistemsel değerleri çekmek ve widget içerisinde uygun yerlerde görüntülemektir. Bu noktada bu değerlere ulaşabileceğimiz SystemState objesini widget javascript objesinin createObject fonksiyonuna “SystemState” değerini gönderek oluşturuyor ve ss isminde bir değişkende tutuyoruz. Bir sonraki aşamada ise ss isimli SystemState değişkeni üzerinden yukarıdaki tabloda isimleri verilen özelliklere ulaşıyor ve bu özelliklerin değerlerini aşağıdaki ekran görüntüsünde gösterildiği üzere bir div içerisinde görüntüleyecek javascript fonksiyonunu oluşturuyoruz.

Bu fonksiyonu ise HTML dosyamız içerisinde oluşturduğumuz button kontrolünün client side click event’i (onlick) tetiklendiğinde çağırıyoruz. İşte bu kadar !

Widget’ ımızı paketlemeye geçmeden önce ihtiyaç duyabileceğimiz önemli bir konuya daha dikkat çekmemiz gerekiyor. Değişikliklerin algılanması. Ya biz yukarıda listelenen sistemsel değerlerin herhangi birinde bir değişiklik olduğunda bu değişiklikten haberdar olmak ve bir javascript fonksiyonunu çalıştırmak istiyorsak ?

Bu ihtiyacın çözümü için yukarıda listelenen SystemState değerleri içerisinde çok basit bir yöntem bulunmaktadır. Değişikliğini algılamak istediğiniz SystemState değerinin üzerinden Javascript addEventListener fonksiyonu ile “changed” olayını yakalayan kod bloğunu aşağıdaki ekran görüntüsündeki gibi ekliyoruz. “changed” yani değişiklik durumu söz konusu olduğunda ise addEventListener fonksiyonunun ikinci parametresinde verilen fonksiyon olan “Degisti” fonksiyonu otomatik olarak çağırılacaktır. Örneğimizde telefonun güç değeri değiştiğinde ekrana mesaj kutusu getiren bir kod bloğunu ekliyoruz.

Daha önce yazdığımız SistemOzellikleriniYukle fonksiyonu içerisine EventHandler’ ımızı ekliyoruz. Ardından bu EventHandler içesinde işaret edilen “Degisti” isimli Javascript fonksiyonumuzu yazıyoruz.

Sıra geldi widget’ ımızı paketlemeye. Tüm gerekli dosyaları seçip zipledikten sonra uzantısını *.widget ya da *.wgt olarak değiştiriyoruz.

Widget’ a mobil cihaz emulatörümüz üzerinden erişip kurulum işlemlerine başlıyoruz.

Widget’ ın başarılı bir şekilde kurulmasından sonra çalıştırıp sayfa içerisindeki button kontrolüne tıklıyoruz ! Hepsi bu kadar !



Emulatör ayarlarından batarya gücünü azaltıyoruz.



OK’ e tıkladığımızda değişikliğin algılandığını ve mesaj kutusunun ekrana geldiğini görüyoruz ! İşte bu kadar !



Hazırladığımız örnek widget’ ı ve diğer dosyaları buradan indirebilirsiniz. Bir başka yazıda daha görüşmek üzere.

Devamını Oku...

23 Eylül 2009

Windows Mobile 6.5 - Widget Javascript Object

Daha önce de konuştuğumuz üzere Windows Mobile 6.5 (WM 6.5) üzerinde uygulama geliştiriciler için gelen en büyük yeniliklerden bir tanesi hiç şüphesiz Widget olarak isimlendirilen, ilk olarak Windows Vista üzerinde Gadget olarak karşımıza çıkan ve standart bildiğimiz web teknolojilerini (HTML, Javascript, CSS) kullanarak geliştirebileceğimiz uygulama parçacıklarıdır. Geliştirdiğimiz Widget’ ların, dinamik bir yapıya sahip olmasını istediğimizde ise elimizdeki tek olanak Widget içerisinde yazabilecek olduğumuz Javascript kod bloklarıdır.

Windows Mobile 6.5 üzerindeki Widget geliştirirken, Javascript kod bloğu içerisinden erişebileceğimiz, widget metadata' ’ına ulaşabileceğimiz, widget menülerini belirleyebileceğimiz ve widget ikon özelliklerine ulaşabileceğimiz bir Javascript objesi bulunmaktadır ; widget !

Widget Javascript objesine widget içerisinde kullanıyor olduğumuz HTML dosyasının içerisinden Javascript kod blokları arasında ulaşabilmekteyiz. Bu obje vasıtası ile widget hakkında birçok bilgiye sahip olabilmekteyiz. Bu yazımızda ise, widget javascript objesini kullanarak widget metadatasına ulaşabilmemiz noktasında bir örnek üzerinde çalışacağız.

Bilindiği üzere Widget’ lar xml içerikli manifest olarak isimlendirilen “konfigurasyon” dosyalarına sahiplerdir. Bu dosyalar vasıtası ile widget içerisindeki gereken tüm bilgilere işletim sistemi tarafından ulaşılır ve widget gerektiği şekilde gerektiği kaynaklar kullanılarak çalıştırılır. XML içerikli bu manifest dosyasının içerisine nelerin yazılabileceğini daha önceki yazılarımızda detaylıca incelemiştik.

Örneğimizde aşağıdaki manifest dosyasını kullanan bir widget üzerinde çalışıyor olacağız.

Yukarıdaki konfigurasyon dosyasında, widget root elementi içerisinde widget ile ilgili gerekecek tüm konfigurasyon değerleri tanımlanmıştır. Widget çalışma zamanında bu değerlere Javascript ile ulaşabilmek için, “sadece wm 6.5 widget’ lar içerisinden kullanılabilecek bir javascript objesi olan widget objesinin kullanılması gerekmektedir. Aşağıdaki örnekte, yukarıdaki konfigurasyon dosyası içerisinde content olarak belirlenen WidgetContent.html dosyası içerisinde bir javascript kod bloğu tanımlanmış, kod bloğu içerisinde ise sayfa üzerine yerleştirilmiş bir div’ in içeriği widget objesi kullanılarak widget bilgileri ile değiştirilmektedir.



Yukarıdaki javascript kod bloğu, sayfa içerisine yerleştirilen bir button’ a tıklandığında client side olarak çalıştırılmaktadır. Kod bloğu içerisinde anlaşılabileceği üzere widget olarak isimlendirilen objeye direk olarak ulaşılabilmekte, widget manifest dosyası içerisindeki tüm bilgilere bu obje üzerinden ulaşılabilmektedir. Ayrıca bu yazımız içerisinde incelemediğimiz menu ve currentIcon özellikleri bir başka yazıda incelenecektir.



(Resmin Büyük Hali İçin Üzerine Tıklayınız)

Widget’ ı hızlıca paketliyoruz (Gerekli dosyaları seçip zip dosyası haline getiriyoruz, daha sonra uzantısını *.wgt ya da *.widget olarak değiştiriyoruz) ;



Widget’ ı Windows Mobile 6.5 emulatör’ ü üzerinden cihaza yüklüyoruz ve çalıştırıyoruz ;



Widget’ ı yüklüyoruz ;



Ve widget’ ı çalıştırıyoruz ;

Ve sonuç ! Uygulama çalıştırıldığında tüm bilgilere widget objesi üzerinden ulaşabilmekteyiz. Bir başka yazıda daha görüşmek dileğiyle.

Örnek uygulamayı buradan indirebilirsiniz !

Devamını Oku...