7 Aralık 2017 Perşembe

c# Uygulama bilgisayarda bir defa çalışması için kontrol




Control to prevent the application from opening twice;

Uygulamamızın Bilgisyarda aynı anda iki defa çalışmasını engellemek için :

foreach (var item in System.Diagnostics.Process.GetProcessesByName(System.Diagnostics.Process.GetCurrentProcess().ProcessName))
                {

                    if (item.Id != System.Diagnostics.Process.GetCurrentProcess().Id)
                    {
                        item.Kill();
                        item.Close();
                    }

                }

20 Eylül 2017 Çarşamba

WPF CodeBhind set Style

StyleLabel0 = (Style)System.Windows.Application.Current.Resources["dxLabelBaseStyle"]; 
     
StyleLabel1 = (Style)System.Windows.Application.Current.Resources["dxLabelBaseStyle"];

           

14 Eylül 2017 Perşembe

WPF DataTrigger Binding Visibility

 <dxlc:LayoutGroup Visibility="Collapsed"  >
         <dxlc:LayoutGroup.Style>
                <Style TargetType="dxlc:LayoutGroup">
                                            <Style.Triggers>
                                                <DataTrigger  Binding="{Binding ElementName=hesapTip,Path=SelectedItem.Alan}" Value="DEGER">
                                                    <Setter Property="Visibility" Value="Visible" />
                                                </DataTrigger>
                                            </Style.Triggers>
                                        </Style>
                                    </dxlc:LayoutGroup.Style>
</dxlc:LayoutGroup>

7 Haziran 2017 Çarşamba

DevExpress WPF GridControl: Adding a ComboBox to a column, binding it to a collection of the row's data

<dxg:GridColumn Header="bb" FieldName="Seviyesi"  ReadOnly="False"  >
       <dxg:GridColumn.EditTemplate>
              <ControlTemplate>
                     <dxe:ComboBoxEdit Name="PART_Editor"
                              HorizontalContentAlignment="Left"
                              ItemsSource="{Binding SelectedItem,
                             Converter={StaticResource  SeviyeComboConverter},
RelativeSource={RelativeSource Mode=FindAncestor,
      AncestorType={x:Type dxg:GridControl}}}"
                              DisplayMember="Name"
                              ValueMember="Code"
                              EditValue="{Binding EditValue,
                             RelativeSource={RelativeSource TemplatedParent}}"
                              IsTextEditable="True"
                              AllowNullInput="True"
                              AutoComplete="True"                            
                              ImmediatePopup="True"/>
                   </ControlTemplate>
              </dxg:GridColumn.EditTemplate>
       </dxg:GridColumn>


 public class SeviyeComboConverter : IValueConverter
    {
        public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {


                int yetkiseviye = ShareDate.GlobalData.TanimList.First(f => f.Ekran_Id == ((ServisBaglanti.BackOfficeEkranRolServiceBaglanti.RefTRolEkranYetki)value).Ekran_Id).seviye;

                List<CodeName> liste = new List<CodeName>();

                for (int i = 0; yetkiseviye + 1 > i; i++)
                {
                    CodeName item = new CodeName { Code = i, Name =  "Seviye " + i };
                    liste.Add(item);

                }
                return liste;
         
        }

        public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            if (value != null)
            {
                return value;
            }
            return null;
        }
    }




          <dxg:GridColumn Header="Company"  FieldName="SelectedCompanyId" Width="50" >
                        <dxg:GridColumn.CellTemplate>
                            <DataTemplate>
                                <dxe:ComboBoxEdit Name="PART_Editor"
                                                     ImmediatePopup="True"                                        
                                    ItemsSource="{Binding RowData.Row.Company}"
                                    IsTextEditable="False"
                                    ApplyItemTemplateToSelectedItem="False"
                                   ValueMember="IdCustomer" 
                                   DisplayMember="Name">
                                    <dxe:ComboBoxEdit.DisplayTemplate>
                                        <ControlTemplate>
                                            <TextBlock   Text="{Binding Path=DisplayText, RelativeSource={RelativeSource TemplatedParent}}"></TextBlock>
                                         </ControlTemplate>
                                    </dxe:ComboBoxEdit.DisplayTemplate>
                                </dxe:ComboBoxEdit>
                            </DataTemplate>
                        </dxg:GridColumn.CellTemplate>
                    </dxg:GridColumn>



                <dxg:GridColumn FieldName="TypeName">
                    <dxg:GridColumn.EditTemplate>
                        <ControlTemplate>
                            <dxe:ComboBoxEdit x:Name="PART_Editor" EditMode="InplaceActive"
                                              EditValue="{Binding EditValue, RelativeSource={RelativeSource Mode=TemplatedParent}, 
                                                            Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"
                                              ItemsSource="{Binding RowData.Row.Types}"
                                              ValueMember="FullName" DisplayMember="FullName">
                            </dxe:ComboBoxEdit>
                        </ControlTemplate>
                    </dxg:GridColumn.EditTemplate>
                </dxg:GridColumn>

