root / UFGraphAli.pas
Historique | Voir | Annoter | Télécharger (17,899 ko)
1 |
unit UFGraphAli ;
|
---|---|
2 |
|
3 |
interface
|
4 |
|
5 |
uses
|
6 |
Windows, Forms, Classes, Controls, Messages, Graphics, Dialogs, StdCtrls, |
7 |
ExtCtrls, Menus, Chart, Series, TeeProcs, TeEngine; |
8 |
|
9 |
type
|
10 |
TFGraphAli = class(TForm)
|
11 |
GBConfig: TGroupBox; |
12 |
CBOnglet: TComboBox; |
13 |
Graph: TChart; |
14 |
Series1: TPieSeries; |
15 |
RBCrois: TRadioButton; |
16 |
RBTruie: TRadioButton; |
17 |
PM: TPopupMenu; |
18 |
MI3D: TMenuItem; |
19 |
MIPrint: TMenuItem; |
20 |
CBTSAA: TComboBox; |
21 |
CBTSMineraux: TComboBox; |
22 |
CBTSFibres: TComboBox; |
23 |
CBTSElem: TComboBox; |
24 |
CBTSAG: TComboBox; |
25 |
MIPreview: TMenuItem; |
26 |
PD: TPrintDialog; |
27 |
procedure FormShow(Sender: TObject);
|
28 |
procedure CBOngletChange(Sender: TObject);
|
29 |
procedure RBTypeClick(Sender: TObject);
|
30 |
procedure CBTSElemChange(Sender: TObject);
|
31 |
procedure CBTSAAChange(Sender: TObject);
|
32 |
procedure CBTSAGChange(Sender: TObject);
|
33 |
procedure CBTSMinerauxChange(Sender: TObject);
|
34 |
procedure CBTSFibresChange(Sender: TObject);
|
35 |
procedure MI3DClick(Sender: TObject);
|
36 |
procedure MIPreviewClick(Sender: TObject);
|
37 |
procedure MIPrintClick(Sender: TObject);
|
38 |
procedure FormCreate(Sender: TObject);
|
39 |
procedure WMSysCommand(var Message: TWMSysCommand); message WM_SYSCOMMAND; |
40 |
private
|
41 |
{ D?clarations priv?es }
|
42 |
procedure AffGraph ;
|
43 |
public
|
44 |
{ D?clarations publiques }
|
45 |
end;
|
46 |
|
47 |
var
|
48 |
FGraphAli: TFGraphAli; |
49 |
|
50 |
implementation
|
51 |
|
52 |
uses
|
53 |
Printers, SysUtils, gnugettext, UVariables, UStrings, UFindRec, UUtil, |
54 |
UFAliment, UFPrevGraph; |
55 |
|
56 |
{$R *.dfm}
|
57 |
|
58 |
{ TFGraphAli }
|
59 |
|
60 |
procedure TFGraphAli.FormCreate(Sender: TObject);
|
61 |
begin
|
62 |
if Screen.Fonts.IndexOf('Arial Unicode MS') <> -1 |
63 |
then
|
64 |
Font.Name := 'Arial Unicode MS';
|
65 |
TranslateComponent(Self); |
66 |
Constraints.MinWidth := 544 + (Width - ClientWidth);
|
67 |
Width := 640;
|
68 |
Constraints.MinHeight := 354 + (Height - ClientHeight);
|
69 |
Height := 480;
|
70 |
CBOnglet.ItemIndex := 0;
|
71 |
CBTSElem.ItemIndex := 0;
|
72 |
end;
|
73 |
|
74 |
procedure TFGraphAli.FormShow (Sender : TObject) ;
|
75 |
begin
|
76 |
MIPrint.Enabled := IsComplete or IsEducation ;
|
77 |
if PAliment.Typ = 2 |
78 |
then
|
79 |
RBTruie.Checked := TRUE |
80 |
else
|
81 |
RBCrois.Checked := TRUE ; |
82 |
Graph.UndoZoom ; |
83 |
Graph.Foot.Text.Clear ; |
84 |
Graph.Foot.Text.Add (PAliment.Nom) ; |
85 |
Series1.OtherSlice.Text := StrAutres ; |
86 |
Series1.Marks.ArrowLength := 24 ;
|
87 |
CBOngletChange (nil) ;
|
88 |
end ;
|
89 |
|
90 |
procedure TFGraphAli.CBOngletChange (Sender : TObject) ;
|
91 |
begin
|
92 |
case CBOnglet.ItemIndex of |
93 |
0 : // Composition ?l?mentaire |
94 |
begin
|
95 |
CBTSElem.Visible := TRUE ; |
96 |
CBTSAA.Visible := FALSE ; |
97 |
CBTSAG.Visible := FALSE ; |
98 |
CBTSMineraux.Visible := FALSE ; |
99 |
CBTSFibres.Visible := FALSE ; |
100 |
CBTSElemChange (nil) ;
|
101 |
end ;
|
102 |
1 : // Acides amin?s |
103 |
begin
|
104 |
CBTSElem.Visible := FALSE ; |
105 |
CBTSAA.Visible := TRUE ; |
106 |
CBTSAG.Visible := FALSE ; |
107 |
CBTSMineraux.Visible := FALSE ; |
108 |
CBTSFibres.Visible := FALSE ; |
109 |
CBTSAAChange (nil) ;
|
110 |
end ;
|
111 |
2 : // Acides gras |
112 |
begin
|
113 |
CBTSElem.Visible := FALSE ; |
114 |
CBTSAA.Visible := FALSE ; |
115 |
CBTSAG.Visible := TRUE ; |
116 |
CBTSMineraux.Visible := FALSE ; |
117 |
CBTSFibres.Visible := FALSE ; |
118 |
CBTSAGChange (nil) ;
|
119 |
end ;
|
120 |
3 : // Min?raux |
121 |
begin
|
122 |
CBTSElem.Visible := FALSE ; |
123 |
CBTSAA.Visible := FALSE ; |
124 |
CBTSAG.Visible := FALSE ; |
125 |
CBTSMineraux.Visible := TRUE ; |
126 |
CBTSFibres.Visible := FALSE ; |
127 |
CBTSMinerauxChange (nil) ;
|
128 |
end ;
|
129 |
4 : // Fibres |
130 |
begin
|
131 |
CBTSElem.Visible := FALSE ; |
132 |
CBTSAA.Visible := FALSE ; |
133 |
CBTSAG.Visible := FALSE ; |
134 |
CBTSMineraux.Visible := FALSE ; |
135 |
CBTSFibres.Visible := TRUE ; |
136 |
CBTSFibresChange (nil) ;
|
137 |
end ;
|
138 |
end ;
|
139 |
end ;
|
140 |
|
141 |
procedure TFGraphAli.CBTSElemChange (Sender : TObject) ;
|
142 |
begin
|
143 |
Graph.Title.Text.Clear ; |
144 |
if CBTSElem.ItemIndex in [8, 9, 10, 12, 13, 14] |
145 |
then
|
146 |
begin
|
147 |
if RBCrois.Checked
|
148 |
then
|
149 |
Graph.Title.Text.Add (Format ('%s (%s)', [CBTSElem.Text, RBCrois.Caption]))
|
150 |
else
|
151 |
Graph.Title.Text.Add (Format ('%s (%s)', [CBTSElem.Text, RBTruie.Caption])) ;
|
152 |
RBCrois.Enabled := TRUE ; |
153 |
RBTruie.Enabled := TRUE ; |
154 |
end
|
155 |
else
|
156 |
begin
|
157 |
Graph.Title.Text.Add (CBTSElem.Text) ; |
158 |
RBCrois.Enabled := FALSE ; |
159 |
RBTruie.Enabled := FALSE ; |
160 |
end ;
|
161 |
AffGraph ; |
162 |
end ;
|
163 |
|
164 |
procedure TFGraphAli.CBTSAAChange (Sender : TObject) ;
|
165 |
begin
|
166 |
Graph.Title.Text.Clear ; |
167 |
Graph.Title.Text.Add (CBTSAA.Text) ; |
168 |
RBCrois.Enabled := FALSE ; |
169 |
RBTruie.Enabled := FALSE ; |
170 |
AffGraph ; |
171 |
end ;
|
172 |
|
173 |
procedure TFGraphAli.CBTSAGChange (Sender : TObject) ;
|
174 |
begin
|
175 |
Graph.Title.Text.Clear ; |
176 |
Graph.Title.Text.Add (CBTSAG.Text) ; |
177 |
RBCrois.Enabled := FALSE ; |
178 |
RBTruie.Enabled := FALSE ; |
179 |
AffGraph ; |
180 |
end ;
|
181 |
|
182 |
procedure TFGraphAli.CBTSMinerauxChange (Sender : TObject) ;
|
183 |
begin
|
184 |
Graph.Title.Text.Clear ; |
185 |
Graph.Title.Text.Add (CBTSMineraux.Text) ; |
186 |
RBCrois.Enabled := FALSE ; |
187 |
RBTruie.Enabled := FALSE ; |
188 |
AffGraph ; |
189 |
end ;
|
190 |
|
191 |
procedure TFGraphAli.CBTSFibresChange (Sender : TObject) ;
|
192 |
begin
|
193 |
Graph.Title.Text.Clear ; |
194 |
Graph.Title.Text.Add (CBTSFibres.Text) ; |
195 |
RBCrois.Enabled := FALSE ; |
196 |
RBTruie.Enabled := FALSE ; |
197 |
AffGraph ; |
198 |
end ;
|
199 |
|
200 |
procedure TFGraphAli.AffGraph ;
|
201 |
var
|
202 |
i, d : integer ; |
203 |
t, v : double ; |
204 |
u : string ;
|
205 |
begin
|
206 |
t := 0 ;
|
207 |
Series1.Clear ; |
208 |
for i := 0 to PAliment.MP.NbMat - 1 do |
209 |
begin
|
210 |
PMatiere := ListMatiere[FindIdxMatiere(FindNomMatiere(PAliment.MP.NumMat[i]))] ; |
211 |
case CBOnglet.ItemIndex of |
212 |
0 : // Composition ?l?mentaire |
213 |
case CBTSElem.ItemIndex of |
214 |
0 : // Frais |
215 |
v := PAliment.MP.Qte[i] ; |
216 |
1 : // Mati?re s?che |
217 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 ;
|
218 |
2 : // Mati?res min?rales |
219 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.MM / 1000 ; |
220 |
3 : // Mati?re organique |
221 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.MO / 1000 ; |
222 |
4 : // Mati?res grasses |
223 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 ; |
224 |
5 : // Mati?res azot?es |
225 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.MAT / 1000 ; |
226 |
6 : // Amidon |
227 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Amidon / 1000 ; |
228 |
7 : // Sucres |
229 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Sucres / 1000 ; |
230 |
8 : // Mati?re organique digestible |
231 |
if RBCrois.Checked
|
232 |
then
|
233 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.MO / 1000 * PMatiere.CC.dMO_C / 100 |
234 |
else
|
235 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.MO / 1000 * PMatiere.CC.dMO_T / 100 ; |
236 |
9 : // Mati?res grasses digestible |
237 |
if RBCrois.Checked
|
238 |
then
|
239 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.dLip_C / 100 |
240 |
else
|
241 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.dLip_T / 100 ; |
242 |
10 : // Mati?res azot?es digestible |
243 |
if RBCrois.Checked
|
244 |
then
|
245 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.MAT / 1000 * PMatiere.CC.dMAT_C / 100 |
246 |
else
|
247 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.MAT / 1000 * PMatiere.CC.dMAT_T / 100 ; |
248 |
11 : // Energie brute |
249 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.EB / 1000 ; |
250 |
12 : // Energie digestible |
251 |
if RBCrois.Checked
|
252 |
then
|
253 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.ED_C / 1000 |
254 |
else
|
255 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.ED_T / 1000 ; |
256 |
13 : // Energie m?tabolisable |
257 |
if RBCrois.Checked
|
258 |
then
|
259 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.EM_C / 1000 |
260 |
else
|
261 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.EM_T / 1000 ; |
262 |
14 : // Energie nette |
263 |
if RBCrois.Checked
|
264 |
then
|
265 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.EN_C / 1000 |
266 |
else
|
267 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.EN_T / 1000 ; |
268 |
else
|
269 |
v := 0 ;
|
270 |
end ;
|
271 |
1 : // Acides amin?s |
272 |
case CBTSAA.ItemIndex of |
273 |
0..12 : // Teneurs |
274 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.AAtotal[CBTSAA.ItemIndex] / 1000 ; |
275 |
13..25 : // Teneurs digestibles |
276 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.AAtotal[CBTSAA.ItemIndex - 13] / 1000 * PMatiere.CUDAA[CBTSAA.ItemIndex - 13] / 100 ; |
277 |
else
|
278 |
v := 0 ;
|
279 |
end ;
|
280 |
2 : // Acides gras |
281 |
case CBTSAG.ItemIndex of |
282 |
0 : // C6:0 + C8:0 + C10:0 |
283 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C6C8C10 / 100 ; |
284 |
1 : // C12:0 |
285 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C12_0 / 100 ; |
286 |
2 : // C14:0 |
287 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C14_0 / 100 ; |
288 |
3 : // C16:0 |
289 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C16_0 / 100 ; |
290 |
4 : // C16:1 |
291 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C16_1 / 100 ; |
292 |
5 : // C18:0 |
293 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C18_0 / 100 ; |
294 |
6 : // C18:1 |
295 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C18_1 / 100 ; |
296 |
7 : // C18:2 |
297 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C18_2 / 100 ; |
298 |
8 : // C18:3 |
299 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C18_3 / 100 ; |
300 |
9 : // C18:4 |
301 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C18_4 / 100 ; |
302 |
10 : // C20:0 |
303 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C20_0 / 100 ; |
304 |
11 : // C20:1 |
305 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C20_1 / 100 ; |
306 |
12 : // C20:4 |
307 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C20_4 / 100 ; |
308 |
13 : // C20:5 |
309 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C20_5 / 100 ; |
310 |
14 : // C22:0 |
311 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C22_0 / 100 ; |
312 |
15 : // C22:1 |
313 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C22_1 / 100 ; |
314 |
16 : // C22:5 |
315 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C22_5 / 100 ; |
316 |
17 : // C22:6 |
317 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C22_6 / 100 ; |
318 |
18 : // C24:0 |
319 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Lip / 1000 * PMatiere.CC.AGsLip / 100 * PMatiere.CC.C24_0 / 100 ; |
320 |
else
|
321 |
v := 0 ;
|
322 |
end ;
|
323 |
3 : // Min?raux |
324 |
case CBTSMineraux.ItemIndex of |
325 |
0 : // Calcium (Ca) |
326 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Ca / 1000 ; |
327 |
1 : // Phosphore (P) |
328 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.P / 1000 ; |
329 |
2 : // Sodium (Na) |
330 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Na / 1000 ; |
331 |
3 : // Potassium (K) |
332 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.K / 1000 ; |
333 |
4 : // Magn?sium (Mg) |
334 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Mg / 1000 ; |
335 |
5 : // Chlore (Cl) |
336 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Cl / 1000 ; |
337 |
6 : // Soufre (S) |
338 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.S / 1000 ; |
339 |
7 : // Cuivre (Cu) |
340 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Cu / 1000 ; |
341 |
8 : // Zinc (Zn) |
342 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Zn / 1000 ; |
343 |
9 : // Mangan?se (Mn) |
344 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Mn / 1000 ; |
345 |
10 : // Fer (Fe) |
346 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Fe / 1000 ; |
347 |
11 : // S?l?nium (Se) |
348 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Se / 1000 ; |
349 |
12 : // Cobalt (Co) |
350 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Co / 1000 ; |
351 |
13 : // Molybd?ne (Mo) |
352 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Mb / 1000 ; |
353 |
14 : // Iode (I) |
354 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.I / 1000 ; |
355 |
15 : // Phosphore digestible |
356 |
if PAliment.Presentation = 0 |
357 |
then // Granul?s |
358 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.PdigG / 1000 |
359 |
else // Farine |
360 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.PdigF / 1000 ; |
361 |
16 : // Phosphore phytique |
362 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.P / 1000 * PMatiere.CC.Phytase / 100 ; |
363 |
17 : // Activit? phytasique |
364 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * (PMatiere.CC.ActPhytE + PMatiere.CC.ActPhytM) / 1000 ; |
365 |
else
|
366 |
v := 0 ;
|
367 |
end ;
|
368 |
4 : // Fibres |
369 |
case CBTSFibres.ItemIndex of |
370 |
0 : // Cellulose brute |
371 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.CB / 1000 ; |
372 |
1 : // NDF |
373 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.NDF / 1000 ; |
374 |
2 : // ADF |
375 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.ADF / 1000 ; |
376 |
3 : // ADL |
377 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.ADL / 1000 ; |
378 |
4 : // Parois v?g?tale |
379 |
v := PAliment.MP.Qte[i] * PAliment.MP.MS[i] / 1000 * PMatiere.CC.Parois / 1000 ; |
380 |
else
|
381 |
v := 0 ;
|
382 |
end ;
|
383 |
else
|
384 |
v := 0 ;
|
385 |
end ;
|
386 |
// Series1.AddPie (v, PMatiere.Nom) ;
|
387 |
if PMatiere.Num > 0 |
388 |
then // Mati?re premi?re utilisateur |
389 |
Series1.AddPie(v, PMatiere.Nom) |
390 |
else // Mati?re premi?re INRA-AFZ (traduction) |
391 |
Series1.AddPie(v, dgettext('InraAfz', PMatiere.Nom));
|
392 |
t := t + v ; |
393 |
end ;
|
394 |
case CBOnglet.ItemIndex of |
395 |
0 : // Composition ?l?mentaire |
396 |
case CBTSElem.ItemIndex of |
397 |
11..14 : // Valeurs ?nerg?tiques |
398 |
begin
|
399 |
d := 1 ;
|
400 |
u := Format ('%s/%s %s', [StrMJ, StrKg, StrFrais]) ;
|
401 |
end ;
|
402 |
else // Teneur et digestibilit? f?cale |
403 |
begin
|
404 |
d := 0 ;
|
405 |
u := Format ('%s/%s %s', [StrG, StrKg, StrFrais]) ;
|
406 |
end ;
|
407 |
end ;
|
408 |
3 : // Min?raux |
409 |
case CBTSMineraux.ItemIndex of |
410 |
7..14 : // Oligo-?l?ments |
411 |
begin
|
412 |
d := 2 ;
|
413 |
u := Format ('%s/%s %s', [StrMg, StrKg, StrFrais]) ;
|
414 |
end ;
|
415 |
17 : // Activit? phytasique |
416 |
begin
|
417 |
d := 0 ;
|
418 |
u := Format ('%s/%s %s', [StrUI, StrKg, StrFrais]) ;
|
419 |
end ;
|
420 |
else // Macro-?l?ments / Phosphore digestible / Phosphore phytique |
421 |
begin
|
422 |
d := 2 ;
|
423 |
u := Format ('%s/%s %s', [StrG, StrKg, StrFrais]) ;
|
424 |
end ;
|
425 |
end ;
|
426 |
4 : // Fibres |
427 |
begin
|
428 |
d := 1 ;
|
429 |
u := Format ('%s/%s %s', [StrG, StrKg, StrFrais]) ;
|
430 |
end ;
|
431 |
else // Acides amin?s / Acides gras |
432 |
begin
|
433 |
d := 2 ;
|
434 |
u := Format ('%s/%s %s', [StrG, StrKg, StrFrais]) ;
|
435 |
end ;
|
436 |
end ;
|
437 |
// Je m'assure que le frais est de 1000 g/kg
|
438 |
t := t / FAliment.PBTotal.AsFloat * 1000 ;
|
439 |
Graph.SubTitle.Text.Clear ; |
440 |
Graph.SubTitle.Text.Add (Format ('Total : %1.*f %s', [d, t, u])) ;
|
441 |
if t = 0 |
442 |
then
|
443 |
Series1.Active := FALSE |
444 |
else
|
445 |
Series1.Active := TRUE ; |
446 |
end ;
|
447 |
|
448 |
procedure TFGraphAli.RBTypeClick (Sender : TObject) ;
|
449 |
begin
|
450 |
CBTSElemChange (nil) ;
|
451 |
end ;
|
452 |
|
453 |
procedure TFGraphAli.MI3DClick (Sender : TObject) ;
|
454 |
begin
|
455 |
Graph.View3D := not (Graph.View3D) ;
|
456 |
end ;
|
457 |
|
458 |
procedure TFGraphAli.MIPreviewClick (Sender : TObject) ;
|
459 |
begin
|
460 |
FPrevGraph := TFPrevGraph.Create (Self) ; |
461 |
with FPrevGraph do |
462 |
begin
|
463 |
TPPGraph.Panels.Add (Graph) ; |
464 |
ShowModal ; |
465 |
Release ; |
466 |
end ;
|
467 |
end ;
|
468 |
|
469 |
procedure TFGraphAli.MIPrintClick (Sender : TObject) ;
|
470 |
begin
|
471 |
if PD.Execute
|
472 |
then
|
473 |
begin
|
474 |
Printer.Orientation := poLandscape ; |
475 |
Graph.Print ; |
476 |
end ;
|
477 |
end ;
|
478 |
|
479 |
procedure TFGraphAli.WMSysCommand(var Message: TWMSysCommand); |
480 |
begin
|
481 |
if Message.CmdType = SC_MINIMIZE
|
482 |
then
|
483 |
Application.Minimize |
484 |
else
|
485 |
inherited;
|
486 |
end;
|
487 |
|
488 |
end.
|