28 Mayıs 2018 Pazartesi

Işlem başka bir işlem tarafından kullanıldığından dosyasına erişemiyor Hatası ve Çözümü


using (System.IO.FileStream file = new System.IO.FileStream(path, System.IO.FileMode.OpenOrCreate, System.IO.FileAccess.ReadWrite, System.IO.FileShare.ReadWrite))
                    using (System.IO.StreamReader sr = new System.IO.StreamReader(file))
                    {
                        // Read the stream to a string, and write the string to the console.
                        string not = sr.ReadToEnd();
                    }

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.