Zasada jako interfejs a nie delegat
"
This commit is contained in:
parent
af2568a913
commit
5240ef7ce6
@ -13,6 +13,7 @@
|
|||||||
<e p="GameOfLife.cs" t="Include" />
|
<e p="GameOfLife.cs" t="Include" />
|
||||||
<e p="IAutomaton.cs" t="Include" />
|
<e p="IAutomaton.cs" t="Include" />
|
||||||
<e p="IField.cs" t="Include" />
|
<e p="IField.cs" t="Include" />
|
||||||
|
<e p="IRule.cs" t="Include" />
|
||||||
<e p="MooreField.cs" t="Include" />
|
<e p="MooreField.cs" t="Include" />
|
||||||
</e>
|
</e>
|
||||||
<e p="AutomatonField.xaml" t="Include" />
|
<e p="AutomatonField.xaml" t="Include" />
|
||||||
|
@ -40,9 +40,9 @@ namespace Life.Automaton
|
|||||||
|
|
||||||
public abstract IEnumerable<Cell> Neighbours(int x, int y);
|
public abstract IEnumerable<Cell> Neighbours(int x, int y);
|
||||||
|
|
||||||
public void Transform(Rule transform)
|
public void Transform(IRule rule)
|
||||||
{
|
{
|
||||||
_cells = transform(this);
|
_cells = rule.Next(this);
|
||||||
|
|
||||||
Notify();
|
Notify();
|
||||||
}
|
}
|
||||||
|
@ -1,24 +1,27 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Runtime.Serialization;
|
|
||||||
|
|
||||||
namespace Life.Automaton
|
namespace Life.Automaton
|
||||||
{
|
{
|
||||||
[Serializable]
|
[Serializable]
|
||||||
public class GameOfLife : IAutomaton
|
public class GameOfLife : IAutomaton
|
||||||
{
|
{
|
||||||
public GameOfLife(int width, int height)
|
[Serializable]
|
||||||
|
public class StandardRule : IRule
|
||||||
{
|
{
|
||||||
Field = new MooreField(width, height);
|
private string survive;
|
||||||
}
|
private string born;
|
||||||
|
|
||||||
|
public StandardRule(string born, string survive)
|
||||||
|
{
|
||||||
|
this.born = born;
|
||||||
|
this.survive = survive;
|
||||||
|
}
|
||||||
|
|
||||||
public static Rule MakeRule(string born, string survive)
|
|
||||||
{
|
|
||||||
bool WillSurvive(int neighbours) => survive.Contains(neighbours.ToString());
|
bool WillSurvive(int neighbours) => survive.Contains(neighbours.ToString());
|
||||||
bool WillBorn(int neighbours) => born.Contains(neighbours.ToString());
|
bool WillBorn(int neighbours) => born.Contains(neighbours.ToString());
|
||||||
|
|
||||||
return field =>
|
public Cell[,] Next(IField field)
|
||||||
{
|
{
|
||||||
var @new = new Cell[field.Size.Width, field.Size.Height];
|
var @new = new Cell[field.Size.Width, field.Size.Height];
|
||||||
|
|
||||||
@ -36,10 +39,15 @@ namespace Life.Automaton
|
|||||||
}
|
}
|
||||||
|
|
||||||
return @new;
|
return @new;
|
||||||
};
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public GameOfLife(int width, int height)
|
||||||
|
{
|
||||||
|
Field = new MooreField(width, height);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Rule Rule { get; set; } = MakeRule("3", "32");
|
public IRule Rule { get; set; } = new StandardRule("3", "32");
|
||||||
|
|
||||||
public int Iteration { get; private set; }
|
public int Iteration { get; private set; }
|
||||||
|
|
||||||
|
@ -4,7 +4,6 @@ using Life.Misc;
|
|||||||
|
|
||||||
namespace Life.Automaton
|
namespace Life.Automaton
|
||||||
{
|
{
|
||||||
public delegate Cell[,] Rule(IField old);
|
|
||||||
|
|
||||||
public interface IField : IObservable<IField>
|
public interface IField : IObservable<IField>
|
||||||
{
|
{
|
||||||
@ -16,7 +15,7 @@ namespace Life.Automaton
|
|||||||
|
|
||||||
IEnumerable<Cell> Neighbours(int x, int y);
|
IEnumerable<Cell> Neighbours(int x, int y);
|
||||||
|
|
||||||
void Transform(Rule rule);
|
void Transform(IRule rule);
|
||||||
void Notify();
|
void Notify();
|
||||||
|
|
||||||
void Resize(int width, int height);
|
void Resize(int width, int height);
|
||||||
|
7
Life/Automaton/IRule.cs
Normal file
7
Life/Automaton/IRule.cs
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
namespace Life.Automaton
|
||||||
|
{
|
||||||
|
public interface IRule
|
||||||
|
{
|
||||||
|
Cell[,] Next(IField old);
|
||||||
|
}
|
||||||
|
}
|
@ -147,11 +147,7 @@ namespace Life.ViewModel
|
|||||||
if (dialog.ShowDialog() == true)
|
if (dialog.ShowDialog() == true)
|
||||||
{
|
{
|
||||||
using var file = dialog.OpenFile();
|
using var file = dialog.OpenFile();
|
||||||
var field = _formatter.Deserialize(file) as IField;
|
Automaton = _formatter.Deserialize(file) as IAutomaton;
|
||||||
|
|
||||||
Automaton.ReplaceField(field);
|
|
||||||
|
|
||||||
OnPropertyChanged(nameof(Field));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -162,7 +158,7 @@ namespace Life.ViewModel
|
|||||||
if (dialog.ShowDialog() == true)
|
if (dialog.ShowDialog() == true)
|
||||||
{
|
{
|
||||||
using var file = dialog.OpenFile();
|
using var file = dialog.OpenFile();
|
||||||
_formatter.Serialize(file, Field);
|
_formatter.Serialize(file, Automaton);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user