Какой рейтинг вас больше интересует?
|
Главная /
Каталог блоговCтраница блогера Непутевые заметки о C#/Записи в блоге |
Непутевые заметки о C#
Голосов: 0 Адрес блога: http://i-am-a-kernel.blogspot.com/ Добавлен: 2012-10-31 18:45:33 |
|
Плавная смена цвета элементов WinForms
2012-10-31 02:37:00 (читать в оригинале)Вот прошло совсем не много времени, и новая публикация. Сегодня я покажу как сделать интересный эффект смены цвета.
Демонстрацию буду проводить на следующем примере: Заменить текст в элементе label по клику по кнопке, но смена текста должна происходить плавно. Так как лучше один раз показать, чем 100 раз рассказать, то тут вы можете скачать ДЕМО.
Для начала создадим проект WinForms и добавим на форму: Label и Button.
Вот код формы:
Этот же прием можно использовать для любого элемента интерфейса WinForms, не ограничивайте себя, пробуйте.
P.S. Если хотите писать красивости в пользовательском интерфейсе, переходите на XAML, там все это намного проще...
Демонстрацию буду проводить на следующем примере: Заменить текст в элементе label по клику по кнопке, но смена текста должна происходить плавно. Так как лучше один раз показать, чем 100 раз рассказать, то тут вы можете скачать ДЕМО.
Для начала создадим проект WinForms и добавим на форму: Label и Button.
Вот код формы:
public partial class Form1 : FormПри запуске приложения, в label один текст. После нажатия на кнопку, он блекнет, потом проявляется новый текст. Вся анимация занимает 2 секунды... Основная идея в том, что изменения свойств должны идти не в цикле и за доли секунды, а через таймер и хоть какое то время, которое будет различать пользователь.
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
dR = label1.BackColor.R - label1.ForeColor.R;
dG = label1.BackColor.G - label1.ForeColor.G;
dB = label1.BackColor.B - label1.ForeColor.B;
sign = 1;
Timer timer = new Timer();
timer.Interval = 100;
timer.Tick += timer_Tick;
timer.Start();
}
int dR, dG, dB, sign;
void timer_Tick(object sender, EventArgs e)
{
if (Math.Abs(label1.ForeColor.R - label1.BackColor.R) < Math.Abs(dR / 10))
{
sign *= -1;
label1.Text = "Новый текст";
}
label1.ForeColor = Color.FromArgb(255, label1.ForeColor.R + sign * dR / 10, label1.ForeColor.G + sign * dG / 10, label1.ForeColor.B + sign * dB / 10);
if (label1.BackColor.R == label1.ForeColor.R + dR)
{
((Timer)sender).Stop();
}
}
}
Этот же прием можно использовать для любого элемента интерфейса WinForms, не ограничивайте себя, пробуйте.
P.S. Если хотите писать красивости в пользовательском интерфейсе, переходите на XAML, там все это намного проще...
Сортировка пузырьком и быстрая сортировка на C#
2012-10-30 16:35:00 (читать в оригинале)Привет, читатель :) Вот я и решил начать, причем начать я решил не с азов (я считаю что рассматривать их не стоит) но и чего-то запредельно сложного тут не найти. Я всего лишь студент который учиться как и ты.
Итак, первое о чем я хотел написать, так это о сортировке и ее реализации. Почему именно с нее? все просто, очень часто на собеседованиях требуют знания как работает тот или иной метод сортировки, или просят его реализовать, а во вторых всегда приятнее уметь самому делать то что уже реализовано. Так что то я заговорился не по делу, пора начинать.
Задача: Реализовать *.DLL библиотеку которая будет реализовывать сортировку массива методом пузырька или быстрой сортировкой по возрастанию и убыванию.
Так с задачей мы определились, начнем реализовывать.
Подробно о этих методах сортировки можно ознакомиться тут:
Сортировка пузырьком, Быстрая сортировка.
Так с теорией мы тоже разобрались :) Быстро продвигаемся.
Начнем с реализации метода пузырька, так как он проще: Создадим класс с именем "BubbleSort.cs"
Заглянем немного на перед и вспомним что потом нам придется реализовывать сортировку по возрастанию и убыванию, следовательно нам нужно свойство которое бы содержало эту информацию, давайте его добавим:
Почему мы сделали именно так? все просто, потому что нам необходимо обеспечить безопасность этого свойства и мы не хотим что бы в него попало не хорошее значение, непонятно откуда.
Теперь начнем самое интересное саму сортировку, так как мы не знаем какой тип данных будет в массиве используем универсальный интерфейс IComparable, объявление метода будет следующим:
Итак, первое о чем я хотел написать, так это о сортировке и ее реализации. Почему именно с нее? все просто, очень часто на собеседованиях требуют знания как работает тот или иной метод сортировки, или просят его реализовать, а во вторых всегда приятнее уметь самому делать то что уже реализовано. Так что то я заговорился не по делу, пора начинать.
Задача: Реализовать *.DLL библиотеку которая будет реализовывать сортировку массива методом пузырька или быстрой сортировкой по возрастанию и убыванию.
Так с задачей мы определились, начнем реализовывать.
Подробно о этих методах сортировки можно ознакомиться тут:
Сортировка пузырьком, Быстрая сортировка.
Так с теорией мы тоже разобрались :) Быстро продвигаемся.
Начнем с реализации метода пузырька, так как он проще: Создадим класс с именем "BubbleSort.cs"
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ASort
{
public class BubbleSort
{
}
}
Заглянем немного на перед и вспомним что потом нам придется реализовывать сортировку по возрастанию и убыванию, следовательно нам нужно свойство которое бы содержало эту информацию, давайте его добавим:
private bool IsDown;
public bool IsDownValue
{
get
{
return IsDown;
}
set
{
IsDown = value;
}
}
Почему мы сделали именно так? все просто, потому что нам необходимо обеспечить безопасность этого свойства и мы не хотим что бы в него попало не хорошее значение, непонятно откуда.
Теперь начнем самое интересное саму сортировку, так как мы не знаем какой тип данных будет в массиве используем универсальный интерфейс IComparable, объявление метода будет следующим:
public Array Sort(T[] arr)where T:IComparable
{
//тут происходит сортировка
return arr;
}
Я продемонстрирую как сделать сортировку по возрастанию, для убывания вы с легкостью сделаете сами:
for (int i = 0; i < arr.Length; i++)
{
for (int j = 0; j < arr.Length-1; j++)
{
if (!IsDownValue)
{
if (arr[j].CompareTo(arr[j + 1]) > 0)//возрастание
{
T temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
else
{
//по аналогии с предыдущем условием делаем для убывания
}
}
}
Результатом работы данного метода будет массив той же размерности и типа что входной, однако уже упорядоченный.
Теперь давай те попробуем сделать тоже самое но методом быстрой сортировки. Создадим новый класс в проекте назовем, например "QuickSort.cs" и как и в прошлый раз создадим в нем точно такое же свойство.
C# с обобщенными типами, тип Т должен реализовывать интерфейс IComparable
int partition( T[] m, int a, int b) where T :IComparable
{
int i = a;
for (int j = a; j <= b; j++) // просматриваем с a по b
{
if (m[j].CompareTo( m[b]) <= 0) // если элемент m[j] не превосходит m[b],
{
T t = m[i]; // меняем местами m[j] и m[a], m[a+1], m[a+2] и так далее...
m[i] = m[j]; // то есть переносим элементы меньшие m[b] в начало,
m[j] = t; // а затем и сам m[b] «сверху»
i++; // таким образом последний обмен: m[b] и m[i], после чего i++
}
}
return i - 1; // в индексе i хранится <новая позиция элемента m[b]> + 1
}
void quicksort( T[] m, int a, int b) where T : IComparable // a - начало подмножества, b - конец
{ // для первого вызова: a = 0, b = <элементов в массиве> - 1
if (a >= b) return;
int c = partition( m, a, b);
quicksort( m, a, c - 1);
quicksort( m, c + 1, b);
}
//Пример вызова
//double[] arr = {9,1.5,34.4,234,1,56.5};
//quicksort(arr,0,arr.Length-1);
Теперь добавим возможность выбора сортировки по возрастанию и убыванию.
private int partitionНу вот и все. Все готово. Советую собирать проект в виде dll и использовать как библиотеку, как ее использовать описано тут в заголовке ASort, там же можно скачать то что получилось у меня.(T[] arr, int start, int end) where T : IComparable
{
int i = start;
for (int j = start; j <= end; j++)
{
if (!IsDownValue)
{
if (arr[j].CompareTo(arr[end]) <= 0)
{
T t = arr[i];
arr[i] = arr[j];
arr[j] = t;
i++;
}
}
else
{
if (arr[j].CompareTo(arr[end]) >= 0)
{
T t = arr[i];
arr[i] = arr[j];
arr[j] = t;
i++;
}
}
}
return i - 1;
}
Не давно нашел пример быстрой сортировки с помощью лямбда выражений:
using System;Ну вот и все, спасибо за внимание.
using System.Collections.Generic;
using System.Linq;
static public class Qsort
{
public static IEnumerableQuickSort (this IEnumerable list) where T : IComparable
{
if (!list.Any())
{
return Enumerable.Empty();
}
var pivot = list.First();
var smaller = list.Skip(1).Where(item => item.CompareTo(pivot) <= 0).QuickSort();
var larger = list.Skip(1).Where(item => item.CompareTo(pivot) > 0).QuickSort();
return smaller.Concat(new[] { pivot }).Concat(larger);
}
//(тоже самое, но записанное в одну строку, без объявления переменных)
public static IEnumerableshortQuickSort (this IEnumerable list) where T : IComparable
{
return !list.Any() ? Enumerable.Empty() : list.Skip(1).Where(
item => item.CompareTo(list.First()) <= 0).shortQuickSort().Concat(new[] { list.First() })
.Concat(list.Skip(1).Where(item => item.CompareTo(list.First()) > 0).shortQuickSort());
}
}
Категория «Картинки»
Взлеты Топ 5
+2036 |
2053 |
Ищешь oldMike? - Это ЗдесЪ! |
+1994 |
2064 |
Splash_Phantom |
+1961 |
2094 |
ДеВаЧкА-НеФоРмАлКа |
+1948 |
2106 |
ROMAHA.SU |
+1947 |
2080 |
Yurenzo |
Падения Топ 5
-1 |
1366 |
Выдающиеся женщины |
-8 |
543 |
absit_omen |
-8 |
18 |
anmak |
-9 |
17 |
ВАДОС |
-10 |
10 |
Всё о Заработке в Интернет, а так же Интернет Новости |
Популярные за сутки
Загрузка...
BlogRider.ru не имеет отношения к публикуемым в записях блогов материалам. Все записи
взяты из открытых общедоступных источников и являются собственностью их авторов.
взяты из открытых общедоступных источников и являются собственностью их авторов.