10 Nisan 2017 Pazartesi

Karşılaştırıcı Kullanarak Haritalanmış (Mapped) GroupBy Örneği


Örneğimiz, bir dizideki anagramları (aynı harflerle yazılan kelimeler) bulmaktadır. Karşılaştırıcı sınıfta kelimelerin anagram olup olmadıklarını belirleyen "SiraliKarakterleriVer" isimli özel bir yöntem kullanıldı. Bu yöntem parametre olarak verilen kelimedeki harfleri alfabetik sıraya sokmaktadır. Anagram kelimelerin harflerinin alfabetik sırası aynı olacağından bu yöntem sayesinde anagram kelimeler karşılaştırılabilmektedir.

Bu örnek dizideki anagramları bulur ve gruplandırır. Daha sonra bu anagram gruplarını çıktıya yazar.

string[] Anagramlar = { "şart", "yumak", "antik", "traş", "yamuk", "nakit" };

var AnagramGruplari = Anagramlar.GroupBy(Kelime => Kelime, new AnagramEsitlikKarsilastirici());

Console.WriteLine("Dizideki anagramlar :");
foreach (var Grup in AnagramGruplari)
{
    Console.WriteLine("---");
    foreach (var Kelime in Grup)
    {
        Console.WriteLine(Kelime);
    }
}
Console.ReadLine();
Örneğin çıktısı şöyle olacaktır :

Dizideki anagramlar :
---
şart
traş
---
yumak
yamuk
---
antik
nakit
Dizide kullanılan karşılaştırıcı sınıf şöyledir:

public class AnagramEsitlikKarsilastirici : IEqualityComparer
{
    public bool Equals(string x, string y)
    {
        return SiraliKarakterleriVer(x) == SiraliKarakterleriVer(y);
    }

    public int GetHashCode(string obj)
    {
        return SiraliKarakterleriVer(obj).GetHashCode();
    }

    private string SiraliKarakterleriVer(string Kelime)
    {
        char[] KelimeninKarakterleri = Kelime.ToCharArray();
        Array.Sort(KelimeninKarakterleri);
        return new string(KelimeninKarakterleri);
    }
}
Kaynak:
https://code.msdn.microsoft.com/101-LINQ-Samples-3fb9811b

Linq SelectMany Kullanımı

var Ogrenciler = OgrencileriGetir();
List Kulupler = KulupleriGetir();

var UyeOlunanKulupler = Ogrenciler.SelectMany(Ogrenci => Kulupler.Where(Kulup => Kulup.KayitNo == Ogrenci.Kulup),
                             (Ogrenci, Kulup) =>
                                                  new {
                                                       Ogrenci.Adi,
                                                       KulupAdi = Kulup.Adi
                                                  }
                             );

Console.WriteLine("Öğrenciler ve kulupleri :");

foreach (var Satir in UyeOlunanKulupler)
{
    Console.WriteLine("{0}, {1} kulübüne üye.", Satir.Adi, Satir.KulupAdi);
}
Console.ReadLine();


SelectMany yönteminin aldığı 2 parametreden birincisi, SelectMany uygulanan veri kaynağının (örneğimizde Ogrenciler ) hangi veri kaynağı ile hangi ortak alan üzerinden birleştirileceğini (örneğimizide Kulup.KayitNo  ve Ogrenci.Kulup ), ikincisi nelerin seçileceğini (örneğimizde öğrenci adı ve kulüp adı) belirler.



