06 Nis 2007 Bana Makale Yaz ! Kategori: Benden Etiketler: ASP.NETASP.NET Ajax 9 Yorum Merhabalar arkadaslar;Bu fikri daha önce bir kaç sitede görmüstüm. Sizlere daha çok yardımcı olabilmek için bende böyle bir yenilige gittim.Hepimize hayırlı olması dilegiyle (:"Bana Makale Yaz" diyorsanız iletisim formundan bana ulasabilirsiniz...
06 Nis 2007 XAML’i Tanıyalım… Kategori: .NET Framework Etiketler: .NET Framework 3 Yorum Yeni bir şey öğrenme arzusu bende her zaman çok büyük heyecanlar yaratmıştır. Framework 3.0’ı makinama ilk kurduğumda ve daha sonra yaptığım araştırmalarda karşıma çıkan ilk şey XAML oldu. Katıldığım bir seminer de bir ustamızın “buton programcılarının devri bitti, XAML, BAML geliyor” demesi ile de başladım araştırmalara ve sonuçta bu makale çıktı ortaya (: Bu makalemiz de anladığınız üzere XAML’i ve bize kazandırdıklarını anlatacağım.Kısaca WPF Windows Presentation Foundation (WPF), windows isletim sistemleri için arayüzler gelistirmek için tasarlanmıstır. Zengin kullanıcı arayüzleri olusturabilmek için bizlere çok büyük kolaylıklar saglar. Windows Presentation Foundation (WPF), web uygulamalarındaki gibi windows uygulamaları gelistirmemizi saglıyor. Windows Presentation Foundation (WPF), Windows XP, Windows Server 2003 ve Vista sistemlerinde çalısıyor fakat genel olarak Vista için gelistirilmisdir. Daha detaylı bilgi için http://wpf.netfx3.com adresine bakınız.XAML Nedir?EXtensible Application Markup Language (XAML), Zamel olarak okunan ve .net uygulamaları için statik yada dinamik kullanıcı arayüzleri olusturmak için microsoftun gelistirmis oldugu yeni bir markup(isretleme) dilidir. XML tabanlı çalısır ve XML'in tüm özelliklerini kullanır. Uzantısı *.xaml dir. XAML, Windows Vistada Kullanıcı arayüzleri olusturmak için kullanılır fakat Windows XP veya Windows Server 2003'de uygulanabilir.XAML, Uygulama kodundan kullanıcı arayüzü kodundan ayırmak için geldi. Bu yapı Javanın kullandıgı MVC(Model View Controller)'a çok benzer. XAML, Windows vista ve .NET 3.0 ile uygulamalar gelistirmek için WPF'e baglıdır. XAML aynı XML gibidir. XML'in tüm özelliklerini kullanır. XML için geçerli olan tüm kurallar XAML içinde geçerlidir. Örnek olarak baslatılan her element sonlandırılmak zorundadır yada büyük küçük harf duyarlılıgı. Her bir XAML Elementi .NET CLR Class'ını temsil eder. XAML'in WPF ile birlesmesi yazılımcılar için zengin kullanıcı arayüzleri gelistirmelerini saglıyor, bu ASP.NET deki code behind ile code inline modeline benziyor. Yani ister ayrı bir dosya içerisine yada inline olarak uygulama kodlarını yazabiliriz. Yani uygulama katmanı ile sunum katmanını tamamen birbirinden bagımsız hale getirebiliyoruz.XAML, BAML dosyalarını derler. BAML XAML'den daha küçüktür ve okumak için daha basittir bu yüzden yüklenmesi çok hızlıdır.XAML ElementleriHer bir XAML Elementi .NET CLR Class'nı temsil eder. Çogu XAML elementi System.Windows.UIElement, System.Windows.FrameworkElement, System.Windows.FrameworkContentElement and System.Windows.ContentElement'den inherit edilir. Ø Root Elementleri : Windows ve Page elementlerini root elementini çok sık kullanır. Bu elementler diger elementleri içerir ve XAML dosyaları için root elementtir.Ø Panel Elementleri : Bu elementler kullanıcı arayüzleri için layoutlar saglar. Temel panel elementleri StackPanel, DockPanel, Grid ve Canvas' dir.Ø Control Elementleri : Bu element XAML kontrollerinin farklı tiplerini tanımlar ve onları kisisellestirmemizi saglar.Ø Geometric Elementler : Bu element arayüzümüz üzerinde geometric grafikler ve sekiller çizmemize yardım eder. Bazı Geometric elementler; LineGeometry, EllipseGeometry, PathGeometry ve LineSegment' dir.Ø Document Elementleri : Bu elementler dökümanın sunumu istendiginde isimize yarayacaktır. 2 ana grubu vardır. Inline ve Block elementler. Bazı inline elementler; Bold, LineBreak ve Italic. Bazı Block elementler; <p>, <table> ve <i> gibi HTML Elementleridir.Stack Panel Kullanımına bir örnek;<StackPanel> <Button Content="Dokunma Bana (:"/></StackPanel>XAML AttribututelariXAML attributeları .net Classındaki Properties'lerle aynıdır... Inline yada Expcilit attribute tanımlayabiliriz. Her attributet ana elementin özelliklerini inherit eder yada onları override eder. Bazı XAML elementleri diger elementler içinde onların özelliklerini alır. Bunlara Attached Properties attributetelar denir.XAML Syntax;<Button> <Button.Background> <SolidColorBrush Color="Blue"/> </Button.Background> <Button.Foreground> <SolidColorBrush Color="Red"/> </Button.Foreground> <Button.Content>This is a button </Button.Content> </Button>Bir buton olusturduk ve özelliklerini belirledik. Ilk element nesnenin tipini belirtiyor. <NesneTipi> Alt elementlerde nesne tipini ve nesne tipinin özelligini yada eventini belirtir. belirtiyor. <NesneTipi.[Özellik, Event]>Neden XAML?Ø Kullanıcı arayüzleri olusturmak XAML ile çok basittir.Ø Önceki UI Dizayn teknikleri için kullanılan kodlardan daha kısadır.Ø Dizayn edilen arayüz diger ortamlarda tasınması ve sunulması basittir. Örnegin Web yada Windows uygulamaları üzerinde gelistirdigimiz arayüzleri kullanabiliriz.Ø Dinamik arayüz gelistirmek XAML ile çok kolaydır.Nasıl XAML Gelistiririm?Windows Vista, Windows XP ve Windows server 2003 ile XAML ve WPF gelistirebiliriz. Visual Studioda XAML ve WPF gelistirmek için WinFX SDK ve Visual Studio 2005 Extensions for WinFX kurulum dosyalarını indirmemiz ve kurmamız gereklidir. WinFXSDK'yı yükleyerek XAML için gelistirme aracına sahip olacagız. Visual studio extension ile de gelismis bir debuging mekanizmasına sahip olacagız. ÖRNEKEvet, ilk XAML uygulamamızı gerçeklestiriyoruz. Ben gerçekten çok heyecanlıyıım (: Visual Studio'u çalıstıralım ve yeni bir proje olusturalım;NET Framework 3.0 adında yeni bir proje tipi geldigini görüyoruz. Burada WPF ile ilgili yeni proje tipleri yer almaktadır. Biz Windows Application (WPF)'i seçiyoruz.Yukarıda da belirttigimiz gibi form desing'i için gerekli kodlar Xaml içerisinde tutuluyor. Kodlarımızı yazacagımız kısım ise yine *.xaml.cs içerisinde olacak. Bu örnegimiz içerisinde bir button'a tıkladıgımızda textbox içerisinde o anki saati görüntüleyecegiz. Formum üzerine toolbox penceresinden bir button ve textbox ekliyorum.Farklo kontrollerin ve kontrol tablarınında eklendigini görüyoruz. Bunlarıda ilerleyen zamanlardas sizlere aktarıyor olacagım.Kontrollerimizi forma ekledikten sonra aynı html deki gibi tüm propertyleri ve eventleri geldi. Button için yeni bir event yazalım. Önce Xaml tarafında bunu belirleyelim. <Button Height="20" Margin="119,0,38,84.5" Click="AbiSaatKac" VerticalAlignment="Bottom"> Saat Kaç ?</Button> Butona tıklandıgında AbiSaatKac isimli metoda gidecek ve onun altına yazacagımız kodları çalıstıracak. Simdi formun code kısmına gidelim. void AbiSaatKac(object sender, RoutedEventArgs e){ MyTextBox.Text = DateTime.Now.ToShortTimeString();}Yukarıdaki metodu olusturdum. Butona tıkladıgımızda Textbox içerisine o anki saati yazacak.Butona tıklayalım;Bu makalenin de sonuna geldik, Olumlu ve olumsuz tüm görüsleriniz için simdiden tesekkür ederim.Örnek Kodlar için mail adresimi kullanabilirsinizinfo@semgoksu.comSem GÖKSU www.semgoksu.com | www.yazilimgunlugu.com sem.goksu@yazilimgunlugu.com Kaynaklarmsdn.com
04 Nis 2007 Microsoft, Türkiyeden, İzmirden bir şirketi satın aldı! Kategori: Yazılım Etiketler: Microsoft 0 Yorum Microsoft, devBiz firmasını satın aldı. Team Foundation Server için gelistirdikleri TFSe web üzerinden erisimi saglayan TeamPlain ürününü bundan sonra ücretsiz olarak indirebilecegiz. Ayrıca simdiki adı TeamPlain olan yazılım VSTSin sonraki sürümlerinde Team System Web Access ismi ile bu ürüne dahil olarak gelecek. Bu isin dünyada ki tüm yazılım gelistiriciler ve VSTS kullanıcıları için güzel tarafı. Bizim için güzel tarafı ise devBiz firması bir Türk firması. 3-4 sene önce tanısmıstık sirketin iki kurucusu ile simdi öyle olmadıkları muhakkak ancak o zaman bir kaç kisilik küçük bir sirket idi. devMail ve çesitli diger basarılı .NET componentleri ile önce .NET dünyasında bilinen component saglayıcı firmalardan birisi oldular. Team Foundation Server üzerine gelistirdikleri ürünler ile sirketin bilinirligi biraz daha arttı sanırım. Microsoft müsterilerinden aldıgı yogun istekler sonucunda Team Foundation Server için bir Web Client saglamaya karar vermis ve bunun için zaten bu isi yapan devBiz firmasını satın alarak ürünü ücretsiz olarak yayınlamıs. Bundan sonra devBiz ekibi, Microsoft çalısanı olarak tüm Microsoft kaynaklarını kullanarak TeamPlain ürününü gelistirmeye devam edecek ve daha da güzel bir ürün ortaya çıkacagından eminim. Bu sevinci paylasmanız için sizlerle paylasmak istedim. Izmirli firmayı bu büyük basarısından ötürü tebrik ederim. http://www.devbiz.com/acquisition.aspx http://www.theserverside.net/news/thread.tss?thread_id=44786 Kaynak: http://www.cengizhan.com/CommentView.aspx?guid=eda4b882-9e18-473c-af12-ac243c2837a1
27 Mar 2007 ASP.NET Custom Control Geliştirme – Karakter Sayan Textbox Kategori: ASP.NET Etiketler: ASP.NETC# 5 Yorum Merhaba arkadaşlar, custom controller dizisi makalesine textbox içerisine girilen karakterleri sayacak ve bu textbox’ı limitlendirecek yeni bir kontrol yazacağız…Karakter Sayan Textbox Bazı durumlarda textbox içerisine girilecek karakter sayısı bizim için önemli olabilir. Bu durumlar da textbox içerisindeki karakter sayısını kontrol edip kaç karakter girdigimizi kontrol etmemiz gerekir. Örnegin firmamız için bir sms gönderme programı yazıyorsak bu bizim için çok önemlidir. Toplu sms gönderimi yaparken kullanıcılara gönderilecek sms'in tek seferde yani en fazla 160 karakter girilerek gönderilmesi gerekir. Iste biz bu sorunu çözmek için hem limitlenen hemde karakter sayan bir textbox yazacagız. Ilk olarak yeni bir web control library projesi olusturalım. Evet, projemizi olusturduktan sonra kodlamaya baslıyalım. using System; using System.Collections.Generic; using System.ComponentModel; using System.Text; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; namespace SemControls { //Ilk olarak toolbox'da kontrolümüze verilecek ismi belirliyoruz.. [DefaultProperty("Text")] [ToolboxData("<{0}:SemLimitliTextbox runat=server></{0}:SemLimitliTextbox>")] public class SemLimitliTextbox : WebControl { string _KarakterLimiti; string _Text; // Kontrol olusturulurken textbox içerisindeki karakteri sayacak ve bunu sınırlandıracak olan javascript kodunu yaziyoruz. protected override void OnInit(EventArgs e) { string script = ""; script += "<script language=\"javascript\">"+System.Environment.NewLine; script += "function textCounter(field, countfield, maxlimit)" + System.Environment.NewLine; script += "{if (field.value.length > maxlimit) field.value = field.value.substring(0, maxlimit);" + System.Environment.NewLine; script += "else countfield.value = maxlimit - field.value.length; }" + System.Environment.NewLine; script += "</script>"; if (!this.Page.IsClientScriptBlockRegistered("SemLimitedTextbox")) { this.Page.RegisterClientScriptBlock("SemLimitedTextbox", script); } } // Property penceresine LimitliTextbox grubu altında karakterLimiti adında yeni bir özellik ekliyoruz. Bu bizim textboxımızı limitlendirecek [Category("LimitliTextbox")] [Browsable(true)] [Description("Textbox'a kaç karakter girilsin?")] public string KarakterLimiti { get { return _KarakterLimiti; } set { _KarakterLimiti = value; } } // Property penceresine LimitliTextbox grubu altında Text adında yeni bir özellik ekliyoruz. Bu bizim textboxımızın text özelligi olacak. [Category("LimitliTextbox")] [Browsable(true)] [Description("Textbox'ın Text'i")] public string Text { get { return _Text; } set { _Text = value; } } //Simdi kontrolümüzü olusturuyoruz. protected override void Render(HtmlTextWriter writer) { try { string LimitedTextbox = ""; LimitedTextbox += "<textarea rows=3 name=LimitliTextbox onKeyDown=\"textCounter(this.document.all.LimitliTextbox,this.document.all.KarakterSayisi,"+KarakterLimiti+");\""; LimitedTextbox += "onKeyUp=\"textCounter(this.document.all.LimitliTextbox,this.document.all.KarakterSayisi," + KarakterLimiti + ");\" cols=38 tabindex=5>"+Text+"</textarea>"; LimitedTextbox += "<br/>"; LimitedTextbox += "<input readonly type=text name=KarakterSayisi size=4 maxlength=3 value=\"" + KarakterLimiti + "\" style=\"font-family: Tahoma; font-size: 8pt; border: 1px solid\">"; LimitedTextbox += "<font color=#6699CC face=Verdana size=1> Karakter Daha Yazabilirsiniz...</font>"; writer.RenderBeginTag(HtmlTextWriterTag.Div); writer.Write(LimitedTextbox.ToString()); writer.RenderEndTag(); } catch { writer.RenderBeginTag(HtmlTextWriterTag.Div); writer.Write("Kontrol Olusturulamadı..."); writer.RenderEndTag(); } } } } Kontrolümüzü olusturduktan sonra; projemize yeni bir web site ekleyelim. Daha sonra Web projesinin referanslarına bu web control libraryi ekleyelim. Simdi toolboxımıza gidelim bakalım kontrol gelmismi? Sem Limitli textbox kontrolü gelmis. Sayfamıza yeni bir SemLimitliTextbox ekliyelim ve özelliklerini ayarlıyalım... Textbox içerisine en fazla 100 karakter girilsin. Simdi web projemizi çalıstıralım. Simdi textbox içerisine birseyler yazalım. Gerçekten de sayıyor. : ) Bu makalemizinde de sonuna geldik. Tesekkür eder iyi çalısmalar dilerim. Sem GÖKSUMCP | MCAD.NET | MCTS | ASP.NET MVP Örnek Kodlar için mail adresimi kullanabilirsinizsemgoksu@semgoksu.com Kaynaklar www.codeproject.com
25 Mar 2007 Tebrikler Türkiye... Ne Oldu Yunanlı? Kategori: Genel Etiketler: FutbolVatan&Millet 4 Yorum