From 4e83861734b6d278872e723161be4260cb53b01b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20Santanch=C3=A8?= Date: Tue, 22 Jun 2021 13:58:41 -0300 Subject: [PATCH] feat (call/factory): new factory method example with components --- README.md | 2 +- .../src/pt/c04gui/s20chart/XYChart02.java | 49 +++++++++++++++++++ .../s10components/App05ChartSequence.java | 36 ++++++++++++++ .../factory/s10components/chart/BarChart.java | 37 ++++++++++++++ .../s10components/chart/BarChartFactory.java | 16 ++++++ .../s10components/chart/ConsoleBarChart.java | 41 ++++++++++++++++ .../s10components/chart/GraphicBarChart.java | 40 +++++++++++++++ .../s10components/chart/IBarChart.java | 5 ++ .../chart/IBarChartProperties.java | 9 ++++ .../factory/s10components/chart/IChart.java | 5 ++ .../s10components/chart/IRSequence.java | 7 +++ .../chart/exception/InvalidBlankChar.java | 15 ++++++ .../chart/exception/PlotException.java | 15 ++++++ .../exception/UnsupportedNegativeNumber.java | 15 ++++++ .../sequence/ArithmeticProgression.java | 39 +++++++++++++++ .../s10components/sequence/Fibonacci.java | 42 ++++++++++++++++ .../sequence/GeometricProgression.java | 39 +++++++++++++++ .../s10components/sequence/IMathSequence.java | 5 ++ .../sequence/IMathSequenceRatio.java | 5 ++ .../s10components/sequence/ISequence.java | 6 +++ .../sequence/ISequenceProperties.java | 6 +++ .../sequence/ISequenceRatioProperties.java | 6 +++ .../sequence/MathSequenceFactory.java | 23 +++++++++ 23 files changed, 462 insertions(+), 1 deletion(-) create mode 100644 src/java/src/pt/c04gui/s20chart/XYChart02.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/App05ChartSequence.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/BarChart.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/BarChartFactory.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/ConsoleBarChart.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/GraphicBarChart.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/IBarChart.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/IBarChartProperties.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/IChart.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/IRSequence.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/exception/InvalidBlankChar.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/exception/PlotException.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/chart/exception/UnsupportedNegativeNumber.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/ArithmeticProgression.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/Fibonacci.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/GeometricProgression.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequence.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequenceRatio.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/ISequence.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceProperties.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceRatioProperties.java create mode 100644 src/java/src/pt/c06patterns/factory/s10components/sequence/MathSequenceFactory.java diff --git a/README.md b/README.md index 71d6222..b5f87c2 100644 --- a/README.md +++ b/README.md @@ -8,7 +8,7 @@ Todos os exemplos no diretório `notebook` são preparados para o ambiente Jupyt ## Abrir branch específico em uma instância do [binderhub](https://github.com/jupyterhub/binderhub) * Última versão testada e estável: - [![launch @ mybinder.org][badge-jupyterlab-mybinder-org]](https://mybinder.org/v2/gh/santanche/java2learn/v1.1.5) + [![launch @ mybinder.org][badge-jupyterlab-mybinder-org]](https://mybinder.org/v2/gh/santanche/java2learn/v1.1.6) * Última versão disponível: [![launch @ mybinder.org][badge-jupyterlab-mybinder-org]](https://mybinder.org/v2/gh/santanche/java2learn/master) diff --git a/src/java/src/pt/c04gui/s20chart/XYChart02.java b/src/java/src/pt/c04gui/s20chart/XYChart02.java new file mode 100644 index 0000000..1bb34e5 --- /dev/null +++ b/src/java/src/pt/c04gui/s20chart/XYChart02.java @@ -0,0 +1,49 @@ +package pt.c04gui.s20chart; + +import java.awt.Color; +import java.util.ArrayList; +import java.util.List; + +import org.knowm.xchart.SwingWrapper; +import org.knowm.xchart.XYChart; +import org.knowm.xchart.XYChartBuilder; +import org.knowm.xchart.XYSeries; +import org.knowm.xchart.XYSeries.XYSeriesRenderStyle; +import org.knowm.xchart.style.markers.SeriesMarkers; + +public class XYChart02 { + + public static void main(String[] args) { + XYChart02 exampleChart = new XYChart02(); + XYChart chart = exampleChart.getChart(); + new SwingWrapper(chart).displayChart(); + } + + public XYChart getChart() { + + // Create Chart + XYChart chart = new XYChartBuilder().width(800).height(600).title("Line Chart").xAxisTitle("X").yAxisTitle("Y").build(); + + // Customize Chart + chart.getStyler().setDefaultSeriesRenderStyle(XYSeriesRenderStyle.Line); + chart.getStyler().setChartTitleVisible(false); + chart.getStyler().setLegendVisible(false); + chart.getStyler().setAxisTitlesVisible(false); + chart.getStyler().setXAxisDecimalPattern("0.0000000"); + + // Series + int size = 10; + List xData = new ArrayList(); + List yData = new ArrayList(); + for (int i = 0; i <= size; i++) { + xData.add(((double) i) / 1000000); + yData.add(10 * Math.exp(-i)); + } + XYSeries series = chart.addSeries("10^(-x)", xData, yData); + series.setMarkerColor(Color.RED); + series.setMarker(SeriesMarkers.SQUARE); + + return chart; + } + +} \ No newline at end of file diff --git a/src/java/src/pt/c06patterns/factory/s10components/App05ChartSequence.java b/src/java/src/pt/c06patterns/factory/s10components/App05ChartSequence.java new file mode 100644 index 0000000..5c39201 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/App05ChartSequence.java @@ -0,0 +1,36 @@ +package pt.c06patterns.factory.s10components; + +import java.util.Scanner; + +import pt.c06patterns.factory.s10components.chart.BarChartFactory; +import pt.c06patterns.factory.s10components.chart.IBarChart; +import pt.c06patterns.factory.s10components.chart.exception.PlotException; +import pt.c06patterns.factory.s10components.sequence.IMathSequenceRatio; +import pt.c06patterns.factory.s10components.sequence.MathSequenceFactory; + +public class App05ChartSequence { + public static void main(String args[]) { + System.out.print("Progression type (arithmetic or geometric): "); + Scanner keyboard = new Scanner(System.in); + String sequenceType = keyboard.nextLine(); + + System.out.print("Chart type (console ou graphic): "); + String chartType = keyboard.nextLine(); + + keyboard.close(); + + IMathSequenceRatio gp = MathSequenceFactory.createSequenceRatio(sequenceType); + gp.setInitial(1); + gp.setRatio(2); + + try { + IBarChart bcg = BarChartFactory.create(chartType); + bcg.setFilled(true); + bcg.setN(7); + bcg.connect(gp); + bcg.plot(); + } catch (PlotException error) { + System.err.println("*** Error: " + error.getMessage()); + } + } +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/BarChart.java b/src/java/src/pt/c06patterns/factory/s10components/chart/BarChart.java new file mode 100644 index 0000000..ce90e87 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/BarChart.java @@ -0,0 +1,37 @@ +package pt.c06patterns.factory.s10components.chart; + +import pt.c06patterns.factory.s10components.sequence.ISequence; + +public abstract class BarChart implements IBarChart { + protected boolean filled; + protected int n; + + protected ISequence sequence; + + public BarChart() { + filled = true; + n = 3; + } + + public boolean isFilled() { + return filled; + } + + public void setFilled(boolean filled) { + this.filled = filled; + } + + public int getN() { + return n; + } + + public void setN(int n) { + this.n = n; + } + + public void connect(ISequence sequence) { + this.sequence = sequence; + } + + public abstract void plot(); +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/BarChartFactory.java b/src/java/src/pt/c06patterns/factory/s10components/chart/BarChartFactory.java new file mode 100644 index 0000000..aafd72c --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/BarChartFactory.java @@ -0,0 +1,16 @@ +package pt.c06patterns.factory.s10components.chart; + +public class BarChartFactory { + + public static IBarChart create(String type) { + IBarChart chart = null; + + if (type.equalsIgnoreCase("console")) + chart = new ConsoleBarChart(); + else if (type.equalsIgnoreCase("graphic")) + chart = new GraphicBarChart(); + + return chart; + } + +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/ConsoleBarChart.java b/src/java/src/pt/c06patterns/factory/s10components/chart/ConsoleBarChart.java new file mode 100644 index 0000000..f272a55 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/ConsoleBarChart.java @@ -0,0 +1,41 @@ +package pt.c06patterns.factory.s10components.chart; + +import pt.c06patterns.factory.s10components.chart.exception.InvalidBlankChar; +import pt.c06patterns.factory.s10components.chart.exception.UnsupportedNegativeNumber; + +public class ConsoleBarChart extends BarChart { + private char character; + + public ConsoleBarChart() { + super(); + character = '*'; + } + + public char getCharacter() { + return character; + } + + public void setCharacter(char character) throws InvalidBlankChar { + if (character == ' ') + throw new InvalidBlankChar("the chart does not support blank character"); + this.character = character; + } + + public void plot() { + if (sequence != null) { + int value = sequence.first(); + for (int s = 1; s <= n; s++) { + if (value > 0) { + for (int v = 1; v < value; v++) + System.out.print((filled) ? character : ' '); + System.out.print(character); + } else if (value < 0) { + System.out.println("?"); + throw new UnsupportedNegativeNumber("the chart does not support a negative number"); + } + System.out.println(); + value = sequence.next(); + } + } + } +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/GraphicBarChart.java b/src/java/src/pt/c06patterns/factory/s10components/chart/GraphicBarChart.java new file mode 100644 index 0000000..44c6419 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/GraphicBarChart.java @@ -0,0 +1,40 @@ +package pt.c06patterns.factory.s10components.chart; + +import java.util.ArrayList; +import java.util.List; + +import org.knowm.xchart.CategoryChart; +import org.knowm.xchart.CategoryChartBuilder; +import org.knowm.xchart.SwingWrapper; + +public class GraphicBarChart extends BarChart { + + public void plot() { + // Create Chart + CategoryChart chart = + new CategoryChartBuilder().width(800).height(600). + title("Chart").xAxisTitle("X").yAxisTitle("Y").build(); + + // Customize Chart + chart.getStyler().setChartTitleVisible(false); + chart.getStyler().setLegendVisible(false); + chart.getStyler().setAxisTitlesVisible(false); + chart.getStyler().setXAxisDecimalPattern("0"); + + // Series + List xData = new ArrayList(); + List yData = new ArrayList(); + if (sequence != null) { + int value = sequence.first(); + for (int s = 1; s <= n; s++) { + xData.add(s); + yData.add(value); + value = sequence.next(); + } + } + chart.addSeries("series", xData, yData); + + new SwingWrapper(chart).displayChart(); + } + +} \ No newline at end of file diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/IBarChart.java b/src/java/src/pt/c06patterns/factory/s10components/chart/IBarChart.java new file mode 100644 index 0000000..c16f685 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/IBarChart.java @@ -0,0 +1,5 @@ +package pt.c06patterns.factory.s10components.chart; + +public interface IBarChart + extends IChart, IRSequence, IBarChartProperties { +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/IBarChartProperties.java b/src/java/src/pt/c06patterns/factory/s10components/chart/IBarChartProperties.java new file mode 100644 index 0000000..bd26e9e --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/IBarChartProperties.java @@ -0,0 +1,9 @@ +package pt.c06patterns.factory.s10components.chart; + +public interface IBarChartProperties { + public boolean isFilled(); + public void setFilled(boolean filled); + + public int getN(); + public void setN(int n); +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/IChart.java b/src/java/src/pt/c06patterns/factory/s10components/chart/IChart.java new file mode 100644 index 0000000..1a56688 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/IChart.java @@ -0,0 +1,5 @@ +package pt.c06patterns.factory.s10components.chart; + +public interface IChart { + public void plot(); +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/IRSequence.java b/src/java/src/pt/c06patterns/factory/s10components/chart/IRSequence.java new file mode 100644 index 0000000..e195068 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/IRSequence.java @@ -0,0 +1,7 @@ +package pt.c06patterns.factory.s10components.chart; + +import pt.c06patterns.factory.s10components.sequence.ISequence; + +public interface IRSequence { + public void connect(ISequence sequence); +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/exception/InvalidBlankChar.java b/src/java/src/pt/c06patterns/factory/s10components/chart/exception/InvalidBlankChar.java new file mode 100644 index 0000000..2e72ab0 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/exception/InvalidBlankChar.java @@ -0,0 +1,15 @@ +package pt.c06patterns.factory.s10components.chart.exception; + +public class InvalidBlankChar extends PlotException { + + private static final long serialVersionUID = -9219514119468607139L; + + public InvalidBlankChar() { + super(); + } + + public InvalidBlankChar(String message) { + super(message); + } + +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/exception/PlotException.java b/src/java/src/pt/c06patterns/factory/s10components/chart/exception/PlotException.java new file mode 100644 index 0000000..6fd43fa --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/exception/PlotException.java @@ -0,0 +1,15 @@ +package pt.c06patterns.factory.s10components.chart.exception; + +public class PlotException extends RuntimeException { + + private static final long serialVersionUID = 2727260512165247433L; + + public PlotException() { + super(); + } + + public PlotException(String message) { + super(message); + } + +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/chart/exception/UnsupportedNegativeNumber.java b/src/java/src/pt/c06patterns/factory/s10components/chart/exception/UnsupportedNegativeNumber.java new file mode 100644 index 0000000..32b2058 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/chart/exception/UnsupportedNegativeNumber.java @@ -0,0 +1,15 @@ +package pt.c06patterns.factory.s10components.chart.exception; + +public class UnsupportedNegativeNumber extends PlotException { + + private static final long serialVersionUID = -1248911490628763059L; + + public UnsupportedNegativeNumber() { + super(); + } + + public UnsupportedNegativeNumber(String message) { + super(message); + } + +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/ArithmeticProgression.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/ArithmeticProgression.java new file mode 100644 index 0000000..15c3da5 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/ArithmeticProgression.java @@ -0,0 +1,39 @@ +package pt.c06patterns.factory.s10components.sequence; + +public class ArithmeticProgression implements IMathSequenceRatio { + private int initial, + ratio; + private int current; + + public ArithmeticProgression() { + initial = 1; + ratio = 1; + current = initial; + } + + public int getInitial() { + return initial; + } + + public void setInitial(int initial) { + this.initial = initial; + } + + public int getRatio() { + return ratio; + } + + public void setRatio(int ratio) { + this.ratio = ratio; + } + + public int first() { + current = initial; + return current; + } + + public int next() { + current += ratio; + return current; + } +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/Fibonacci.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/Fibonacci.java new file mode 100644 index 0000000..2738f84 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/Fibonacci.java @@ -0,0 +1,42 @@ +package pt.c06patterns.factory.s10components.sequence; + +public class Fibonacci implements IMathSequence { + private int initialCurrent, initialNext; + private int current, next; + + public Fibonacci() { + initialCurrent = 0; + initialNext = 1; + current = 0; + next = 1; + } + + public int getInitial() { + return initialCurrent; + } + + public void setInitial(int initial) { + current = 0; + next = 1; + while (initial > current) { + int sum = current + next; + current = next; + next = sum; + } + initialCurrent = current; + initialNext = next; + } + + public int first() { + current = initialCurrent; + next = initialNext; + return current; + } + + public int next() { + int sum = current + next; + current = next; + next = sum; + return current; + } +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/GeometricProgression.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/GeometricProgression.java new file mode 100644 index 0000000..2e24033 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/GeometricProgression.java @@ -0,0 +1,39 @@ +package pt.c06patterns.factory.s10components.sequence; + +public class GeometricProgression implements IMathSequenceRatio { + private int initial, + ratio; + private int current; + + public GeometricProgression() { + initial = 1; + ratio = 2; + current = initial; + } + + public int getInitial() { + return initial; + } + + public void setInitial(int initial) { + this.initial = initial; + } + + public int getRatio() { + return ratio; + } + + public void setRatio(int ratio) { + this.ratio = ratio; + } + + public int first() { + current = initial; + return current; + } + + public int next() { + current *= ratio; + return current; + } +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequence.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequence.java new file mode 100644 index 0000000..8794252 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequence.java @@ -0,0 +1,5 @@ +package pt.c06patterns.factory.s10components.sequence; + +public interface IMathSequence + extends ISequence, ISequenceProperties { +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequenceRatio.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequenceRatio.java new file mode 100644 index 0000000..7aa2b38 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/IMathSequenceRatio.java @@ -0,0 +1,5 @@ +package pt.c06patterns.factory.s10components.sequence; + +public interface IMathSequenceRatio + extends IMathSequence, ISequenceRatioProperties { +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequence.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequence.java new file mode 100644 index 0000000..37365a1 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequence.java @@ -0,0 +1,6 @@ +package pt.c06patterns.factory.s10components.sequence; + +public interface ISequence { + public int first(); + public int next(); +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceProperties.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceProperties.java new file mode 100644 index 0000000..3c38514 --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceProperties.java @@ -0,0 +1,6 @@ +package pt.c06patterns.factory.s10components.sequence; + +public interface ISequenceProperties { + public int getInitial(); + public void setInitial(int initial); +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceRatioProperties.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceRatioProperties.java new file mode 100644 index 0000000..eb604fa --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/ISequenceRatioProperties.java @@ -0,0 +1,6 @@ +package pt.c06patterns.factory.s10components.sequence; + +public interface ISequenceRatioProperties { + public int getRatio(); + public void setRatio(int ratio); +} diff --git a/src/java/src/pt/c06patterns/factory/s10components/sequence/MathSequenceFactory.java b/src/java/src/pt/c06patterns/factory/s10components/sequence/MathSequenceFactory.java new file mode 100644 index 0000000..2524d5a --- /dev/null +++ b/src/java/src/pt/c06patterns/factory/s10components/sequence/MathSequenceFactory.java @@ -0,0 +1,23 @@ +package pt.c06patterns.factory.s10components.sequence; + +public class MathSequenceFactory { + public static IMathSequence createSequence(String type) { + IMathSequence sequence = createSequenceRatio(type); + + if (sequence == null && type.equalsIgnoreCase("fibonacci")) + sequence = new Fibonacci(); + + return sequence; + } + + public static IMathSequenceRatio createSequenceRatio(String type) { + IMathSequenceRatio sequence = null; + + if (type.equalsIgnoreCase("arithmetic")) + sequence = new ArithmeticProgression(); + else if (type.equalsIgnoreCase("geometric")) + sequence = new GeometricProgression(); + + return sequence; + } +}