Bu örnekte new { Ogrenci.Adi, KulupAdi = Kulup.Adi } ifadesinde birinci özelliğin adı belirtilmemiştir. Yani isimsiz tip new { Adi = Ogrenci.Adi, KulupAdi = Kulup.Adi }  şeklinde yazılmamıştır. Böyle bir durumda özellik adı olarak seçilen özelliğin adı (örneğimizde Ogrenci.Adi bölümündeki Adi) kullanılacaktır.

6 Nisan 2017 Perşembe

c# İstisna (Exception) Durum Sınıf Açıklamaları

Sık Kulanılan İstisnai Durum Sınıfları

Çalışma zamanında beklenmedik bir hatanın oluşumu sonrasında oluşturulan nesnelere istisnai durum sınıf nesneleri denir. Bir hatanın oluşması, çalışma zamanında ilgili hatayı temsil eden sınıf türünden bir nesnenin oluşturulması anlamına gelir. Sık kullanılan istisnai durum sınıfları :
  • System.OutOfMemoryException: Programın çalışması için yeterli bellek kalmadıysa oluşur.
  • System.StackOverflowException: Stack (Yığın) bellek bölgesinin birden fazla metod için kullanılması durumunda oluşur. Genellikle kendini çağıran metodların hatalı kullanılmasıyla meydana gelir.
  • System.NullReferenceException: Bellekte yer ayrılmamış bir nesne üzerinden sınıfın üye elemanlarına erişmeye çalışırken oluşur.
  • System.OverflowException: Bir veri türüne kapasitesinden fazla veri yüklemeye çalışılırken oluşur.
  • System.InvalidCastException: Tür dönüştürme operatörüyle geçersiz tür dönüşümü yapılmaya çalışıldığında oluşur.
  • System.IndexOutOfRangeException: Bir dizinin olmayan elemanına erişilmeye çalışılırken fırlatılır.
  • System.ArrayTypeMismatchException: Bir dizinin elemanına yanlış türde veri atanmaya çalışılırken oluşur.
  • System.DividedByZero: Sıfıra bölme yapıldığı zaman oluşur.
  • System.ArithmeticException: DividedByZero ve OverflowException bu sınıftan türemiştir. Hemen hemen matematikle ilgili tüm istisnaları yakalayabilir.
  • System.FormatException: Metodlara yanlış biçimde parametre verildiğinde oluşur.

1 Nisan 2017 Cumartesi

REST Servis Cagırma

REST GET/POST/PUT/DELETE yapmak için uyguladığım adımlar şu şekilde:
  • Visual Studio’da Visual C#/Windows Desktop/Console Application projesi oluşturdum. Adını RestClientSample koydum.
  • NuGet üzerinden Microsoft.AspNet.WebApi.Client paketini yükledim.
  • Rest servise gönderilecek ve servisten dönecek nesnelere karşılık gelen sınıfları oluşturdum.
  • Program.cs’yi aşağıdaki gibi değiştirdim.

using System;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
 
namespace RestClientSample
{
    class Program
    {
        static void Main(string[] args)
        {
            try
            {
                RunAsync().Wait();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.StackTrace);
            }
 
            Console.ReadKey();
        }
 
        static async Task RunAsync()
        {
            using (var client = new HttpClient())
            {
                // Servis adresi
                client.BaseAddress = new Uri("http://webadresi.com/");
                client.DefaultRequestHeaders.Accept.Clear();
                client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
 
                // Servis Basic Http Authentication istiyorsa eklenir.
                client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(new UTF8Encoding().GetBytes(string.Format("{0}:{1}", "TestUser", "Pass"))));
 
                // HTTP GET
                HttpResponseMessage response = await client.GetAsync("api/IotDatas/1");
                if (response.IsSuccessStatusCode)
                {
                    IotData product = await response.Content.ReadAsAsync<IotData>();
                    Console.WriteLine("{0}\t${1}\t{2}", product.Name, product.Value, product.CreateDate);
                }
 
                // HTTP POST
                var iotData = new IotData { Name = "Test", Value = null, CreateDate = DateTime.Now };
                response = await client.PostAsJsonAsync("api/IotDatas", iotData);
                if (response.IsSuccessStatusCode)
                {
                    Uri gizmoUrl = response.Headers.Location;
 
                    // HTTP PUT
                    iotData.Value = null;
                    response = await client.PutAsJsonAsync(gizmoUrl, iotData);
 
                    // HTTP DELETE
                    response = await client.DeleteAsync(gizmoUrl);
                }
            }
        }
    }
}