Ana içeriğe atla

Devexpress - 3 Adımda Uygulama Bazlı Dinamik LookandFeel Değişikliği

devexpress ile yaptığımız projelerde bazen çalışma zamanında(runtime) temanın değiştirilebilmesini isteyebiliriz.son kullanıcı istediği zaman combobox'ta listelediğimiz temaları programa uygulayabilir ve birdahaki değişikliğe kadar aynı temalayı kullanabilir.aşağıda göreceğimiz örnek ile bunu nasıl yapabileceğimizi göreceğiz;

öncelikle projemize bir adet settings dosyası ekliyoruz.kullanıcının seçtiği temanın adını buraya kaydedeceğiz.bu sayede 2. bir değişikliğe kadar proje en son seçilen tema ile kullanılacak.


bir form oluşturuyor ve bu forma;

1 adet combobox,
1 adet button
1 adet defaultBarAndDockingController ekliyoruz.

Not : defaultBarAndDockingController kontrolü seçili lookandfeel özelliğinin uygulama bazlı olmasını sağlar.bunun için formunuzun lookandfeel özelliğini skin olarak ayarlamanız gerekmektedir.

Not : Listelenen bazı LookandFeel skin'leri BonusSkin olarak geçer ve bunları kullanabilmek için  projenize ilgili versiyonun BonusSkins.dll dosyasını eklemeniz gerekir.Bu İşlemi program.cs dosyasına ;
DevExpress.UserSkins.BonusSkins.Register();
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
kodlarını ekleyerek yapabilirsiniz.

1- form load olayında combobox değişkenimize tema adlarını dolduruyoruz.
private void lookandfeel_Load(object sender, EventArgs e)
        {
           this.comboBoxEdit1.Properties.Items.AddRange(new object[] {
            "Metropolis",
            "Money Twins",
            "DevExpress Style",
            "DevExpress Dark Style",
            "VS2010",
            "Seven Classic",
            "Office 2010 Blue",
            "Office 2010 Black",
            "Office 2010 Silver",
            "Office 2013",
            "Coffee",
            "Liquid Sky",
            "London Liquid Sky",
            "Glass Oceans",
            "Stardust",
            "Xmas 2008 Blue",
            "Valentine",
            "McSkin",
            "Summer 2008",
            "Pumpkin",
            "Dark Side",
            "Springtime",
            "Foggy",
            "High Contrast",
            "Seven",
            "Sharp",
            "Sharp Plus",
            "The Asphalt World",
            "Whiteprint",
            "Caramel",
            "Lilian",
            "iMaginary",
            "Black",
            "Office 2007 Blue",
            "Office 2007 Black",
            "Office 2007 Silver",
            "Office 2007 Pink",
            "Blue",
            "Darkroom",
            "Blueprint",
            "Metropolis Dark"});
           }


2 - Button nesnemizin click olayına aşağıdaki kodları yazıyoruz.
//seçtiğimiz tema adını settings dosyasına taşıyoruz
     Properties.Settings.Default.lookandfeel = comboBoxEdit1.SelectedText;
//settings dosyasındaki değişikliği kaydediyoruz
                Properties.Settings.Default.Save();
// değiştirdiğimiz temanın projemizdeki tüm formlarda aktif olmasını sağlıyoruz.
defaultBarAndDockingController1.Controller.LookAndFeel.Style = DevExpress.LookAndFeel.LookAndFeelStyle.Skin;
// uygulayacağımız temayı  defaultBarAndDockingController nesnemize atıyoruz.
 defaultBarAndDockingController1.Controller.LookAndFeel.SkinName = Properties.Settings.Default.lookandfeel.ToString();

3 - proje açılışında en son seçilen aktif temanın kullanımı;

program.cs dosyamız içerisinde yapacağımız tanımlama ile en son seçilen aktif temayı program açılırken formlara uyguluyoruz.
mainForm frm = new mainForm();
frm.defaultBarAndDockingController1.Controller.LookAndFeel.Style = DevExpress.LookAndFeel.LookAndFeelStyle.Skin;
frm.defaultBarAndDockingController1.Controller.LookAndFeel.SkinName = Properties.Settings.Default.lookandfeel;

Bu makalede 3 adımda LookandFeel Teknolojisinin profesyonel olarak nasıl kullanılabileceğini görmeye çalıştık hepinize iyi çalışmalar.





