1 module ithox.qrcode.renderer.text.plain;
2 
3 import ithox.qrcode.renderer.rendererinterface;
4 import ithox.qrcode.encoder.qrcode;
5 import ithox.qrcode.renderer.rendererinterface;
6 import ithox.qrcode.renderer.color.colorinterface;
7 
8 /**
9 * Plaintext renderer.
10 */
11 class Plain : RendererInterface
12 {
13 	/**
14 	* Margin around the QR code, also known as quiet zone.
15 	*
16 	* @var integer
17 	*/
18     protected int margin = 1;
19     /**
20 	* Char used for full block.
21 	*
22 	* UTF-8 FULL BLOCK (U+2588)
23 	*
24 	* @var  string
25 	* @link http://www.fileformat.info/info/unicode/char/2588/index.htm
26 	*/
27     protected string fullBlock = "\xE2\x96\x88";
28     /**
29 	* Char used for empty space
30 	*
31 	* @var string
32 	*/
33     protected string emptyBlock = " ";
34 
35 	/**
36 	* Set char used as full block (occupied space, "black").
37 	*
38 	* @param string fullBlock
39 	*/
40     public void setFullBlock(string fullBlock)
41     {
42         this.fullBlock = fullBlock;
43     }
44     /**
45 	* Get char used as full block (occupied space, "black").
46 	*
47 	* @return string
48 	*/
49     public string getFullBlock()
50     {
51         return this.fullBlock;
52     }
53     /**
54 	* Set char used as empty block (empty space, "white").
55 	*
56 	* @param string emptyBlock
57 	*/
58     public void setEmptyBlock(string emptyBlock)
59     {
60         this.emptyBlock = emptyBlock;
61     }
62     /**
63 	* Get char used as empty block (empty space, "white").
64 	*
65 	* @return string
66 	*/
67     public string getEmptyBlock()
68     {
69         return this.emptyBlock;
70     }
71     /**
72 	* Sets the margin around the QR code.
73 	*
74 	* @param  integer margin
75 	* @return AbstractRenderer
76 	* @throws Exception\InvalidArgumentException
77 	*/
78     public RendererInterface setMargin(int margin)
79     {
80         if (margin < 0) {
81             throw new Exception("Margin must be equal to greater than 0");
82         }
83         this.margin = margin;
84         return this;
85     }
86     /**
87 	* Gets the margin around the QR code.
88 	*
89 	* @return integer
90 	*/
91     public int getMargin()
92     {
93         return this.margin;
94     }
95     /**
96 	* render(): defined by RendererInterface.
97 	*
98 	* @see    RendererInterface::render()
99 	* @param  QrCode qrCode
100 	* @return string
101 	*/
102     public string render(QrCode qrCode)
103     {
104 		import std.array;
105         Appender!string result = appender!string();
106         auto matrix = qrCode.matrix();
107         auto width  = matrix.width();
108         // Top margin
109         for (auto x = 0; x < this.margin; x++) {
110             //result .= str_repeat(this.emptyBlock, width + 2 * this.margin)."\n";
111 			result.put(replicate(this.emptyBlock, width + 2 * this.margin));
112 			result.put("\n");
113         }
114         // Body
115         auto array = matrix.getArray();
116         foreach (row ; array) {
117             //result .= str_repeat(this.emptyBlock, this.margin); // left margin
118 			result.put(replicate(this.emptyBlock, this.margin));
119             foreach (_byte ; row) {
120                 //result .= byte ? this.fullBlock : this.emptyBlock;
121 				result.put(_byte ? this.fullBlock : this.emptyBlock);
122             }
123             //result .= str_repeat(this.emptyBlock, this.margin); // right margin
124 			result.put(replicate(this.emptyBlock, this.margin));
125            // result .= "\n";
126 			result.put("\n");
127         }
128         // Bottom margin
129         for (auto x = 0; x < this.margin; x++) {
130 			// result .= str_repeat(this.emptyBlock, width + 2 * this.margin)."\n";
131 			result.put(replicate(this.emptyBlock, width + 2 * this.margin));
132 			result.put("\n");
133         }
134         return result.data;
135     }
136 
137 	public void initRender(){};
138 	public void addColor(string id, ColorInterface color){}
139 	public void drawBackground(string colorId){}
140 	public void drawBlock(int x, int y, string colorId){}
141 	public string getByteStream(){
142 		return string.init;
143 	}
144 }