Yorumlar

  1. ÜStad bende devx ile cross bi projede çalışıyorum ancak business object nesnesine otomatik sayı aldırmayı bir türlü yapamadım yardımcı olurmusunuz.

    YanıtlaSil
  2. Merhaba;

    biraz daha detay verebilirseniz yardımcı olabilirim.tam olarak ne yapmak istediğinizi belirtin lütfen.business object dediğimizde birden çok kapsamı olabiliyor çünkü.

    YanıtlaSil

Yorum Gönder

Bu blogdaki popüler yayınlar

PAYTR SANAL POS ASP.NET C# Entegrasyonu

merhaba, bu makalede sizlere PAYTR Sanal pos yapısını .NET üzerinde nasıl çalıştıracağımız ile ilgili bilgi aktarmaya çalışacağım. Ücretsiz başlangıç sağlaması ve sabit ödeme almaması sebebiyle düşük bütçeli e-ticaret yapmak isteyen kişilerin tercih ettiği PAYTR Sanal pos entegrasyonu temelde PHP üzerine kurulmuş. Dolayısıyla .net ile e-ticaret yazmaktaysanız bu sizi bir hayli zorluyor zira firma ile birçok görüşme yapmama rağmen sağlıklı bir .net örneklemesi bulamadım. Baktım olacak gibi değil, sonunda oturdum kendi entegrasyonumu kendim yazdım :). aşağıda detaylı olarak bulabilirsiniz. //using satırlarımızı ekleyelim; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.Collections.Specialized; using System.Data; using System.Linq; using System.Net; using System.Security.Cryptography; using System.Text; using System.Web; using System.Web.Script.Serialization; using System.Web.UI; using System.Web.UI.WebControls; //aşağıdaki sabit PAYTR Fonksiyon...

Devexpress SchedulerControl Kullanımı

Uzun bir aradan sonra merhaba; Sizlere bu makalede Devexpress ürününün en karmaşık kontrollerinden biri olan SchedulerControl nesnesinin kullanımı açıklamaya çalışacağım. Scheduler kontrol adındanda anlaşılacağı üzere tarihsel işlemleri görsel hale getirebileceğimiz detaylı bir kontroldür.zamanlamalı olarak randevu,görev,işlem vb. kavramları scheduler kontrol nesnesiyle kullanabiliriz.bunlarlada sınırlı değil tabiki.isterseniz Microsoft Outlook Takviminede bağlayabilir ve işlem kapsamınızı genişletebilirsiniz.Lafı fazla uzatmadan kodlamaya geçelim isterseniz. bu makaledeki bağlantı ve işlem şekilleri tamamen C# kodları ile yapılmaktadır.dataset vb. kontrolleri kullanmadım. yeni bir windows forms Projesi açalım ve boş bir forma schedulercontrol nesnesini sürükleyip bırakalım. kontrol ekranımıza yerleştiğinde alt kısımda SchedulerStorage isimli nesneyi göreceksiniz.SchedulerStorage SchedulerControl'ün çalışması için gerekli bir nesnedir zira veri işlemleri SchedulerStorage ...

Devexpress ASPxGridView içerisinde ASPxPopupControl Kullanımı

Merhaba, bu makalede sizlere; ASPxPopupControl  nesnesinin ASPxGridView  ile nasıl kullanacağına dair bilgi vermeye çalışacağım. Proje ortamında en sık karşılaştığımız işlemlerden biri, grid üzerinde düzenleme yapabilmektir.  Aslında standartta ASPxGridView  sizlere bu özelliği zaten kendi Edit modları ile sağlamakta. Fakat ASPxGridView üzerinde barındırılmayan ama bu veriler ile ilişkili olan işlemleri gerçekleştirmek için böyle bir yapıya ihtiyacımız var. Örneğin,  öğrencilerin not bilgilerini görüntülediğiniz Grid nesnesi üzerinde, sınav tarihlerini düzenlemek isteyebilirsiniz. İşte bu gibi durumlarda ASPxPopupControl kullanmamız gerekmekte. Örnekte (öğrencilere ait basit birkaç bilgi ile işlem gerçekleştireceğiz) bu işlemleri Client-Side desteğiyle nasıl gerçekleştirebiliriz ona bakalım; İlk olarak aşağıdaki gibi bir html tasarım oluşturalım;