From ce599e4f9f94b4eb00c1b5edb85bce5431ab3df2 Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdeedu@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kalzium/ChangeLog | 30 + kalzium/Makefile.am | 6 + kalzium/README.packagers | 14 + kalzium/RELEASE-PLAN | 70 + kalzium/TODO | 109 + kalzium/configure.in.bot | 26 + kalzium/configure.in.in | 66 + kalzium/src/Makefile.am | 100 + kalzium/src/data/Makefile.am | 6 + kalzium/src/data/bg.jpg | Bin 0 -> 11255 bytes kalzium/src/data/data.dtd | 23 + kalzium/src/data/data.xml | 4879 +++++++++++++++++++++ kalzium/src/data/knowledge.xml | 283 ++ kalzium/src/data/knowledge.xml.todo | 1282 ++++++ kalzium/src/data/toolpics/Makefile.am | 42 + kalzium/src/data/toolpics/abzug.jpg | Bin 0 -> 30460 bytes kalzium/src/data/toolpics/becherglas.jpg | Bin 0 -> 31131 bytes kalzium/src/data/toolpics/brechungsmesser.jpg | Bin 0 -> 45480 bytes kalzium/src/data/toolpics/brenner.jpg | Bin 0 -> 20585 bytes kalzium/src/data/toolpics/destillierbruecke.jpg | Bin 0 -> 43252 bytes kalzium/src/data/toolpics/dsc.jpg | Bin 0 -> 25806 bytes kalzium/src/data/toolpics/erlenmeyerkolben.jpg | Bin 0 -> 24780 bytes kalzium/src/data/toolpics/exikator.jpg | Bin 0 -> 64372 bytes kalzium/src/data/toolpics/halter.jpg | Bin 0 -> 36157 bytes kalzium/src/data/toolpics/heizplatte.jpg | Bin 0 -> 31325 bytes kalzium/src/data/toolpics/hplc.jpg | Bin 0 -> 25651 bytes kalzium/src/data/toolpics/kolbenprober.png | Bin 0 -> 2008 bytes kalzium/src/data/toolpics/korkring.jpg | Bin 0 -> 26377 bytes kalzium/src/data/toolpics/messzylinder.jpg | Bin 0 -> 27754 bytes kalzium/src/data/toolpics/moerser.jpg | Bin 0 -> 37467 bytes kalzium/src/data/toolpics/phpapier.jpg | Bin 0 -> 24457 bytes kalzium/src/data/toolpics/pileusball.jpg | Bin 0 -> 36030 bytes kalzium/src/data/toolpics/pipette.jpg | Bin 0 -> 22077 bytes kalzium/src/data/toolpics/rg-halter.jpg | Bin 0 -> 35934 bytes kalzium/src/data/toolpics/rg-staender.jpg | Bin 0 -> 64250 bytes kalzium/src/data/toolpics/rg.jpg | Bin 0 -> 29212 bytes kalzium/src/data/toolpics/rotationsverdampfer.jpg | Bin 0 -> 31383 bytes kalzium/src/data/toolpics/rueckflusskuehler.jpg | Bin 0 -> 25041 bytes kalzium/src/data/toolpics/ruehrfisch.jpg | Bin 0 -> 37029 bytes kalzium/src/data/toolpics/rundkolben.jpg | Bin 0 -> 32033 bytes kalzium/src/data/toolpics/scheidetrichter.jpg | Bin 0 -> 23790 bytes kalzium/src/data/toolpics/schutzbrille.jpg | Bin 0 -> 34337 bytes kalzium/src/data/toolpics/spatel.jpg | Bin 0 -> 25335 bytes kalzium/src/data/toolpics/spritzflasche.jpg | Bin 0 -> 16592 bytes kalzium/src/data/toolpics/thermometer.jpg | Bin 0 -> 14182 bytes kalzium/src/data/toolpics/thermometer2.jpg | Bin 0 -> 26858 bytes kalzium/src/data/toolpics/tonschale.jpg | Bin 0 -> 26600 bytes kalzium/src/data/toolpics/trichter.jpg | Bin 0 -> 11213 bytes kalzium/src/data/toolpics/trockenrohr.jpg | Bin 0 -> 18599 bytes kalzium/src/data/toolpics/tropftrichter.jpg | Bin 0 -> 20472 bytes kalzium/src/data/toolpics/uhrglas.jpg | Bin 0 -> 16195 bytes kalzium/src/data/toolpics/verteiler.jpg | Bin 0 -> 24720 bytes kalzium/src/data/toolpics/vollpipette.jpg | Bin 0 -> 20936 bytes kalzium/src/data/toolpics/waage.jpg | Bin 0 -> 33777 bytes kalzium/src/data/toolpics/wasserstrahlpumpe.jpg | Bin 0 -> 26347 bytes kalzium/src/data/tools.xml | 227 + kalzium/src/data/tools.xml.todo | 50 + kalzium/src/detailedgraphicaloverview.cpp | 232 + kalzium/src/detailedgraphicaloverview.h | 69 + kalzium/src/detailinfodlg.cpp | 497 +++ kalzium/src/detailinfodlg.h | 122 + kalzium/src/element.cpp | 548 +++ kalzium/src/element.h | 515 +++ kalzium/src/elementdataviewer.cpp | 352 ++ kalzium/src/elementdataviewer.h | 147 + kalzium/src/elementpics/Al.jpg | Bin 0 -> 14461 bytes kalzium/src/elementpics/As.jpg | Bin 0 -> 13320 bytes kalzium/src/elementpics/Au.jpg | Bin 0 -> 11654 bytes kalzium/src/elementpics/B.jpg | Bin 0 -> 11642 bytes kalzium/src/elementpics/Be.jpg | Bin 0 -> 11644 bytes kalzium/src/elementpics/Bi.jpg | Bin 0 -> 15090 bytes kalzium/src/elementpics/Br.jpg | Bin 0 -> 6323 bytes kalzium/src/elementpics/C.jpg | Bin 0 -> 12778 bytes kalzium/src/elementpics/Ca.jpg | Bin 0 -> 12047 bytes kalzium/src/elementpics/Cd.jpg | Bin 0 -> 14345 bytes kalzium/src/elementpics/Cl.jpg | Bin 0 -> 4453 bytes kalzium/src/elementpics/Co.jpg | Bin 0 -> 14371 bytes kalzium/src/elementpics/Cr.jpg | Bin 0 -> 12953 bytes kalzium/src/elementpics/Cu.jpg | Bin 0 -> 12388 bytes kalzium/src/elementpics/F.jpg | Bin 0 -> 10542 bytes kalzium/src/elementpics/Fe.jpg | Bin 0 -> 14847 bytes kalzium/src/elementpics/Ga.jpg | Bin 0 -> 13441 bytes kalzium/src/elementpics/Ge.jpg | Bin 0 -> 13744 bytes kalzium/src/elementpics/H.jpg | Bin 0 -> 9917 bytes kalzium/src/elementpics/He.jpg | Bin 0 -> 10289 bytes kalzium/src/elementpics/Hg.jpg | Bin 0 -> 14241 bytes kalzium/src/elementpics/I.jpg | Bin 0 -> 10987 bytes kalzium/src/elementpics/In.jpg | Bin 0 -> 12619 bytes kalzium/src/elementpics/K.jpg | Bin 0 -> 11681 bytes kalzium/src/elementpics/Kr.jpg | Bin 0 -> 10412 bytes kalzium/src/elementpics/Li.jpg | Bin 0 -> 10127 bytes kalzium/src/elementpics/Makefile.am | 3 + kalzium/src/elementpics/Mg.jpg | Bin 0 -> 11770 bytes kalzium/src/elementpics/Mn.jpg | Bin 0 -> 12522 bytes kalzium/src/elementpics/Mo.jpg | Bin 0 -> 11475 bytes kalzium/src/elementpics/N.jpg | Bin 0 -> 9386 bytes kalzium/src/elementpics/Na.jpg | Bin 0 -> 10846 bytes kalzium/src/elementpics/Nb.jpg | Bin 0 -> 11546 bytes kalzium/src/elementpics/Ne.jpg | Bin 0 -> 10653 bytes kalzium/src/elementpics/Ni.jpg | Bin 0 -> 11282 bytes kalzium/src/elementpics/O.jpg | Bin 0 -> 9275 bytes kalzium/src/elementpics/P.jpg | Bin 0 -> 10595 bytes kalzium/src/elementpics/Pb.jpg | Bin 0 -> 11723 bytes kalzium/src/elementpics/Pd.jpg | Bin 0 -> 12028 bytes kalzium/src/elementpics/Pt.jpg | Bin 0 -> 13352 bytes kalzium/src/elementpics/Re.jpg | Bin 0 -> 11582 bytes kalzium/src/elementpics/Rh.jpg | Bin 0 -> 10836 bytes kalzium/src/elementpics/S.jpg | Bin 0 -> 10339 bytes kalzium/src/elementpics/Sb.jpg | Bin 0 -> 14329 bytes kalzium/src/elementpics/Se.jpg | Bin 0 -> 12707 bytes kalzium/src/elementpics/Si.jpg | Bin 0 -> 11240 bytes kalzium/src/elementpics/Sn.jpg | Bin 0 -> 13722 bytes kalzium/src/elementpics/Ta.jpg | Bin 0 -> 11378 bytes kalzium/src/elementpics/Te.jpg | Bin 0 -> 11402 bytes kalzium/src/elementpics/Th.jpg | Bin 0 -> 11633 bytes kalzium/src/elementpics/Ti.jpg | Bin 0 -> 11922 bytes kalzium/src/elementpics/U.jpg | Bin 0 -> 12441 bytes kalzium/src/elementpics/V.jpg | Bin 0 -> 10911 bytes kalzium/src/elementpics/W.jpg | Bin 0 -> 13506 bytes kalzium/src/elementpics/Xe.jpg | Bin 0 -> 10017 bytes kalzium/src/elementpics/Zn.jpg | Bin 0 -> 10101 bytes kalzium/src/elementpics/Zr.jpg | Bin 0 -> 9520 bytes kalzium/src/eqchemview.cpp | 121 + kalzium/src/eqchemview.h | 104 + kalzium/src/eqresult.cpp | 128 + kalzium/src/eqresult.h | 90 + kalzium/src/exporter.cpp | 62 + kalzium/src/exporter.h | 54 + kalzium/src/hi128-app-kalzium.png | Bin 0 -> 6890 bytes kalzium/src/hi16-app-kalzium.png | Bin 0 -> 628 bytes kalzium/src/hi22-app-kalzium.png | Bin 0 -> 734 bytes kalzium/src/hi32-app-kalzium.png | Bin 0 -> 1370 bytes kalzium/src/hi48-app-kalzium.png | Bin 0 -> 2227 bytes kalzium/src/hi64-app-kalzium.png | Bin 0 -> 3094 bytes kalzium/src/hisc-app-kalzium.svgz | Bin 0 -> 1271 bytes kalzium/src/icons/Makefile.am | 4 + kalzium/src/icons/cr16-action-calculate.png | Bin 0 -> 416 bytes kalzium/src/icons/cr16-action-chemical.png | Bin 0 -> 863 bytes kalzium/src/icons/cr16-action-elempic.png | Bin 0 -> 819 bytes kalzium/src/icons/cr16-action-energies.png | Bin 0 -> 960 bytes kalzium/src/icons/cr16-action-eqchem.png | Bin 0 -> 653 bytes kalzium/src/icons/cr16-action-glossary.png | Bin 0 -> 922 bytes kalzium/src/icons/cr16-action-isotopemap.png | Bin 0 -> 447 bytes kalzium/src/icons/cr16-action-legend.png | Bin 0 -> 327 bytes kalzium/src/icons/cr16-action-misc.png | Bin 0 -> 329 bytes kalzium/src/icons/cr16-action-orbits.png | Bin 0 -> 589 bytes kalzium/src/icons/cr16-action-overview.png | Bin 0 -> 681 bytes kalzium/src/icons/cr16-action-plot.png | Bin 0 -> 585 bytes kalzium/src/icons/cr16-action-sidebar.png | Bin 0 -> 516 bytes kalzium/src/icons/cr16-action-spectrum.png | Bin 0 -> 270 bytes kalzium/src/icons/cr16-action-statematter.png | Bin 0 -> 706 bytes kalzium/src/icons/cr16-action-timeline.png | Bin 0 -> 538 bytes kalzium/src/icons/cr16-action-tooltip.png | Bin 0 -> 458 bytes kalzium/src/icons/cr22-action-calculate.png | Bin 0 -> 493 bytes kalzium/src/icons/cr22-action-chemical.png | Bin 0 -> 1114 bytes kalzium/src/icons/cr22-action-elempic.png | Bin 0 -> 1217 bytes kalzium/src/icons/cr22-action-energies.png | Bin 0 -> 702 bytes kalzium/src/icons/cr22-action-eqchem.png | Bin 0 -> 868 bytes kalzium/src/icons/cr22-action-glossary.png | Bin 0 -> 1264 bytes kalzium/src/icons/cr22-action-isotopemap.png | Bin 0 -> 380 bytes kalzium/src/icons/cr22-action-legend.png | Bin 0 -> 1066 bytes kalzium/src/icons/cr22-action-orbits.png | Bin 0 -> 887 bytes kalzium/src/icons/cr22-action-overview.png | Bin 0 -> 952 bytes kalzium/src/icons/cr22-action-plot.png | Bin 0 -> 804 bytes kalzium/src/icons/cr22-action-sidebar.png | Bin 0 -> 677 bytes kalzium/src/icons/cr22-action-spectrum.png | Bin 0 -> 321 bytes kalzium/src/icons/cr22-action-statematter.png | Bin 0 -> 1036 bytes kalzium/src/icons/cr22-action-timeline.png | Bin 0 -> 713 bytes kalzium/src/icons/cr22-action-tooltip.png | Bin 0 -> 611 bytes kalzium/src/icons/cr32-action-calculate.png | Bin 0 -> 633 bytes kalzium/src/icons/cr32-action-chemical.png | Bin 0 -> 2196 bytes kalzium/src/icons/cr32-action-elempic.png | Bin 0 -> 2032 bytes kalzium/src/icons/cr32-action-energies.png | Bin 0 -> 2285 bytes kalzium/src/icons/cr32-action-eqchem.png | Bin 0 -> 1395 bytes kalzium/src/icons/cr32-action-glossary.png | Bin 0 -> 2157 bytes kalzium/src/icons/cr32-action-isotopemap.png | Bin 0 -> 725 bytes kalzium/src/icons/cr32-action-legend.png | Bin 0 -> 1673 bytes kalzium/src/icons/cr32-action-misc.png | Bin 0 -> 676 bytes kalzium/src/icons/cr32-action-orbits.png | Bin 0 -> 1367 bytes kalzium/src/icons/cr32-action-overview.png | Bin 0 -> 1179 bytes kalzium/src/icons/cr32-action-plot.png | Bin 0 -> 1127 bytes kalzium/src/icons/cr32-action-sidebar.png | Bin 0 -> 805 bytes kalzium/src/icons/cr32-action-spectrum.png | Bin 0 -> 388 bytes kalzium/src/icons/cr32-action-statematter.png | Bin 0 -> 1453 bytes kalzium/src/icons/cr32-action-timeline.png | Bin 0 -> 999 bytes kalzium/src/icons/cr32-action-tooltip.png | Bin 0 -> 861 bytes kalzium/src/icons/cr48-action-calculate.png | Bin 0 -> 932 bytes kalzium/src/icons/cr48-action-chemical.png | Bin 0 -> 3932 bytes kalzium/src/icons/cr48-action-elempic.png | Bin 0 -> 2032 bytes kalzium/src/icons/cr48-action-energies.png | Bin 0 -> 3704 bytes kalzium/src/icons/cr48-action-eqchem.png | Bin 0 -> 2310 bytes kalzium/src/icons/cr48-action-glossary.png | Bin 0 -> 3406 bytes kalzium/src/icons/cr48-action-isotopemap.png | Bin 0 -> 912 bytes kalzium/src/icons/cr48-action-legend.png | Bin 0 -> 2672 bytes kalzium/src/icons/cr48-action-misc.png | Bin 0 -> 811 bytes kalzium/src/icons/cr48-action-orbits.png | Bin 0 -> 2279 bytes kalzium/src/icons/cr48-action-overview.png | Bin 0 -> 1607 bytes kalzium/src/icons/cr48-action-plot.png | Bin 0 -> 1746 bytes kalzium/src/icons/cr48-action-sidebar.png | Bin 0 -> 1098 bytes kalzium/src/icons/cr48-action-spectrum.png | Bin 0 -> 393 bytes kalzium/src/icons/cr48-action-statematter.png | Bin 0 -> 2332 bytes kalzium/src/icons/cr48-action-timeline.png | Bin 0 -> 1424 bytes kalzium/src/icons/cr48-action-tooltip.png | Bin 0 -> 1223 bytes kalzium/src/icons/crsc-action-calculate.svgz | Bin 0 -> 1599 bytes kalzium/src/icons/crsc-action-chemical.svgz | Bin 0 -> 7817 bytes kalzium/src/icons/crsc-action-elempic.svgz | Bin 0 -> 5397 bytes kalzium/src/icons/crsc-action-energies.svgz | Bin 0 -> 4278 bytes kalzium/src/icons/crsc-action-eqchem.svgz | Bin 0 -> 3688 bytes kalzium/src/icons/crsc-action-glossary.svgz | Bin 0 -> 2540 bytes kalzium/src/icons/crsc-action-isotopemap.svgz | Bin 0 -> 2079 bytes kalzium/src/icons/crsc-action-misc.svgz | Bin 0 -> 1299 bytes kalzium/src/icons/crsc-action-orbits.svgz | 1119 +++++ kalzium/src/icons/crsc-action-overview.svgz | Bin 0 -> 1322 bytes kalzium/src/icons/crsc-action-plot.svgz | Bin 0 -> 1834 bytes kalzium/src/icons/crsc-action-sidebar.svgz | Bin 0 -> 1729 bytes kalzium/src/icons/crsc-action-spectrum.svgz | Bin 0 -> 2521 bytes kalzium/src/icons/crsc-action-statematter.svgz | Bin 0 -> 3642 bytes kalzium/src/icons/crsc-action-timeline.svgz | Bin 0 -> 1785 bytes kalzium/src/icons/crsc-action-tooltip.svgz | Bin 0 -> 2929 bytes kalzium/src/icons/htmlview/Makefile.am | 3 + kalzium/src/icons/htmlview/abundance.png | Bin 0 -> 2716 bytes kalzium/src/icons/htmlview/boilingpoint.png | Bin 0 -> 2360 bytes kalzium/src/icons/htmlview/book.png | Bin 0 -> 867 bytes kalzium/src/icons/htmlview/characteristics.png | Bin 0 -> 247 bytes kalzium/src/icons/htmlview/density.png | Bin 0 -> 1446 bytes kalzium/src/icons/htmlview/discovery.png | Bin 0 -> 1275 bytes kalzium/src/icons/htmlview/electronaffinity.png | Bin 0 -> 1082 bytes kalzium/src/icons/htmlview/header.png | Bin 0 -> 275 bytes kalzium/src/icons/htmlview/icons.svg | 698 +++ kalzium/src/icons/htmlview/ionisation.png | Bin 0 -> 1221 bytes kalzium/src/icons/htmlview/mass.png | Bin 0 -> 661 bytes kalzium/src/icons/htmlview/meltingpoint.png | Bin 0 -> 1339 bytes kalzium/src/icons/htmlview/radius.png | Bin 0 -> 2716 bytes kalzium/src/icons/htmlview/structure.png | Bin 0 -> 1601 bytes kalzium/src/icons/htmlview/style.css | 83 + kalzium/src/isotope.cpp | 76 + kalzium/src/isotope.h | 244 ++ kalzium/src/kalzium.cpp | 578 +++ kalzium/src/kalzium.desktop | 128 + kalzium/src/kalzium.h | 189 + kalzium/src/kalzium.kcfg | 220 + kalzium/src/kalziumdataobject.cpp | 264 ++ kalzium/src/kalziumdataobject.h | 79 + kalzium/src/kalziumtip.cpp | 306 ++ kalzium/src/kalziumtip.h | 88 + kalzium/src/kalziumui.rc | 45 + kalzium/src/kalziumutils.cpp | 88 + kalzium/src/kalziumutils.h | 73 + kalzium/src/main.cpp | 94 + kalzium/src/molcalcwidget.cpp | 153 + kalzium/src/molcalcwidget.h | 80 + kalzium/src/molcalcwidgetbase.ui | 135 + kalzium/src/moleculeparser.cpp | 304 ++ kalzium/src/moleculeparser.h | 138 + kalzium/src/orbitswidget.cpp | 257 ++ kalzium/src/orbitswidget.h | 86 + kalzium/src/parser.cpp | 217 + kalzium/src/parser.h | 105 + kalzium/src/periodictableview.cpp | 1382 ++++++ kalzium/src/periodictableview.h | 523 +++ kalzium/src/plotsetupwidget.ui | 256 ++ kalzium/src/plotwidget.cpp | 69 + kalzium/src/plotwidget.h | 55 + kalzium/src/prefs.kcfgc | 6 + kalzium/src/settings_colors.ui | 936 ++++ kalzium/src/settings_misc.ui | 71 + kalzium/src/settings_units.ui | 167 + kalzium/src/solver/Makefile | 92 + kalzium/src/solver/README | 19 + kalzium/src/solver/calc.ml | 53 + kalzium/src/solver/calc.mli | 3 + kalzium/src/solver/chem.ml | 60 + kalzium/src/solver/chem.mli | 2 + kalzium/src/solver/chemset.ml | 82 + kalzium/src/solver/chemset.mli | 10 + kalzium/src/solver/datastruct.ml | 141 + kalzium/src/solver/datastruct.mli | 23 + kalzium/src/solver/lexer.ml | 189 + kalzium/src/solver/lexer.mll | 41 + kalzium/src/solver/main.c | 46 + kalzium/src/solver/main.ml | 46 + kalzium/src/solver/modwrap.c | 37 + kalzium/src/solver/parser.ml | 317 ++ kalzium/src/solver/parser.mli | 15 + kalzium/src/solver/parser.mly | 83 + kalzium/src/somwidget.ui | 185 + kalzium/src/somwidget_impl.cpp | 172 + kalzium/src/somwidget_impl.h | 63 + kalzium/src/spectrum.cpp | 151 + kalzium/src/spectrum.h | 174 + kalzium/src/spectrumview.ui | 224 + kalzium/src/spectrumviewimpl.cpp | 47 + kalzium/src/spectrumviewimpl.h | 49 + kalzium/src/spectrumwidget.cpp | 430 ++ kalzium/src/spectrumwidget.h | 234 + kalzium/src/tempunit.cpp | 134 + kalzium/src/tempunit.h | 92 + kalzium/src/timewidget.ui | 201 + kalzium/src/timewidget_impl.cpp | 40 + kalzium/src/timewidget_impl.h | 41 + 300 files changed, 23072 insertions(+) create mode 100644 kalzium/ChangeLog create mode 100644 kalzium/Makefile.am create mode 100644 kalzium/README.packagers create mode 100644 kalzium/RELEASE-PLAN create mode 100644 kalzium/TODO create mode 100644 kalzium/configure.in.bot create mode 100644 kalzium/configure.in.in create mode 100644 kalzium/src/Makefile.am create mode 100644 kalzium/src/data/Makefile.am create mode 100644 kalzium/src/data/bg.jpg create mode 100644 kalzium/src/data/data.dtd create mode 100644 kalzium/src/data/data.xml create mode 100644 kalzium/src/data/knowledge.xml create mode 100644 kalzium/src/data/knowledge.xml.todo create mode 100644 kalzium/src/data/toolpics/Makefile.am create mode 100644 kalzium/src/data/toolpics/abzug.jpg create mode 100644 kalzium/src/data/toolpics/becherglas.jpg create mode 100644 kalzium/src/data/toolpics/brechungsmesser.jpg create mode 100644 kalzium/src/data/toolpics/brenner.jpg create mode 100644 kalzium/src/data/toolpics/destillierbruecke.jpg create mode 100644 kalzium/src/data/toolpics/dsc.jpg create mode 100644 kalzium/src/data/toolpics/erlenmeyerkolben.jpg create mode 100644 kalzium/src/data/toolpics/exikator.jpg create mode 100644 kalzium/src/data/toolpics/halter.jpg create mode 100644 kalzium/src/data/toolpics/heizplatte.jpg create mode 100644 kalzium/src/data/toolpics/hplc.jpg create mode 100644 kalzium/src/data/toolpics/kolbenprober.png create mode 100644 kalzium/src/data/toolpics/korkring.jpg create mode 100644 kalzium/src/data/toolpics/messzylinder.jpg create mode 100644 kalzium/src/data/toolpics/moerser.jpg create mode 100644 kalzium/src/data/toolpics/phpapier.jpg create mode 100644 kalzium/src/data/toolpics/pileusball.jpg create mode 100644 kalzium/src/data/toolpics/pipette.jpg create mode 100644 kalzium/src/data/toolpics/rg-halter.jpg create mode 100644 kalzium/src/data/toolpics/rg-staender.jpg create mode 100644 kalzium/src/data/toolpics/rg.jpg create mode 100644 kalzium/src/data/toolpics/rotationsverdampfer.jpg create mode 100644 kalzium/src/data/toolpics/rueckflusskuehler.jpg create mode 100644 kalzium/src/data/toolpics/ruehrfisch.jpg create mode 100644 kalzium/src/data/toolpics/rundkolben.jpg create mode 100644 kalzium/src/data/toolpics/scheidetrichter.jpg create mode 100644 kalzium/src/data/toolpics/schutzbrille.jpg create mode 100644 kalzium/src/data/toolpics/spatel.jpg create mode 100644 kalzium/src/data/toolpics/spritzflasche.jpg create mode 100644 kalzium/src/data/toolpics/thermometer.jpg create mode 100644 kalzium/src/data/toolpics/thermometer2.jpg create mode 100644 kalzium/src/data/toolpics/tonschale.jpg create mode 100644 kalzium/src/data/toolpics/trichter.jpg create mode 100644 kalzium/src/data/toolpics/trockenrohr.jpg create mode 100644 kalzium/src/data/toolpics/tropftrichter.jpg create mode 100644 kalzium/src/data/toolpics/uhrglas.jpg create mode 100644 kalzium/src/data/toolpics/verteiler.jpg create mode 100644 kalzium/src/data/toolpics/vollpipette.jpg create mode 100644 kalzium/src/data/toolpics/waage.jpg create mode 100644 kalzium/src/data/toolpics/wasserstrahlpumpe.jpg create mode 100644 kalzium/src/data/tools.xml create mode 100644 kalzium/src/data/tools.xml.todo create mode 100644 kalzium/src/detailedgraphicaloverview.cpp create mode 100644 kalzium/src/detailedgraphicaloverview.h create mode 100644 kalzium/src/detailinfodlg.cpp create mode 100644 kalzium/src/detailinfodlg.h create mode 100644 kalzium/src/element.cpp create mode 100644 kalzium/src/element.h create mode 100644 kalzium/src/elementdataviewer.cpp create mode 100644 kalzium/src/elementdataviewer.h create mode 100644 kalzium/src/elementpics/Al.jpg create mode 100644 kalzium/src/elementpics/As.jpg create mode 100644 kalzium/src/elementpics/Au.jpg create mode 100644 kalzium/src/elementpics/B.jpg create mode 100644 kalzium/src/elementpics/Be.jpg create mode 100644 kalzium/src/elementpics/Bi.jpg create mode 100644 kalzium/src/elementpics/Br.jpg create mode 100644 kalzium/src/elementpics/C.jpg create mode 100644 kalzium/src/elementpics/Ca.jpg create mode 100644 kalzium/src/elementpics/Cd.jpg create mode 100644 kalzium/src/elementpics/Cl.jpg create mode 100644 kalzium/src/elementpics/Co.jpg create mode 100644 kalzium/src/elementpics/Cr.jpg create mode 100644 kalzium/src/elementpics/Cu.jpg create mode 100644 kalzium/src/elementpics/F.jpg create mode 100644 kalzium/src/elementpics/Fe.jpg create mode 100644 kalzium/src/elementpics/Ga.jpg create mode 100644 kalzium/src/elementpics/Ge.jpg create mode 100644 kalzium/src/elementpics/H.jpg create mode 100644 kalzium/src/elementpics/He.jpg create mode 100644 kalzium/src/elementpics/Hg.jpg create mode 100644 kalzium/src/elementpics/I.jpg create mode 100644 kalzium/src/elementpics/In.jpg create mode 100644 kalzium/src/elementpics/K.jpg create mode 100644 kalzium/src/elementpics/Kr.jpg create mode 100644 kalzium/src/elementpics/Li.jpg create mode 100644 kalzium/src/elementpics/Makefile.am create mode 100644 kalzium/src/elementpics/Mg.jpg create mode 100644 kalzium/src/elementpics/Mn.jpg create mode 100644 kalzium/src/elementpics/Mo.jpg create mode 100644 kalzium/src/elementpics/N.jpg create mode 100644 kalzium/src/elementpics/Na.jpg create mode 100644 kalzium/src/elementpics/Nb.jpg create mode 100644 kalzium/src/elementpics/Ne.jpg create mode 100644 kalzium/src/elementpics/Ni.jpg create mode 100644 kalzium/src/elementpics/O.jpg create mode 100644 kalzium/src/elementpics/P.jpg create mode 100644 kalzium/src/elementpics/Pb.jpg create mode 100644 kalzium/src/elementpics/Pd.jpg create mode 100644 kalzium/src/elementpics/Pt.jpg create mode 100644 kalzium/src/elementpics/Re.jpg create mode 100644 kalzium/src/elementpics/Rh.jpg create mode 100644 kalzium/src/elementpics/S.jpg create mode 100644 kalzium/src/elementpics/Sb.jpg create mode 100644 kalzium/src/elementpics/Se.jpg create mode 100644 kalzium/src/elementpics/Si.jpg create mode 100644 kalzium/src/elementpics/Sn.jpg create mode 100644 kalzium/src/elementpics/Ta.jpg create mode 100644 kalzium/src/elementpics/Te.jpg create mode 100644 kalzium/src/elementpics/Th.jpg create mode 100644 kalzium/src/elementpics/Ti.jpg create mode 100644 kalzium/src/elementpics/U.jpg create mode 100644 kalzium/src/elementpics/V.jpg create mode 100644 kalzium/src/elementpics/W.jpg create mode 100644 kalzium/src/elementpics/Xe.jpg create mode 100644 kalzium/src/elementpics/Zn.jpg create mode 100644 kalzium/src/elementpics/Zr.jpg create mode 100644 kalzium/src/eqchemview.cpp create mode 100644 kalzium/src/eqchemview.h create mode 100644 kalzium/src/eqresult.cpp create mode 100644 kalzium/src/eqresult.h create mode 100644 kalzium/src/exporter.cpp create mode 100644 kalzium/src/exporter.h create mode 100644 kalzium/src/hi128-app-kalzium.png create mode 100644 kalzium/src/hi16-app-kalzium.png create mode 100644 kalzium/src/hi22-app-kalzium.png create mode 100644 kalzium/src/hi32-app-kalzium.png create mode 100644 kalzium/src/hi48-app-kalzium.png create mode 100644 kalzium/src/hi64-app-kalzium.png create mode 100644 kalzium/src/hisc-app-kalzium.svgz create mode 100644 kalzium/src/icons/Makefile.am create mode 100644 kalzium/src/icons/cr16-action-calculate.png create mode 100644 kalzium/src/icons/cr16-action-chemical.png create mode 100644 kalzium/src/icons/cr16-action-elempic.png create mode 100644 kalzium/src/icons/cr16-action-energies.png create mode 100644 kalzium/src/icons/cr16-action-eqchem.png create mode 100644 kalzium/src/icons/cr16-action-glossary.png create mode 100644 kalzium/src/icons/cr16-action-isotopemap.png create mode 100644 kalzium/src/icons/cr16-action-legend.png create mode 100644 kalzium/src/icons/cr16-action-misc.png create mode 100644 kalzium/src/icons/cr16-action-orbits.png create mode 100644 kalzium/src/icons/cr16-action-overview.png create mode 100644 kalzium/src/icons/cr16-action-plot.png create mode 100644 kalzium/src/icons/cr16-action-sidebar.png create mode 100644 kalzium/src/icons/cr16-action-spectrum.png create mode 100644 kalzium/src/icons/cr16-action-statematter.png create mode 100644 kalzium/src/icons/cr16-action-timeline.png create mode 100644 kalzium/src/icons/cr16-action-tooltip.png create mode 100644 kalzium/src/icons/cr22-action-calculate.png create mode 100644 kalzium/src/icons/cr22-action-chemical.png create mode 100644 kalzium/src/icons/cr22-action-elempic.png create mode 100644 kalzium/src/icons/cr22-action-energies.png create mode 100644 kalzium/src/icons/cr22-action-eqchem.png create mode 100644 kalzium/src/icons/cr22-action-glossary.png create mode 100644 kalzium/src/icons/cr22-action-isotopemap.png create mode 100644 kalzium/src/icons/cr22-action-legend.png create mode 100644 kalzium/src/icons/cr22-action-orbits.png create mode 100644 kalzium/src/icons/cr22-action-overview.png create mode 100644 kalzium/src/icons/cr22-action-plot.png create mode 100644 kalzium/src/icons/cr22-action-sidebar.png create mode 100644 kalzium/src/icons/cr22-action-spectrum.png create mode 100644 kalzium/src/icons/cr22-action-statematter.png create mode 100644 kalzium/src/icons/cr22-action-timeline.png create mode 100644 kalzium/src/icons/cr22-action-tooltip.png create mode 100644 kalzium/src/icons/cr32-action-calculate.png create mode 100644 kalzium/src/icons/cr32-action-chemical.png create mode 100644 kalzium/src/icons/cr32-action-elempic.png create mode 100644 kalzium/src/icons/cr32-action-energies.png create mode 100644 kalzium/src/icons/cr32-action-eqchem.png create mode 100644 kalzium/src/icons/cr32-action-glossary.png create mode 100644 kalzium/src/icons/cr32-action-isotopemap.png create mode 100644 kalzium/src/icons/cr32-action-legend.png create mode 100644 kalzium/src/icons/cr32-action-misc.png create mode 100644 kalzium/src/icons/cr32-action-orbits.png create mode 100644 kalzium/src/icons/cr32-action-overview.png create mode 100644 kalzium/src/icons/cr32-action-plot.png create mode 100644 kalzium/src/icons/cr32-action-sidebar.png create mode 100644 kalzium/src/icons/cr32-action-spectrum.png create mode 100644 kalzium/src/icons/cr32-action-statematter.png create mode 100644 kalzium/src/icons/cr32-action-timeline.png create mode 100644 kalzium/src/icons/cr32-action-tooltip.png create mode 100644 kalzium/src/icons/cr48-action-calculate.png create mode 100644 kalzium/src/icons/cr48-action-chemical.png create mode 100644 kalzium/src/icons/cr48-action-elempic.png create mode 100644 kalzium/src/icons/cr48-action-energies.png create mode 100644 kalzium/src/icons/cr48-action-eqchem.png create mode 100644 kalzium/src/icons/cr48-action-glossary.png create mode 100644 kalzium/src/icons/cr48-action-isotopemap.png create mode 100644 kalzium/src/icons/cr48-action-legend.png create mode 100644 kalzium/src/icons/cr48-action-misc.png create mode 100644 kalzium/src/icons/cr48-action-orbits.png create mode 100644 kalzium/src/icons/cr48-action-overview.png create mode 100644 kalzium/src/icons/cr48-action-plot.png create mode 100644 kalzium/src/icons/cr48-action-sidebar.png create mode 100644 kalzium/src/icons/cr48-action-spectrum.png create mode 100644 kalzium/src/icons/cr48-action-statematter.png create mode 100644 kalzium/src/icons/cr48-action-timeline.png create mode 100644 kalzium/src/icons/cr48-action-tooltip.png create mode 100644 kalzium/src/icons/crsc-action-calculate.svgz create mode 100644 kalzium/src/icons/crsc-action-chemical.svgz create mode 100644 kalzium/src/icons/crsc-action-elempic.svgz create mode 100644 kalzium/src/icons/crsc-action-energies.svgz create mode 100644 kalzium/src/icons/crsc-action-eqchem.svgz create mode 100644 kalzium/src/icons/crsc-action-glossary.svgz create mode 100644 kalzium/src/icons/crsc-action-isotopemap.svgz create mode 100644 kalzium/src/icons/crsc-action-misc.svgz create mode 100644 kalzium/src/icons/crsc-action-orbits.svgz create mode 100644 kalzium/src/icons/crsc-action-overview.svgz create mode 100644 kalzium/src/icons/crsc-action-plot.svgz create mode 100644 kalzium/src/icons/crsc-action-sidebar.svgz create mode 100644 kalzium/src/icons/crsc-action-spectrum.svgz create mode 100644 kalzium/src/icons/crsc-action-statematter.svgz create mode 100644 kalzium/src/icons/crsc-action-timeline.svgz create mode 100644 kalzium/src/icons/crsc-action-tooltip.svgz create mode 100644 kalzium/src/icons/htmlview/Makefile.am create mode 100644 kalzium/src/icons/htmlview/abundance.png create mode 100644 kalzium/src/icons/htmlview/boilingpoint.png create mode 100644 kalzium/src/icons/htmlview/book.png create mode 100644 kalzium/src/icons/htmlview/characteristics.png create mode 100644 kalzium/src/icons/htmlview/density.png create mode 100644 kalzium/src/icons/htmlview/discovery.png create mode 100644 kalzium/src/icons/htmlview/electronaffinity.png create mode 100644 kalzium/src/icons/htmlview/header.png create mode 100644 kalzium/src/icons/htmlview/icons.svg create mode 100644 kalzium/src/icons/htmlview/ionisation.png create mode 100644 kalzium/src/icons/htmlview/mass.png create mode 100644 kalzium/src/icons/htmlview/meltingpoint.png create mode 100644 kalzium/src/icons/htmlview/radius.png create mode 100644 kalzium/src/icons/htmlview/structure.png create mode 100644 kalzium/src/icons/htmlview/style.css create mode 100644 kalzium/src/isotope.cpp create mode 100644 kalzium/src/isotope.h create mode 100644 kalzium/src/kalzium.cpp create mode 100644 kalzium/src/kalzium.desktop create mode 100644 kalzium/src/kalzium.h create mode 100644 kalzium/src/kalzium.kcfg create mode 100644 kalzium/src/kalziumdataobject.cpp create mode 100644 kalzium/src/kalziumdataobject.h create mode 100644 kalzium/src/kalziumtip.cpp create mode 100644 kalzium/src/kalziumtip.h create mode 100644 kalzium/src/kalziumui.rc create mode 100644 kalzium/src/kalziumutils.cpp create mode 100644 kalzium/src/kalziumutils.h create mode 100644 kalzium/src/main.cpp create mode 100644 kalzium/src/molcalcwidget.cpp create mode 100644 kalzium/src/molcalcwidget.h create mode 100644 kalzium/src/molcalcwidgetbase.ui create mode 100644 kalzium/src/moleculeparser.cpp create mode 100644 kalzium/src/moleculeparser.h create mode 100644 kalzium/src/orbitswidget.cpp create mode 100644 kalzium/src/orbitswidget.h create mode 100644 kalzium/src/parser.cpp create mode 100644 kalzium/src/parser.h create mode 100644 kalzium/src/periodictableview.cpp create mode 100644 kalzium/src/periodictableview.h create mode 100644 kalzium/src/plotsetupwidget.ui create mode 100644 kalzium/src/plotwidget.cpp create mode 100644 kalzium/src/plotwidget.h create mode 100644 kalzium/src/prefs.kcfgc create mode 100644 kalzium/src/settings_colors.ui create mode 100644 kalzium/src/settings_misc.ui create mode 100644 kalzium/src/settings_units.ui create mode 100644 kalzium/src/solver/Makefile create mode 100644 kalzium/src/solver/README create mode 100644 kalzium/src/solver/calc.ml create mode 100644 kalzium/src/solver/calc.mli create mode 100644 kalzium/src/solver/chem.ml create mode 100644 kalzium/src/solver/chem.mli create mode 100644 kalzium/src/solver/chemset.ml create mode 100644 kalzium/src/solver/chemset.mli create mode 100644 kalzium/src/solver/datastruct.ml create mode 100644 kalzium/src/solver/datastruct.mli create mode 100644 kalzium/src/solver/lexer.ml create mode 100644 kalzium/src/solver/lexer.mll create mode 100644 kalzium/src/solver/main.c create mode 100644 kalzium/src/solver/main.ml create mode 100644 kalzium/src/solver/modwrap.c create mode 100644 kalzium/src/solver/parser.ml create mode 100644 kalzium/src/solver/parser.mli create mode 100644 kalzium/src/solver/parser.mly create mode 100644 kalzium/src/somwidget.ui create mode 100644 kalzium/src/somwidget_impl.cpp create mode 100644 kalzium/src/somwidget_impl.h create mode 100644 kalzium/src/spectrum.cpp create mode 100644 kalzium/src/spectrum.h create mode 100644 kalzium/src/spectrumview.ui create mode 100644 kalzium/src/spectrumviewimpl.cpp create mode 100644 kalzium/src/spectrumviewimpl.h create mode 100644 kalzium/src/spectrumwidget.cpp create mode 100644 kalzium/src/spectrumwidget.h create mode 100644 kalzium/src/tempunit.cpp create mode 100644 kalzium/src/tempunit.h create mode 100644 kalzium/src/timewidget.ui create mode 100644 kalzium/src/timewidget_impl.cpp create mode 100644 kalzium/src/timewidget_impl.h (limited to 'kalzium') diff --git a/kalzium/ChangeLog b/kalzium/ChangeLog new file mode 100644 index 00000000..61d29e3a --- /dev/null +++ b/kalzium/ChangeLog @@ -0,0 +1,30 @@ +*** Changes after Kalzium Hydrogen *** +Change: + - Make the plot window always plot on changes of setting + (No more having to press the Plot button.) + +Add: + - The spectrum dialog + - The table now has a small gap over the rare earth + - The isotope table provides now more data + - halflife-periods + - weight + - number of neutrons + - abundance + - alpha-decay + - betadecay (both plus and minus) + - spin + - magnetic moment + - The documentation has been overhauled + - The menustructure is now more consistent + - One icon has been added + - Make the mainwidget a QScrollView. This make sizehandling easier + - Improved layout of the detailed information dialog + - Added a widget which shows you a table of the isotopes + - Added EqChem, a chemical equation solver + - Added several glossary-items + - Display no legend when the No Color-mode is choosen + - The dialogboxes now have a help-button which will open the + correct page in the help + - The molecule parser for the weight calculator. + - adding the abundance of an element in a crustal rock (measured in ppm) diff --git a/kalzium/Makefile.am b/kalzium/Makefile.am new file mode 100644 index 00000000..294144f0 --- /dev/null +++ b/kalzium/Makefile.am @@ -0,0 +1,6 @@ +SUBDIRS = src + +AUTOMAKE_OPTIONS = foreign + +DOXYGEN_REFERENCES = kdeui kdecore kfile libkdeedu +include ../admin/Doxyfile.am diff --git a/kalzium/README.packagers b/kalzium/README.packagers new file mode 100644 index 00000000..85f705b2 --- /dev/null +++ b/kalzium/README.packagers @@ -0,0 +1,14 @@ +For full functionality (equation solver integration) Kalzium depends on Ocaml and the FaCiLe library. The FaciLe library is only used for compilation and for packagers. + +Ocaml +webpage: http://caml.inria.fr/about/index.en.html +download: http://caml.inria.fr/download.en.html + +FaCiLe +webpage: http://www.recherche.enac.fr/opti/facile/ +download: http://www.recherche.enac.fr/opti/facile/distrib/ + + +If these 2 dependencies are not met, Kalzium will not propose the equation solver in its Tools menu. + +The Kalzium developers diff --git a/kalzium/RELEASE-PLAN b/kalzium/RELEASE-PLAN new file mode 100644 index 00000000..f556379b --- /dev/null +++ b/kalzium/RELEASE-PLAN @@ -0,0 +1,70 @@ + Release plan + ============ + +Status: Under discussion + + +Overview +-------- + +Currently we plan for 3 releases: + + - A standalone release of Kalzium in August + - The release for KDE 3.5 + - The release for KDE 4.0 + +The reason for the standalone release is that we want user feedback +for the KDE 3.5 release. + +All details of the release plan are below the TODO items for the +respective release. + +Dates + +2005-08-07 Feature freeze. All features in the TODO for + version Helium should be done at the end of this day. + +2005-08-26 End of bug testing and fixing period. + +2005-08-30 Release of Kalzium Helium + + +================================================================ + Details of the release plan + + +* Standalone release of Kalzium + + After one week of testing and improving I would like to release + Kalzium (together with libkdeedu for the plotting and the glossary) + on the 30th of August (a tuesday). Two days later I leave to to + aKademy in Malaga, Spain. + + + Release criteria, prio 1: + - Fix all bugs on bugs.kde.org + - *must be* Update edu.kde.org/kalzium with screenshots + - *must be* increase the version number + + Release criteria, prio 2: + - Make the release very usable: + - Write the documentation + These prio 2 issues will be prio 1 for KDE 3.5 + + + Release mechanism: + - Announcement on kde-edu@kde.org + - Announcement on kalzium@kde.org + - Announcement on www.kde-apps.org + - Announcement on kde-announce@kde.org + - I will blog about the release and it goals + +* KDE 3.5-release + + Make use of the feedback we get of the standalone release + + The 3.5-release will probably be pretty identical with the + standalone-release, except for bug fixes and usability issues. + + +* KDE 4-release + + + Port to Qt4. We use a lot QValueList and paintEvents, so I + expect some fun :) + + Switch to KCanvas2 so that scaling the table is possible? + IW: Scaling can be made possible without KCanvas2 as well. + + Implement the things in the TODO-file diff --git a/kalzium/TODO b/kalzium/TODO new file mode 100644 index 00000000..73186d48 --- /dev/null +++ b/kalzium/TODO @@ -0,0 +1,109 @@ + TODO for Kalzium 1.5 + =================== + +Bugs +---- + +* Miscellaneous bugs: + + Make use of the biological symbol. ---- + CN: I lost the "translation" though, will have to look after it. + CN: I have deactivated the drawingconde + + correct mass-rounding + presumably, the arg()-funktion now rounds wrong ----- + + +================================================================ + Future versions + +* Export to html and csv comes into my mind. Pretty easy I + guess. Something like that was in Kalzium of KDE 3.1 I + think. But my implementation sucked so much I removed it. + +* Add KHotNewStuff support (xml) so that a user can define which + dates are displayed in the timeline (see SOM) + +* Log-scale of the gradient + +* Plotting + + Add groups of elements, for example "Metals", 4th Period + transitionmetals and so on. The user can easily select them + and only plot the selected group + + More than one group should be plottable at once. + This would enable the user to compare two or more groups, + eg. 4th with 5th group + +* Add more than only one mode to Kalzium, eg a mode with simplified + user interface (less looks, easier menu structure, less information + in the infodialog) and a full-mode where everything is enabled. + +* There should be more data about the elements, for example which + chemitry-nobel-prize was won in that year (+/- 5 years or so) + +* Make use of hotnewstuff. In the detailinfodlg there should be + a weblookup. If the user click on a button Konq will start with + a page about the element. Of course, the user should be able + to decide which page. + For this we could create a simple editor and store it in xml. + on edu.kde.org we would enable KHNS so that users can share + their pages. Imaginge for example the different wikipedia-languages + +* Add the weblookup also in the glossary + +* Besides although for the "common user" is more easy to understand + the information in "... years", it's more correct and flexible in + scientific terms to use the scientific notation: ...x10e9 years. + +* Add lesson-mode? The idea is that a teacher could create xml-files + which can somehow be used as lessons. Perhaps something like + "find out how many element boild at 200 Degree Celsius and above. + With the information: Why is it so?" + +* Add experiental mode: A teacher defines experiments (in xml) where + fotos and texts are used to represent a experiment/task. Perhaps + combined with openoffice-files (charts and so on). Like in CheExp. + +* Add two comboboxes to the infodialog: That way the user can search + for an element by name and number. Like in CheExp + +* Thinking on people with some disabilities, it would be great if they can +select the elements on the grid by using cursor keys (or just tab key). + +* Perhaps there must be a KComboBox in the toolbar where you can select the +different views of the PTE. + +* There's no view of the natural occurrence of the elements. Look at +http://en.wikipedia.org/wiki/Periodic_table_(standard) and see the notes +about borders. + +* Spectrum-Classes + + Create an editor. The user enters some wavelength and Kalzium will + create a graphic from that data. + +* Some websites with a lot of information: +http://en.wikipedia.org/wiki/History_of_chemistry +http://en.wikipedia.org/wiki/Timeline_of_chemical_element_discovery +http://en.wikipedia.org/wiki/Nobel_Prize_in_chemistry +http://chemipedia.org/mediawiki/index.php/Hauptseite +http://physics.nist.gov/PhysRefData/Handbook/periodictable.htm + +Properties listed on my periodic table: +Page 1: +- electronconfig [DONE] +- Atomic radius (covalent, ionic, vdw [Semi-DONE] +- reduction potential +- EN [DONE, there are more values, other scales] +- abundance [Semi-Done] +- biological symbol [DONE] +- IUPAC-Name [DONE] +- number [DONE] +- oxidation-numer(s) [DONE, need to be checked] +- orbitals [DONE] + +Page 2: +- number of natural isotopes +- massenzahlen (# of neutrons) of the most important isotopes +- natural abundance of the isotopes +- first IE [DONE] +- density [DONE] +- SP and BP [DONE] +- Infos about the most important isotope [DONE but needs to be improved] diff --git a/kalzium/configure.in.bot b/kalzium/configure.in.bot new file mode 100644 index 00000000..6bc3c088 --- /dev/null +++ b/kalzium/configure.in.bot @@ -0,0 +1,26 @@ +if test x$eqchem_enabled = xno && test x$with_ocamlsolver != xno ; then + cat << EOF + +The Kalzium Chemical Equation Solver has been disabled. Possible +reasons of that: + +EOF + + if test "x$ocaml_installed" = "xno"; then + cat << EOF +* OCaml was not found. In order to have the Solver, you have to + install OCaml. You can get OCaml from http://pauillac.inria.fr/ocaml/. + +EOF + fi + + if test "x$facile_installed" = "xno"; then + cat << EOF +* The FaCiLe module for OCaml was not found. In order to have the Solver, + you have to install the FaCiLe module. You can get it from + http://www.recherche.enac.fr/opti/facile/. + +EOF + fi + +fi diff --git a/kalzium/configure.in.in b/kalzium/configure.in.in new file mode 100644 index 00000000..757485ad --- /dev/null +++ b/kalzium/configure.in.in @@ -0,0 +1,66 @@ +#MIN_CONFIG(3.3) + +ocaml_installed=no +facile_installed=no +eqchem_enabled=no + +AC_DEFUN([OCAML_PROG],[ + KDE_FIND_PATH(ocamlopt, OCAML, [$bindir], + [ + OCAML='' + ]) +]) + +AC_DEFUN([FACILE_PROG],[ + AC_REQUIRE([OCAML_PROG]) + + AC_MSG_CHECKING([if the facile constraint solver is installed]) + FACILE="`ocamlopt -where`/facile" + if test -d "$FACILE" ; then + eqchem_enabled=yes + AC_MSG_RESULT([yes]) + facile_installed=yes + else + eqchem_enabled=no + AC_MSG_RESULT([no]) + facile_installed=no + fi + + AC_SUBST([FACILE]) +]) + +AC_ARG_ENABLE( ocamlsolver, + [ --disable-ocamlsolver Disable support for the OCaml solver @<:@default=check@:>@]], + [ with_ocamlsolver=$enableval ], + [ with_ocamlsolver=check] ) + +if test "x$with_ocamlsolver" != xno; then + OCAML_PROG + if test -n "$OCAML"; then + ocaml_installed=yes + FACILE_PROG + fi + + AH_TEMPLATE(HAVE_FACILE, facile solver available?) + + EQCHEM_SUB= + OCAMLLIB= + EQCHEM_LDADD= + if test "$eqchem_enabled" = "yes"; then + EQCHEM_SUB=solver + OCAMLLIB=`ocamlc -where` + FACILELIB=`ocamlc -where`/facile + EQCHEM_LDADD="-lasmrun -lstr -lnums -lm -ldl solver.o modwrap.o" + + AC_DEFINE(HAVE_FACILE, 1) + fi + + AC_SUBST(EQCHEM_SUB) + AC_SUBST(OCAMLLIB) + AC_SUBST(FACILELIB) + AC_SUBST(EQCHEM_LDADD) + + if test "$eqchem_enabled" = "yes"; then + with_ocamlsolver=yes + fi +fi diff --git a/kalzium/src/Makefile.am b/kalzium/src/Makefile.am new file mode 100644 index 00000000..7e5b3295 --- /dev/null +++ b/kalzium/src/Makefile.am @@ -0,0 +1,100 @@ +# set the include path for X, qt and KDE +INCLUDES= -I$(srcdir)/../../libkdeedu/kdeeduplot -I$(srcdir)/../../libkdeedu/kdeeduui $(all_includes) + +bin_PROGRAMS = kalzium +kalzium_SOURCES = eqresult.cpp eqchemview.cpp kalzium.cpp \ + main.cpp \ + periodictableview.cpp \ + element.cpp \ + prefs.kcfgc \ + settings_colors.ui \ + settings_misc.ui \ + settings_units.ui \ + detailinfodlg.cpp \ + orbitswidget.cpp \ + plotwidget.cpp \ + elementdataviewer.cpp \ + plotsetupwidget.ui \ + detailedgraphicaloverview.cpp \ + molcalcwidgetbase.ui \ + molcalcwidget.cpp \ + timewidget.ui \ + timewidget_impl.cpp \ + somwidget.ui \ + somwidget_impl.cpp \ + kalziumtip.cpp \ + spectrum.cpp \ + isotope.cpp \ + kalziumdataobject.cpp \ + spectrumwidget.cpp \ + exporter.cpp \ + spectrumview.ui \ + spectrumviewimpl.cpp \ + kalziumutils.cpp \ + parser.cpp \ + moleculeparser.cpp \ + tempunit.cpp + +kalzium_LDADD = ../../libkdeedu/kdeeduplot/libkdeeduplot.la ../../libkdeedu/kdeeduui/libkdeeduui.la $(LIB_KIO) $(LIB_KDEUI) $(LIB_KHTML) -L$(OCAMLLIB) -L$(FACILELIB) $(EQCHEM_LDADD) +KDE_CXXFLAGS = -D_ISOC99_SOURCE + +SUBDIRS = icons elementpics data $(EQCHEM_SUB) + +EXTRA_DIST = main.cpp \ + kalzium.cpp kalzium.h \ + periodictableview.cpp periodictableview.h \ + element.cpp element.h \ + settings_colors.ui \ + settings_misc.ui \ + detailinfodlg.cpp detailinfodlg.h \ + orbitswidget.cpp orbitswidget.h \ + plotwidget.cpp plotwidget.h \ + elementdataviewer.cpp elementdataviewer.h \ + detailedgraphicaloverview.cpp detailedgraphicaloverview.h \ + molcalcwidget.cpp molcalcwidget.h \ + timewidget.ui \ + timewidget_impl.cpp timewidget_impl.h \ + somwidget.ui \ + somwidget_impl.cpp somwidget_impl.h \ + spectrum.cpp spectrum.h \ + isotope.cpp isotope.h \ + kalziumdataobject.cpp kalziumdataobject.h \ + spectrumwidget.cpp spectrumwidget.h \ + exporter.cpp exporter.h \ + spectrumview.ui \ + spectrumviewimpl.cpp spectrumviewimpl.h \ + kalziumutils.cpp kalziumutils.h \ + parser.cpp parser.h \ + moleculeparser.cpp moleculeparser.h \ + tempunit.cpp tempunit.h + +METASOURCES = AUTO + +xdg_apps_DATA = kalzium.desktop +kde_kcfg_DATA = kalzium.kcfg + +rcuidir = $(kde_datadir)/kalzium +rcui_DATA = kalziumui.rc + +KDE_ICON = AUTO + +# the library search path. +kalzium_LDFLAGS = $(all_libraries) $(KDE_RPATH) + +#this RegExp-monster grep for bar and puts the i18n() around foo and bar +messages-old: rc.cpp + cat data/data.xml | grep name| sed -e 's/< *name *origin *= *"\([^\"]*\)\">\([^<]*\)<\/ *name *>/I18N_NOOP(\"\1\"); I18N_NOOP(\"\2\");/;s/I18N_NOOP("");//g' | grep I18N_NOOP >> rc.cpp + cat data/knowledge.xml | grep name| sed -e 's/< *name *>\([^<]*\)<\/ *name *>/I18N_NOOP(\"\1\");/' >> rc.cpp + cat data/knowledge.xml | grep desc | sed -e 's/< *desc *>\([^<]*\)<\/ *desc *>/I18N_NOOP(\"\1\");/' >> rc.cpp + cat data/knowledge.xml | grep refitem | sed -e 's/< *refitem *>\([^<]*\)<\/ *refitem *>/I18N_NOOP(\"\1\");/' >> rc.cpp + cat data/tools.xml | grep name | sed -e 's/< *name *>\([^<]*\)<\/ *name *>/I18N_NOOP(\"\1\");/' >> rc.cpp + cat data/tools.xml | grep desc | sed -e 's/< *desc *>\([^<]*\)<\/ *desc *>/I18N_NOOP(\"\1\");/' >> rc.cpp + $(XGETTEXT) *.cpp -o $(podir)/kalzium.pot + rm -f rc.cpp # for testing + +messages: rc.cpp + $(EXTRACTATTR) --attr=name,origin data/data.xml >> rc.cpp + $(EXTRACTRC) --tag-group=none --tag=name data/data.xml >> rc.cpp + $(EXTRACTRC) --tag-group=none --tag=name --tag=desc --tag=refitem data/knowledge.xml >> rc.cpp + $(EXTRACTRC) --tag-group=none --tag=name --tag=desc data/tools.xml >> rc.cpp + $(XGETTEXT) *.cpp -o $(podir)/kalzium.pot diff --git a/kalzium/src/data/Makefile.am b/kalzium/src/data/Makefile.am new file mode 100644 index 00000000..4377f0ac --- /dev/null +++ b/kalzium/src/data/Makefile.am @@ -0,0 +1,6 @@ +SUBDIRS = $(AUTODIRS) + +xml_DATA = bg.jpg data.xml knowledge.xml tools.xml + +xmldir = $(kde_datadir)/kalzium/data + diff --git a/kalzium/src/data/bg.jpg b/kalzium/src/data/bg.jpg new file mode 100644 index 00000000..0729fe39 Binary files /dev/null and b/kalzium/src/data/bg.jpg differ diff --git a/kalzium/src/data/data.dtd b/kalzium/src/data/data.dtd new file mode 100644 index 00000000..93a7878b --- /dev/null +++ b/kalzium/src/data/data.dtd @@ -0,0 +1,23 @@ + + + + + + + + + + + diff --git a/kalzium/src/data/data.xml b/kalzium/src/data/data.xml new file mode 100644 index 00000000..47053fa7 --- /dev/null +++ b/kalzium/src/data/data.xml @@ -0,0 +1,4879 @@ + + + + + + 1 + Hydrogen + H + 1 + + + + + + + + + + + + + 1.00794 + s + 1 + 1766 + + 1 + -73 + 2.1 + 13.81 + 20.28 + + + + + + 0.084 + + 13.598 + + + 37.3 + 25 + 120 + 74.130 + 208 + + 1s1 + +1.(-1) + Non-Metal + 1520 + + + 2 + Helium + He + 1 + + + + + + + + + + + + + + + + + + + + + 4.002602 + p + 1 + 1895 + 0 + 8 + 21 + + 0.95 + 4.216 + 0.1785 + + 24.587 + 54.417 + + + 32 + 31 + 140 + 300 + + 1s2 + 0 + + + + + Noblegas + hcp + + + 3 + Lithium + Li + 2 + 6.941 + s + 0 + + + + + + + + + + + + + 1817 + 5 + 1 + -60 + 0.98 + 453.7 + 1615 + 0.53 + + 5.392 + 75.980 + + + 134 + 145 + 182 + 303.9 + 74 + + 1s2 2s1 + +1 + + + + + Alkali_Earth + bcc + 18 + + + 4 + Beryllium + Be + 2 + 9.012182 + s + 2 + 0 + 1798 + 3 + 2 + 19 + 1.57 + 1560 + 3243 + 1.85 + + 9.322 + 18.211 + + + 90 + 105 + 222.6 + + 35 + + 1s2 2s2 + +2 + + + + + + Alkaline_Earth + hdp + 2 + + + + + + + + + + + + + + + 5 + Boron + B + 2 + 10.811 + p + 3 + 1808 + 3 + 3 + -27 + 2.04 + 2365 + 4275 + 2.46 + + 8.298 + 25.154 + 37.9 + + + + + + + + + + + 82 + 85 + 158.9 + + 23 + + 9 + 1s2 2s2 2p1 + +3 + + + + + Metalloids + rh + + + 6 + Carbon + C + 2 + 12.0107 + p + 3 + + + + + + + + + + + + + + + + + + + + + + + + 0 + 1 + 4 + -122 + 2.55 + 3825 + 5100 + 3.51 + + 11.260 + 24.376 + + + 77.2 + 70 + 170 + 142.6 + 16 + + 180 + 1s2 2s2 2p2 + -4.+2.+4 + + + + + + + Non-Metal + + + 7 + Nitrogen + N + 2 + 14.0067 + p + 3 + + + + + + + + + + + + + + + 1772 + 1 + 5 + 7 + 3.04 + 63.15 + 77.344 + 1.17 + + 14.534 + 29.602 + + + 75 + 65 + 155 + 13 + 16 + 16 + 109.76 + + 19 + 1s2 2s2 2p3 + -3.(+1.+2.+3.+4.+5) + + + + + Non-Metal + hcp + + + 8 + Oxygen + O + 2 + 15.9994 + p + 3 + + + + + + + + + + + + + + + 1774 + 1 + 6 + -141 + 3.44 + 54.8 + 90.188 + 1.33 + + 13.618 + 35.116 + + + 73 + 60 + 152 + 146 + 120.741 + + 455000 + 1s2 2s2 2p4 + -2.(-1.+2) + + + + + + Non-Metal + sc + + + 9 + Fluorine + F + 2 + 18.9984032 + p + 3 + + + + + + + + + + + + + + + + + + 1886 + 4 + 7 + -328 + 3.98 + 53.55 + 85.0 + 1.58 + + 17.422 + 34.969 + + + 70.9 + 50 + 147 + 141.8 + 131 + + 544 + 1s2 2s2 2p5 + -1 + + + + + Halogene + + + 10 + Neon + Ne + 2 + 20.1797 + p + 1 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1898 + 0 + 8 + 29 + + 24.55 + 27.10 + 0.8999 + + 21.564 + 40.962 + + + 69 + 38 + 154 + 313 + + 1s2 2s2 2p6 + 0 + + + + + + Noblegas + ccp + + + 11 + Sodium + + + + + + + + + + + + + + + Na + 3 + 22.989770 + s + 0 + 1807 + 2 + 1 + -53 + 0.93 + 371.0 + 1156 + 0.97 + + 5.139 + + + 153.7 + 180 + 227 + 102 + 371.7 + + 22700 + 1s2 2s2 2p6 3s1 + +1 + Alkali_Earth + + + + + + bcc + + + 12 + Magnesium + Mg + 3 + 24.3050 + s + 0 + 1808 + 1 + 2 + + + + + + + + + + + + + + + 19 + 1.31 + 922 + 1380 + 1.74 + + 7.646 + 15.0 + 80.1 + + + 130 + 150 + 173 + 319.7 + 72 + + 27640 + 1s2 2s2 2p6 3s2 + +2 + + + + + + Alkaline_Earth + hdp + + + 13 + Aluminum + Al + 3 + 26.981538 + p + 2 + 1825 + 0 + 3 + + + + + + + + + + + + -43 + 1.61 + 933.5 + 2740 + 2.70 + + 5.986 + 18.8 + 28.4 + + + 118 + 125 + + 53 + 286.3 + + 83000 + 1s2 2s2 2p6 3s2 3p1 + +3 + + + + + Other_Metal + ccp + + + 14 + Silicon + Si + 3 + 28.0855 + p + 3 + 1823 + 4 + 4 + + + + + + + + + + + + + + + + + + + + + + + + -134 + 1.91 + 1683 + 2630 + 2.33 + + 8.151 + 16.3 + 33.4 + + + 111 + 110 + 210 + 235.2 + 40 + + 272200 + 1s2 2s2 2p6 3s2 3p2 + +4.(-4.+2) + + + + + + Metalloids + d + + + 15 + Phosphorus + P + 3 + 30.973761 + p + 3 + 1669 + 1 + 5 + + + + + + + + + + + + + + + + + + + -72 + 2.19 + 317.3 + 553 + 1.82 + + 10.486 + 19.8 + 30.2 + + + 106 + 100 + 180 + 35 + 44 + 221 + + 1120 + 1s2 2s2 2p6 3s2 3p3 + -3.(+1.+3).+5 + + + + + Non-Metal + sc + + + 16 + Sulfur + S + 3 + 32.065 + p + 3 + 0 + 1 + + + + + + + + + + + + + + + + + + 6 + -200 + 2.58 + 392.2 + 717.82 + 2.06 + + 10.360 + 23.3 + 34.8 + + + 102 + 100 + 180 + 184 + 205 + + 340 + 1s2 2s2 2p6 3s2 3p4 + -2.+2.+4.+6 + + + + + + + + Non-Metal + or + + + 17 + Chlorine + Cl + 3 + + + + + + + + + + + + + 35.453 + p + 3 + 1774 + 2 + 7 + -349 + 3.16 + 172.17 + 239.18 + 2.95 + + 12.967 + 23.8 + 39.6 + + + 99.4 + 100 + 175 + 189.1 + 181 + + 126 + 1s2 2s2 2p6 3s2 3p5 + -1.(+1.+3.+5.+7) + + + + + Halogene + tet + + + 18 + Argon + Ar + 3 + 39.948 + p + + + + + + + + + + + + + + + + + + + + + 1 + 1894 + 0 + 8 + 29 + + 83.95 + 87.45 + 1.66 + + 15.759 + 27.6 + 40.7 + + + 97 + 71 + 188 + 372 + + + 1s2 2s2 2p6 3s2 3p6 + 0 + + + + + + Noblegas + tet + + + 19 + Potassium + K + 4 + + + + + + + + + + 39.0983 + s + 0 + 1807 + 1 + 1 + -48 + 0.82 + 336.8 + 1033 + 0.86 + + 4.341 + + + 196 + 220 + 275 + + Ar 4s1 + +1 + + + + + + Alkali_Earth + bcc + + + 20 + Calcium + Ca + 4 + 40.078 + + + + + + + + + + + + + + + + + s + 0 + 1808 + 1 + 2 + 10 + 1.00 + 1112 + 1757 + 1.54 + + 6.113 + 11.9 + + + 174 + 180 + + + Ar 4s2 + +2 + + + + + + + + + Alkaline_Earth + ccp + + + 21 + Scandium + Sc + 4 + 44.955910 + + + + + + + + + + + + + d + 0 + 1879 + 0 + 3 + -18 + 1.36 + 1814 + 3109 + 2.99 + + 6.54 + + + 144 + 160.6 + + + Ar 3d1 4s2 + +3 + + + + + + + Transition + hdp + + + 22 + Titanium + Ti + 4 + 47.867 + d + + + + + + + + + + + + + + + + + + + + 2 + 1791 + 0 + 4 + -8 + 1.54 + 1935 + 3560 + 4.51 + + 6.82 + + + 144.8 + 140 + + + Ar 3d2 4s2 + +4.+3 + + + + + + + + Transition + hdp + + + 23 + Vanadium + V + 4 + 50.9415 + d + + + + + + + + + + + + + + + + + + + + 2 + 1830 + 4 + 5 + -51 + 1.63 + 2163 + 3650 + 6.09 + + 6.74 + + + 125 + 135 + + + Ar 3d3 4s2 + +5.(+2.+3.+4) + + + + + Transition + bcc + + + 24 + Chromium + Cr + 4 + 51.9961 + + + + + + + + + + + + d + 2 + 1797 + 4 + 6 + -64 + 1.66 + 2130 + 2945 + 7.14 + + 6.766 + + + 124.9 + 140 + + + Ar 3d5 4s1 + +2.+3.(+1.+4.+5).+6 + + + + + + + Transition + bcc + + + 25 + Manganese + Mn + 4 + 54.938049 + d + + + + + + + + + + + + + + 2 + 1774 + 1 + 7 + + 1.55 + 1518 + 2235 + 7.44 + + 7.435 + + + 139 + 140 + + + Ar 3d5 4s2 + +2.+4.(+5).+6.+7 + + + + + Transition + own + + + 26 + Iron + Fe + + + + + + + + + + + + + + + + + + + + + + + 4 + 55.845 + d + 2 + 0 + 1 + 8 + -16 + 1.83 + 1808 + 3023 + 7.874 + + 7.870 + + + 124.1 + 140 + + + Ar 3d6 4s2 + +2.+3 + + + + + + + Transition + bcc + + + 27 + Cobalt + Co + 4 + 58.933200 + + + + + + + + + + + + + + + + d + 2 + 1737 + 2 + 8 + -64 + 1.88 + 1768 + 3143 + 8.89 + + 7.86 + + + 125.3 + 135 + + + Ar 3d7 4s2 + +2.+3.(+4) + + + + + + + + Transition + hdp + + + 28 + Nickel + Ni + 4 + 58.6934 + d + + + + + + + + + + + + + + + + + + + 0 + 1751 + 4 + 8 + -112 + 1.91 + 1726 + 3005 + 8.91 + + 7.635 + + + 124.6 + 135 + 163 + + Ar 3d8 4s2 + 0.(+2).+3 + + + + + + + + + + Transition + ccp + + + 29 + Copper + Cu + 4 + 63.546 + + + + + + + + + + + + + + + + d + 0 + 0 + 1 + 1 + -118 + 1.90 + 1356.6 + 2840 + 8.92 + + 7.726 + 19.579 + 35.55 + + + 138 + 135 + 140 + + Ar 3d10 4s1 + +1.+2 + + + + + + Transition + ccp + + + 30 + Zinc + Zn + 4 + 65.39 + d + + + + + + + + + + + + + + + + 2 + 1746 + 1 + 2 + 47 + 1.65 + 692.73 + 1180 + 7.14 + + 9.394 + + + 131 + 133.2 + 139 + + Ar 3d10 4s2 + +2 + + + + + + + + + Transition + hdp + + + 31 + Gallium + Ga + 4 + 69.723 + p + + + + + + + + 2 + 1875 + 0 + 3 + -29 + 1.81 + 302.92 + 2478 + 5.91 + + 5.999 + 20.5 + 30.7 + + + 126 + 130 + 187 + + Ar 3d10 4s2 4p1 + (+1).(+2).+3 + + + + + Other_Metal + own + + + 32 + Germanium + Ge + 4 + 72.64 + p + + + + + + + + + + + + + + + + + + + 2 + 1886 + 0 + 4 + -116 + 2.01 + 1211.5 + 3107 + 5.32 + + 7.899 + + + 122.5 + 125 + + + Ar 3d10 4s2 4p2 + +4.(+2) + + + + + + + + Metalloids + d + + + 33 + Arsenic + As + 4 + 74.92160 + p + + + + + + + + + + + + 2 + 0 + 4 + 5 + -78 + 2.18 + 1090 + 876 + 5.72 + + 9.81 + + + 119 + 115 + 185 + 46 + + Ar 3d10 4s2 4p3 + (-3).+3.(+5) + + + + + Metalloids + rh + + + 34 + Selenium + Se + 4 + 78.96 + p + + + + + + + + + + + + + + 3 + 1817 + 2 + 6 + -195 + 2.55 + 494 + 958 + 4.82 + + 9.752 + + + 116 + 115 + 190 + 202 + + Ar 3d10 4s2 4p4 + (-2).+4.(+6) + + + + + + + + + Non-Metal + hcp + + + 35 + Bromine + Br + 4 + 79.904 + + + + + + + + + + + + + + p + 3 + 1826 + 5 + 7 + -325 + 2.96 + 265.95 + 331.85 + 3.14 + + 11.814 + + + 114.5 + 115 + 185 + + Ar 3d10 4s2 4p5 + -1.(+1.+5.+7) + + + + + Halogene + or + + + 36 + Krypton + Kr + 4 + 83.80 + + + + + + + + + + + + + + + + + + p + 1 + 1898 + 0 + 8 + 39 + + 116 + 120.85 + 4.48 + + 13.999 + + + 110 + 88 + 202 + + Ar 3d10 4s2 4p6 + +2.(+4) + + + + + + + + + Noblegas + ccp + + + 37 + Rubidium + Rb + 5 + 85.4678 + + + + + + + + + s + 0 + 1861 + 5 + 1 + -47 + 0.82 + 312.63 + 961 + 1.53 + + 4.177 + + + 211 + 235 + + + Kr 5s1 + +1 + + + + + + Alkali_Earth + bcc + + + 38 + Strontium + Sr + + + + + + + + + + + + + + + + 5 + 87.62 + s + 0 + 1790 + 3 + 2 + + 0.95 + 1042 + 1655 + 2.63 + + 5.695 + 11.0 + + + 211 + 235 + + + Kr 5s2 + +2 + + + + + + + + Alkaline_Earth + ccp + + + 39 + Yttrium + Y + 5 + + + + + + + + + + + + + 88.90585 + d + 0 + 1794 + 0 + 3 + -30 + 1.22 + 1795 + 3611 + 4.47 + + 6.38 + + + 162 + 180 + + + Kr 4d1 5s2 + +3 + + + + + Transition + hdp + + + 40 + Zirconium + Zr + 5 + 91.224 + d + + + + + + + + + + + + + + + + + + + + + + 2 + 1789 + 0 + 4 + -41 + 1.33 + 2128 + 4682 + 6.51 + + 6.84 + + + 148 + 155 + + + Kr 4d2 5s2 + +4 + + + + + + + + + + Transition + hdp + + + 41 + Niobium + Nb + 5 + + + + + + + + + + + + + + + + + + + 92.90638 + d + 2 + 1801 + 0 + 5 + -86 + 1.6 + 2742 + 5015 + 8.58 + + 6.88 + + + 137 + 145 + + + Kr 4d4 5s1 + +3.+5 + Transition + + + + + bcc + + + 42 + Molybdenum + Mo + 5 + 95.94 + d + + + + + + + + + + + + + + + + + + 2 + 1778 + 1 + 6 + -72 + 2.16 + 2896 + 4912 + 10.28 + + 7.099 + + + 145 + 145 + + + Kr 4d5 5s1 + (+2.+3.+4.+5).+6 + + + + + + + + + + + + Transition + bcc + + + 43 + Technetium + Tc + 5 + 98.9063 + d + 2 + 1 + 1 + 1937 + 0 + + + + + + + + + + + + + + + + 7 + -53 + 1.9 + 2477 + 4538 + 11.49 + + 7.28 + + + 156 + 135 + + + Kr 4d6 5s1 + +7 + + + + + Transition + hdp + + + 44 + Ruthenium + Ru + 5 + 101.07 + + + + + + + + + + + + + + d + 2 + 1844 + 0 + 8 + -101 + 2.2 + 2610 + 4425 + 12.45 + + 7.37 + + + 126 + 130 + + + Kr 4d7 5s1 + +3.+4.(+8) + + + + + + + + + + + + Transition + hdp + + + 45 + Rhodium + Rh + 5 + 102.90550 + + + + + + + + + + + + + d + 0 + 1803 + 0 + 8 + -110 + 2.28 + 2236 + 3970 + 12.41 + + 7.46 + + + 135 + 134.5 + + + Kr 4d8 5s1 + +1.(+2).+3.(+4) + + + + Transition + ccp + + + 46 + Palladium + Pd + 5 + 106.42 + + + + + + + + + + + + + + + d + 0 + 1803 + 0 + 8 + -54 + 2.20 + 1825 + 3240 + 12.02 + + 8.34 + + + 131 + 140 + 163 + + Kr 4d10 + +2.+4 + + + + + + + + + + + + Transition + ccp + + + 47 + Silver + Ag + 5 + 107.8682 + + + + + + + + + d + 0 + 0 + 0 + 1 + -126 + 1.93 + 1235.1 + 2436 + 10.49 + + 7.576 + + + 153 + 160 + 172 + + Kr 4d10 5s1 + +1.(+2.+3) + + + + + Transition + ccp + + + 48 + Cadmium + Cd + 5 + 112.411 + d + + + + + + + + + + + + + 0 + 1817 + 5 + 2 + 32 + 1.69 + 594.26 + 1040 + 8.64 + + 8.993 + + + 148.9 + 155 + 158 + + Kr 4d10 5s2 + +2 + + + + + + + + + + + + + + Transition + hdp + + + 49 + Indium + In + 5 + + + + + + + + + + + + + + + + 114.818 + p + 2 + 1863 + 0 + 3 + -29 + 1.78 + 429.78 + 2350 + 7.31 + + 5.786 + 18.9 + 28.0 + + + 144 + 155 + 193 + + Kr 4d10 5s2 5p1 + +3.(+1.+2) + + + + + Other_Metal + ccp + + + 50 + Tin + Sn + 5 + 118.710 + p + + + + + + + + + + + + + + + + + + + + + 2 + 0 + 6 + 4 + -116 + 1.96 + 505.12 + 2876 + 7.29 + + 7.344 + + + 140.5 + 145 + 217 + + Kr 4d10 5s2 5p2 + +2.+4 + + + + + + + + + + + + + + + Other_Metal + own + + + 51 + Antimony + Sb + 5 + 121.760 + + + + + + + + + + + + + + + + + p + 2 + 0 + 0 + 5 + -103 + 2.05 + 903.91 + 1860 + 6.69 + + 8.641 + + + 138 + 145 + + 62 + + Kr 4d10 5s2 5p3 + (-3).+3.(+5) + + + + + Metalloids + rh + + + 52 + Tellurium + Te + 5 + 127.60 + p + + + + + + + + + + + + + + + + + 2 + 1782 + 0 + 6 + -190 + 2.1 + 722.72 + 1261 + 6.25 + + 9.009 + + + 135 + 140 + 206 + 222 + + Kr 4d10 5s2 5p4 + (-2).+4.(+6) + + + + + + + + + + + + + Metalloids + hcp + + + 53 + Iodine + I + 5 + 126.90447 + p + + + + + + + + + + + + + 3 + 1811 + 2 + 7 + -295 + 2.66 + 386.7 + 457.5 + 4.94 + + 10.451 + + + 133.1 + 140 + 198 + + Kr 4d10 5s2 5p5 + + + + + -1.(+1.+3.+5.+7) + Halogene + or + + + 54 + Xenon + Xe + 5 + 131.293 + + + + + + + + + + + + + + + p + 1 + 1898 + 0 + 8 + 41 + + 161.39 + 165.1 + 4.49 + + 12.130 + + + 130 + 108 + 216 + + Kr 4d10 5s2 5p6 + +4.(+2.+6) + + + + + + + + + + + + + + + + Noblegas + + + 55 + Caesium + Cs + 6 + 132.90545 + + + + + + + + + + + + + s + 0 + 1860 + 0 + 1 + -45 + 0.79 + 301.54 + 944 + 1.90 + + 3.894 + + + 235 + 265.4 + + + Xe 6s1 + +1 + + + + + Alkali_Earth + bcc + + + 56 + Barium + Ba + 6 + 137.237 + + + + + + + + + + + + + + + + + s + 0 + 1808 + 3 + 2 + + 0.89 + 1002 + 2078 + 3.65 + + 5.212 + 10.0 + + + 198 + 217.3 + + + Xe 6s2 + +2 + + + + + + + + + + + Alkaline_Earth + bcc + + + 57 + Lanthanum + La + 6 + 138.9055 + f + + + + + + + + + + + + + + + + + + 0 + 1839 + 0 + 3 + + 1.10 + 1191 + 3737 + 6.16 + + 5.577 + 11.0 + 19.17 + 49.9 + 61.6 + + + 169 + 187.0 + + + Xe 5d1 6s2 + +3 + + + + + + Rare_Earth + hcp + + + 58 + Cerium + Ce + 6 + 140.116 + f + 0 + 1803 + 0 + 4 + + 1.12 + 1071 + 3715 + 6.77 + + 5.47 + 10.9 + 20.2 + 36.8 + 65.5 + + + 165 + 182.5 + + + Xe 4f1 5d1 6s2 + +3.+4 + + + + + + + + + + Rare_Earth + ccp + + + 59 + Praseodymium + Pr + 6 + 140.90765 + f + 0 + 1885 + 0 + 5 + + 1.13 + 1204 + 3785 + 6.48 + + 5.42 + 10.6 + 21.6 + + + 165 + 182.8 + + + Xe 4f3 6s2 + +3.+4 + + + + + Rare_Earth + + + 60 + Neodymium + Nd + 6 + 144.24 + f + 0 + 1885 + 0 + 6 + + 1.14 + 1294 + 3347 + 7.00 + + 5.49 + + + 164 + 182.1 + + + Xe 4f4 6s2 + +3 + + + + + + + + + + + + Rare_Earth + + + 61 + Promethium + Pm + 6 + 146.9151 + f + 0 + 1 + 1945 + 0 + 7 + + 1.13 + 1315 + 3273 + 7.22 + + 5.55 + + + 163 + 181.0 + + + Xe 4f5 6s2 + + + + + + + +3 + Rare_Earth + + + 62 + Samarium + Sm + 6 + 150.36 + f + 0 + 1879 + 0 + 8 + + 1.17 + 1347 + 2067 + 7.54 + + 5.63 + + + 166 + 180.2 + + + Xe 4f6 6s2 + +2.+3 + + + + + + + + + + + + + + Rare_Earth + + + 63 + Europium + Eu + 6 + 151.964 + f + 0 + 1901 + 0 + 8 + + 1.2 + 1095 + 1800 + 5.25 + + 5.67 + + + 185 + 204.2 + + + Xe 4f7 6s2 + +2.+3 + + + + + Rare_Earth + bcc + + + 64 + Gadolinium + Gd + 6 + 157.25 + f + 0 + 1880 + 0 + 8 + + 1.20 + 1585 + 3545 + 7.89 + + 6.14 + + + 161 + 180.2 + + + Xe 4f7 5d1 6s2 + +3 + + + + + + + + + + + + Rare_Earth + hdp + + + 65 + Terbium + Tb + 6 + 158.92534 + f + 0 + 1843 + 0 + 1 + + 1.1 + 1629 + 3500 + 8.25 + + 5.85 + + + 159 + 178.2 + + + Xe 4f9 6s2 + + + + + +3.+4 + Rare_Earth + hdp + + + 66 + Dysprosium + Dy + 6 + 162.50 + f + 0 + 1886 + 0 + 2 + + 1.22 + 1685 + 2840 + 8.56 + + 5.93 + + + 159 + 177.3 + + + Xe 4f10 6s2 + + + + + + + + + + + +3 + Rare_Earth + hdp + + + 67 + Holmium + Ho + 6 + 164.93032 + f + 0 + 1878 + 0 + 3 + + 1.23 + 1747 + 2968 + 8.78 + + 6.02 + + + 158 + 176.6 + + + + Xe 4f11 6s2 + + + + + +3 + Rare_Earth + hdp + + + 68 + Erbium + Er + 6 + 167.259 + f + 0 + 1843 + 0 + 4 + + 1.24 + 1802 + 3140 + 9.05 + + 6.10 + + + 157 + 175.7 + + + + + Xe 4f12 6s2 + +3 + + + + + + + + + Rare_Earth + hdp + + + 69 + Thulium + Tm + 6 + 168.93421 + f + 0 + 1879 + 0 + 5 + + 1.25 + 1818 + 2223 + 9.32 + + 6.18 + + + 156 + 174.6 + + + + + Xe 4f13 6s2 + + + + +2.+3 + Rare_Earth + hdp + + + 70 + Ytterbium + Yb + 6 + 173.04 + f + 0 + 1878 + 0 + 6 + + 1.1 + 1092 + 1469 + 9.32 + + 6.254 + + + 170 + 194 + + + + + Xe 4f14 6s2 + +2.+3 + + + + + + + + + + + Rare_Earth + ccp + + + 71 + Lutetium + Lu + 6 + 174.967 + f + 0 + 1907 + 0 + 7 + + 1.27 + 1936 + 3668 + 9.84 + + 5.426 + + + 156 + 173.4 + + + + + Xe 4f14 5d1 6s2 + +3 + + + + + + Rare_Earth + hdp + + + 72 + Hafnium + Hf + 6 + 178.49 + d + 2 + 1923 + 0 + 4 + + 1.3 + 2504 + 4875 + 13.31 + + 7.0 + + + 144 + 156.4 + + + + + Xe 4f14 5d2 6s2 + +5 + + + + + + + + + + Transition + hdp + + + 73 + Tantalum + Ta + 6 + 180.9479 + d + 2 + 1802 + 0 + 5 + -31 + 1.5 + 3293 + 5730 + 16.68 + + 7.89 + + + 134 + 143 + + + + + Xe 4f14 5d3 6s2 + +3.+5 + + + + + + Transition + bcc + + + 74 + Tungsten + W + 6 + 183.84 + d + 2 + 1783 + 5 + 6 + -79 + 2.36 + 3695 + 5825 + 19.26 + + 7.98 + + + 130 + 137 + + + + + Xe 4f14 5d4 6s2 + (+4). +6 + + + + + + + + + + + Transition + bcc + + + 75 + Rhenium + Re + 6 + 186.207 + d + 2 + 1925 + 0 + 7 + -14 + 1.9 + 3455 + 5870 + 21.03 + + 7.88 + + + 159 + 135 + + 274.1 + 63 + + 0.0007 + Xe 4f14 5d5 6s2 + +7.+2.+4 + + + + + + + Transition + hdp + + + 76 + Osmium + Os + 6 + 190.23 + d + 2 + 1804 + 0 + 8 + -106 + 2.2 + 3300 + 5300 + 22.61 + + 8.7 + + + 128 + 130 + + 267.5 + 63 + + 0.005 + Xe 4f14 5d6 6s2 + +4.(+2.+3.+6.+8) + + + + + + + + + + + + Transition + hdp + + + 77 + Iridium + Ir + 6 + 192.217 + d + 0 + 1804 + 0 + 8 + -151 + 2.20 + 2720 + 4700 + 22.65 + + 9.1 + + + 137 + 135 + + 271.4 + 63 + + 0.001 + Xe 4f14 5d7 6s2 + +1.+4.(+2.+3.+6) + + + + + + Transition + ccp + + + 78 + Platinum + Pt + 6 + 195.078 + d + 0 + 1735 + 0 + 8 + -205 + 2.28 + 2042.1 + 4100 + 21.450 + + 9.0 + + + 128 + 135 + 175 + 277.5 + 80 + + 0.01 + Xe 4f14 5d9 6s1 + +2.+4 + + + + + + + + + + Transition + ccp + + + 79 + Gold + Au + 6 + 196.96654 + d + 0 + 0 + 0 + 1 + -223 + 2.54 + 1337.58 + 3130 + 19.32 + + 9.225 + + + 144.2 + 135 + 166 + 288.4 + 137 + + 0.004 + Xe 4f14 5d10 6s1 + (+1).+3 + + + + + + + Transition + ccp + + + 80 + Mercury + Hg + 6 + 200.59 + d + 0 + 0 + 0 + 2 + 61 + 2.00 + 234.31 + 629.88 + 13.55 + + 10.437 + + + 160 + 150 + 155 + 300.5 + 102 + + 0.08 + Xe 4f14 5d10 6s2 + (+1).+2 + + + + + + + + + + + + Transition + ccp + + + 81 + Thallium + Tl + 6 + 204.3833 + p + 2 + 1861 + 0 + 3 + -20 + 2.04 + 577 + 1746 + 11.85 + + 6.108 + 20.4 + 29.8 + + + 170.4 + 190 + 196 + 150 + 340.8 + + 0.7 + Xe 4f14 5d10 6s2 6p1 + +1.(+3) + + + + + + Other_Metal + hdp + + + 82 + Lead + Pb + 6 + 207.2 + p + 2 + 0 + 3 + 4 + -35 + 2.33 + 600.65 + 2023 + 11.34 + + 7.416 + + + 147 + 180 + 202 + 350.0 + 118 + + 13 + Xe 4f14 5d10 6s2 6p2 + +2.(+4) + + + + + + + Other_Metal + ccp + + + 83 + Bismuth + Bi + 6 + 208.98038 + p + 0 + 0 + 0 + 5 + -91 + 2.02 + 544.59 + 1837 + 9.80 + + 7.289 + + + + + + + 155 + 160 + + 74 + 102 + 309 + + 13 + Xe 4f14 5d10 6s2 6p3 + +3.(+5) + Other_Metal + rh + + + 84 + Polonium + Po + 6 + 208.9824 + p + 2 + 1 + 1898 + 0 + 6 + -183 + 2.0 + 527 + + 9.20 + + 8.42 + + + + + + + + + + + + + 167.5 + 190 + + 334.5 + 97 + + 0 + Xe 4f14 5d10 6s2 6p4 + (+2).+4.(+6) + Metalloids + mono + + + 85 + Astatine + At + 6 + 209.9871 + p + 3 + 1 + 1940 + 0 + 7 + -270 + 2.2 + 575 + 610 + + + 9.5 + + + + + + + + + + + + 127 + + + + 0 + Xe 4f14 5d10 6s2 6p5 + -1.(1.3.5.7) + Halogene + + + 86 + Radon + Rn + 6 + 222.0176 + p + 1 + 1 + 1898 + 0 + 8 + 41 + + 202 + 211.4 + 9.23 + + 10.748 + + + 145 + 120 + + + + 0 + Xe 4f14 5d10 6s2 6p6 + 2 + Noblegas + ccp + + + 87 + Francium + Fr + 7 + 223.0197 + s + 0 + 1 + 1939 + 0 + 1 + -44 + 0.7 + 300 + 950 + + + 4.0 + + + 270 + + + 180 + + + + Rn 7s1 + +1 + Alkali_Earth + + + 88 + Radium + Ra + 7 + 226.0254 + s + 0 + 1 + 1898 + 0 + 2 + + 0.89 + 973 + 1413 + 5.50 + + 5.279 + + + 223 + 215 + + 143 + 445.8 + + 0 + Rn 7s2 + +2 + Alkaline_Earth + bcc + + + 89 + Actinium + Ac + 7 + 227.0278 + f + 0 + 1 + 1899 + 0 + 3 + + 1.1 + 1324 + 3470 + 10.07 + + 6.9 + + + 187.8 + 195 + + 118 + 375.6 + + 0 + Rn 6d1 7s2 + (+2).+3 + Rare_Earth + ccp + + + 90 + Thorium + Th + 7 + 232.0381 + f + 0 + 1 + 1828 + 0 + 4 + + 1.3 + 2028 + 5060 + 11.72 + + 6.95 + + + + + + + + + + + + + 179.8 + + 100 + 359.5 + + 12 + +3.+4 + Rare_Earth + Rn 6d2 7s2 + ccp + + + 91 + Protactinium + Pa + 7 + 231.03588 + f + 0 + 1 + 1917 + 0 + 5 + + 1.5 + 1845 + 4300 + 15.37 + + + 180.6 + + 98 + 89 + 113 + 321.2 + + 12 + +4.+5 + + + + + + Rare_Earth + Rn 5f2 6d1 7s2 + own + + + 92 + Uranium + U + 7 + 238.02891 + f + 0 + 1 + 1789 + 0 + 6 + + 1.38 + 1408 + 4407 + 18.97 + + 6.08 + + + + + + + + + + + + + 138.5 + 175 + 186 + 97 + 80 + 73 + 277 + + 2.3 + +3.+4.+5.+6.+7 + Rare_Earth + Rn 5f3 6d1 7s2 + own + + + 93 + Neptunium + Np + 7 + 237.0482 + f + 0 + 1 + 1940 + 0 + 7 + + 1.36 + 912 + 4175 + 20.48 + + + + 131 + 175 + + 95 + 262 + + 0 + +4.+3.+5.+7 + + + + + + Rare_Earth + Rn 5f4 6d1 7s2 + own + + + 94 + Plutonium + Pu + 7 + 244.0642 + f + 0 + 1 + 1940 + 0 + 8 + + 1.28 + 913 + 3505 + 19.74 + + 5.8 + + + 151 + 175 + + 80 + 302.6 + + 0 + +3.+4.+5.+6.+7 + + + + + + + + + + Rare_Earth + Rn 5f6 7s2 + own + + + 95 + Americium + Am + 7 + 243.0614 + f + 0 + 1 + 1 + 1945 + 0 + 8 + + 1.3 + 1449 + 2880 + 13.67 + + 6.0 + + + 184 + 175 + + 100 + 345.0 + + 0 + +2.+3.+4.+5.+6 + + + + + + Rare_Earth + Rn 5f7 7s2 + + + 96 + Curium + Cm + 7 + 247.0703 + f + 0 + 1 + 1 + 1944 + 0 + 8 + + 1.3 + + + + + 98 + 347.7 + + 0 + 1620 + + 13.51 + +3.+4 + Rare_Earth + Rn 5f7 6d1 7s2 + + + 97 + Berkelium + Bk + 7 + 247.0703 + f + 0 + 1 + 1 + + + + + 98 + 339.8 + + 0 + 1949 + 0 + 1 + + 1.3 + 1258 + + 13.25 + +3.+4 + Rare_Earth + Rn 5f9 7s2 + + + 98 + Californium + Cf + 7 + 251.0796 + f + 0 + 1 + 1 + 1950 + 0 + 2 + + + + + + 98 + 337.7 + + 0 + 1.3 + 1172 + + 15.1 + +3.+4 + Rare_Earth + Rn 5f10 7s2 + + + 99 + Einsteinium + Es + 7 + 252.0829 + f + 0 + 1 + 1 + 1952 + 0 + 3 + + + 186 + + 98 + + + 0 + + + + + 1.3 + 1130 + +2.+3.+4 + Rare_Earth + Rn 5f11 7s2 + + + 100 + Fermium + Fm + 7 + 257.0951 + f + 0 + 1 + 1 + 1953 + 0 + 4 + + + + 190 + + 97 + + + 0 + + + + 1.3 + 1800 + +2.+3 + Rare_Earth + Rn 5f12 7s2 + + + 101 + Mendelevium + Md + 7 + 258.0986 + f + 0 + 1 + 1 + 1955 + 0 + 5 + + + + + 96 + + + 0 + + 1.3 + + + + 1100 + +2.+3 + Rare_Earth + Rn 5f13 7s2 + + + 102 + Nobelium + No + 7 + 259.1009 + f + + + + + 113 + + + 0 + 0 + 1 + 1 + 1958 + 0 + 6 + + 1.3 + 1100 + +2.+3.+4 + Rare_Earth + Rn 5f14 7s2 + + + + + + 103 + Lawrencium + Lr + 7 + 262.110 + f + 0 + 1 + 1 + 1961 + 0 + 7 + + 1.3 + 1900 + + + + + + + + + + + + 94 + + + 0 + +3 + Rare_Earth + Rn 5f14 7s2 7p1 + + + 104 + Rutherfordium + Rf + 7 + 261.1089 + d + 2 + 1 + 1 + 1964 + 0 + 4 + + + + + + + + + + + + + + + + + 0 + +3 + Transition + Rn 5f14 6d2 7s2 + + + 105 + Dubnium + Db + 7 + 262.1144 + d + 2 + 1 + 1 + 1967 + 0 + 5 + + + + + + + + + + + + + + + + + 0 + Rn 5f14 6d3 7s2 + Transition + + + 106 + Seaborgium + Sg + 7 + 263.1186 + d + 2 + 1 + 1 + 1974 + + + + + + + 0 + + + + 0 + 6 + + Transition + + + 107 + Bohrium + Bh + 7 + 262.1231 + d + 2 + 1 + 1 + 1981 + + + + + + + 0 + 0 + + + + 7 + + Transition + + + 108 + Hassium + Hs + 7 + 265.1306 + d + 2 + 1 + 1 + 1984 + 0 + + + + + + + 0 + 8 + + + + + Transition + + + 109 + Meitnerium + Mt + 7 + 266.1378 + d + 0 + 1 + 1 + 1982 + + + + + + + 0 + 0 + + + + 8 + + Transition + + + 110 + Darmstadtium + Ds + 7 + 271 + d + 0 + 1 + 1 + 1994 + 0 + + + + + + + 0 + + + + 8 + + Transition + + + 111 + Roentgenium + Rg + 7 + 272 + d + 0 + 1 + 1 + 1994 + 0 + + + + + + + 0 + + + + 1 + + Transition + + diff --git a/kalzium/src/data/knowledge.xml b/kalzium/src/data/knowledge.xml new file mode 100644 index 00000000..fbcde140 --- /dev/null +++ b/kalzium/src/data/knowledge.xml @@ -0,0 +1,283 @@ + + + + State of matter + Form of a substance; dependant on form stability and whether it takes up a definite volume: solid, liquid or gaseous. + + Boiling point + Melting point + + + + Chemical Symbol + One, two, or three letter abbreviation; set through international convention. + + Element + + + + Chromatography + Matter separation in a moving medium (mobile phase) through differentiated absorption on a static medium (stationary phase). + + + Distillation + Separation of a liquid solution (homogeneous mix) into its components through evaporation and condensation. In a fractionary distillation the process is repeated several times in a column. + + + Element + Matter that cannot be broken down into simpler matter. Chemical elements are cornerstones of Materials. Elements consist of atoms that consist of a nucleus of positive protons, neutral neutrons, and a shell of electrons. + + + Emulsion + Heterogeneous mix of two liquids. + + + Extraction + Processing a homogeneous or heterogeneous mix to get pure matter. + + Mix + + + + Filtering + Separation of a solid matter from a liquid matter or gaseous matter with a filter (porous separation wall). + + + Mix + Matter consisting of differentiated matter, combined in non-set ratios. [i]Homogeneous mixes[/i] have a coherent look, [i]heterogeneous mixes[/i] consist of multiple phases. + + + Accuracy + Consisting of accidental and systematic errors. + + + Law of Conservation of Mass + During a chemical reaction mass is neither lost nor gained. The sum mass of the material going into the reaction equals the sum of the mass of the products of the reaction. + + + Law of multiple proportions + An alloy always contains the same elements in the same mass ratio. Should two or more elements bind together then the mass ratio is constant. + + + Crystallization + Separation of solid, crystalline matter from a solution, or the liquid or gaseous phases. + + + Solution + Homogeneous mix of multiple pure materials + + + Mass + Measurement of an amount of matter. + + + Matter + All that takes up space and has mass. + + + Phase + Through chemical composition and physical attributes, homogeneous portion of matter that separated from its environment in its expansion through a surface. + + + Accuracy and precision + Expressed through standard deviation: Values given over accidental errors. + + + Correctness + Values given over accidental errors. + + + SI-Unit + Measurement unit using International Symbols. + + + Significant figures + The number of digits which are meaningful in a number. + + + Standard deviation + An amount with which the precision of a measurement can be estimates. + + + Suspension + Heterogeneous mix consisting of a liquid and solid matter. + + + Alloys + Pure matter consisting of multiple elements in a set ratio. + + + Alpha rays + Rays consisting of alpha particles, consisting of two protons and two neutrons that are emitted from the Atoms of certain radioactive elements. + + + Atom + Atoms are chemically inseparable and building blocks of matter. Atoms of one kind are called an Element. + + Element + Electron + Proton + Neutron + + + + Atomic nucleus + The small, positively-charged center of an Atom, in which Protons and Neutrons are found. + + Atom + + + + Atomic Mass + Mass of an atom, taken on a scale where the the mass of a carbon atom is 12u. In elements that consist of different isotopes the mid-range mass of the isotope mix is given. + + Atom + Mass + + + + Isotope + Isotopes are forms of a chemical element whose nuclei have the same atomic number, Z, but different atomic masses, A. The word isotope, meaning at the same place, comes from the fact that all isotopes of an element are located at the same place on the periodic table. + + Atom + + + + Spin + The spin is an intrinsic angular momentum associated with microscopic particles. It is a purely quantum mechanical phenomenon without any analogy in classical mechanics. Whereas classical angular momentum arises from the rotation of an extended object, spin is not associated with any rotating internal masses, but is intrinsic to the particle itself. + + Isotope + + + + Magnetic Moment + The magnetic moment of an object is a vector relating the aligning torque in a magnetic field experienced by the object to the field vector itself. It's measured in units of the nuclear magneton μ[sub]n[/sub]=(5.0507866 ± 0.0000017) 10[sup]-27[/sup] JT[sup]-1[/sup] + + Isotope + + + + Decay Mode + The decay mode describes a particular way a particle decays. For radioactive decay (the decay of nuclides) the decay modes are:[br] -> alpha decay (emission of a Helium-4 nucleus).[br] -> β[sup]-[/sup] decay (emission of an electron)[br] -> β[sup]+[/sup] decay (emission of a positron) [br] -> electron capture (EC) [br] -> proton emission [br] -> spontaneous fission [br] Typically one decay mode predominates for a particular nuclide. + + Isotope + + + + Decay Energy + The decay energy is the energy released by a nuclear decay. + + Isotope + + + + Nuclides + [i]see isotopes[/i] + + Isotope + Isotone + Nuclear Isomer + Isobars + + + + Isotone + Two nuclides are isotones if they have the same number N of neutrons. + + Isotope + Nuclear Isomer + Isobar + + + + Isobar + Isobars are nuclides having the same mass number, i.e. sum of protons plus neutrons. + + Isotope + Isotone + Nuclear Isomer + + + + Nuclear Isomer + A nuclear isomer is a metastable or isomeric state of an atom caused by the excitation of a proton or neutron in its nucleus so that it requires a change in spin before it can release its extra energy. They decay to lower energy states of the nuclide through two isomeric transitions:[br] -> γ- emission (emission of a high-energy photon)[br] -> internal conversion (the energy is used to ionize the atom)[br] Contrast this with the definition of a chemical isomer, the more common use of the word. Also contrast with the meaning of isotope, in which the difference is the number of neutrons in the nucleus. Metastable isomers of a particular atom are usually designated with an "m" (or, in the case of atoms with more than one isomer, 2m, 3m, and so on). This designation is usually placed after the atomic symbol and number of the atom (e.g., Co-58m), but is sometimes placed as a superscript before (e.g., [sup]m[/sup]Co-58 or [sup]58m[/sup]Co). + + Isotope + Isobar + Isotone + + + + Beta rays + Rays consisting of electrons that are emitted from Atoms of radioactive elements. + + + Electron + The electron is a subatomic particle with a mass of m[sub]e[/sub]=(9.1093897 ± 0.0000054)e-31 kg and a negative charge of [i]e[/i]=(1.60217733 ± 0.00000049)e-19 C + + + Atom + + + + Proton + The proton is a subatomic particle with a mass of m[sub]e[/sub]=(1.6726231 ± 0.0000010) 10[sup]-27[/sup] kg and a positive charge of [i]e[/i]=(1.60217733 ± 0.00000049) 10[sup]-19[/sup] C which occurs in the nucleus of an atom. + + Atom + Electron + Neutron + + + + Neutron + The neutron is a subatomic particle with a mass of m[sub]e[/sub]=(1.6749286 ± 0.0000010) 10[sup]-27[/sup] kg which occurs in the nucleus of an atom. + + Atom + Electron + Proton + + + + Cathode Rays + Cathode rays are streams of electrons observed in vacuum tubes, i.e. evacuated glass tubes that are equipped with at least two electrodes, a cathode (negative electrode) and an anode (positive electrode) in a configuration known as a diode. + + Electron + + + + Ionic Radius + The Ionic Radius is the radius of a charged atom, a so called ion. The ion can have a positive or a negative charge. The charge of the ion which radius you see is also displayed in Kalzium. A positive ion has less electrons in its shell then the atom, a negative ion has more electrons. Therefore, a postive ion has a smaller radius than its atom and vice versa. + + Covalent Radius + Atomic Radius + Van der Waals Radius + + + + Van der Waals Radius + The van der Waals radius of an atom is the radius of an imaginary hard sphere which can be used to model the atom for many purposes. Van der Waals radii are determined from measurements of atomic spacing between pairs of unbonded atoms in crystals. + + Covalent Radius + Atomic Radius + Ionic Radius + + + + Atomic Radius + The atomic radius is the distance from the atomic nucleus to the outmost stable electron orbital in a atom that is at equilibrium. + + Covalent Radius + Van der Waals Radius + Ionic Radius + + + + Covalent Radius + Covalent radius in chemistry corresponds to half of the distance between two identical atomic nuclei, bound by a covalent bond. + + Atomic Radius + Ionic Radius + Van der Waals Radius + + + diff --git a/kalzium/src/data/knowledge.xml.todo b/kalzium/src/data/knowledge.xml.todo new file mode 100644 index 00000000..c87560f6 --- /dev/null +++ b/kalzium/src/data/knowledge.xml.todo @@ -0,0 +1,1282 @@ + + + ElektronDONE-JB + Subatomares Teilchen mit der Masse 0,00055 u und Ladung -[i]e[/i]. Diese Ladung nennt man die Elementarladung. + + + Elementarladung + [img]e.png[/img] Das Elektron hat eine negative, das Proton eine positive Elementarladung. + + + IsotopeDONE-JB + Atome des gleichen Elements und daher gleicher Ordnungszahl, aber unterschiedlicher Massen- und Neutronenzahl. + + + Kanalstrahlen oder positive Strahlen + Strahlen von positiven Ionen. + + + KathodenstrahlDONE-JB + Strahl von Elektronen, die von der Kathode (negativen + Elektrode) in einem evakuierten Rohr ausgehen. + + + Kernbindungsenergie + Das Energiequivalent zum Massendefekt eines Atomkerns. + Sie entspricht der Energie, die aufzubringen wre, um den Atomkern in seine + Nucleonen zu zerlegen. + + + Massenspektrometer + Instrument, mit dem die Masse von Isotopen und deren relative Hufigkeit gemessen werden kann. + + + Massenzahl + Summe aller Protonen und Neutronen im Atomkern. Symbol: "A" + + + NeutronDONE-JB + Subatomares Teilchen ohne elektrische Ladung, mit Masse 1,0087 u, das im Atomkern vorkommt. + + + ProtonDONE-JB + Subatomares Teilchen mit positiver Ladung und Masse 1,0073 u + und das im Atomkern vorkommt. + + + Radioaktivitt + Der spontane Zerfall von Atomkernen unter Aussto von radioaktiver Strahlung und Umwandlung zu anderen Kernen; natrliche radioaktive Stoffe geben Alpha-, Beta- oder Gamma-Strahlen ab. + + + Relative Atommasse A + Relative Atommasse A Masse eines Atoms relativ zum zwlften Teil der Masse eines Atoms C-12 + Atom + + + Anion + Negativ geladenes Ion, entstanden durch Aufnahme eines + oder mehrerer Elektronen durch ein Atom oder eine Gruppe von kovalent + miteinander verbundenen Atomen. + + + Avogadro-Zahl + Zahl der Teilchen in einem Mol: [img]n.png[/img] + + + + Chemische Formel + Formel zur Bezeichnung der Art und relativen Anzahl der + Atome in einer Verbindung mit Hilfe von Elementsymbolen. + + + Einatomiges Ion + Geladenes Atom. Zum Beispiel F(-) + Atom + + + Empirische Formel + Chemische Formel, die das einfachste ganzzahlige + Verhltnis der Atome in einer Verbindung bezeichnet. + + + Massenanteil + Anteil des Elements [i]X[/i] an der Masse der Verbindung oder Konzentrationsangabe einer Lsung als Masse des gelsten Stoffes pro Masse Lsung.[i]w[/i] * 100% = Massenprozent. + + + Mehratomiges Ion (Molekl-Ion) + Ion, das aus mehreren Atomen besteht. + Atom + + + Mol + Stoffmenge, die genauso viele Teilchen enthlt wie Atome in C-12 enthalten sind, nmlich die Avogadro-Zahl [i]N[/i]. + + + Molare Masse + Masse eines Mols eines Stoffes. Diese Masse eines Molekls ergibt sich aus der Summe der molaren Massen der Atome. + + + Molmasse + + Molare Masse,Avogadro-Zahl + + + Molekl + Teilchen, das aus mehreren aneinander gebundenen Atomen besteht. + Atom + + + Moleklformel oder Molekularformel + Chemische Formel, welche die Art und Zahl der Atome in einem Molekl bezeichnet. + + + Moleklmasse + Masse eines Molekls in u-Einheiten. + + + Relative Formelmasse und relative Moleklmasse + Summe der relativen Atommassen aller Atome in der Anzahl wie in der chemischen Formel bezeichnet. + + + Stchiometrie + Die quantitativen Beziehungen zwischen Elementen in einer Verbindung und zwischen Elementen und Verbindungen, die an einer chemischen Reaktion beteiligt sind. + + + Bildungsenthalpie + Reaktionsenthalpie fr die Bildung einer Verbindung aus den Elementen in deren stabilster Form. Die Standard-Bildungsenthalpie bezieht sich auf die Bildungsreaktion unter Standard-Bedingungen, d.h. Norm-Atmosphrendruck (101,3kPa) und einer Standard-Temperatur, in der Regel 25C = 298 K. + + + Bildungsenergie + Bentigte Energie, um die Bindung zwischen zwei Atomen aufzubrechen. Die (Bindungs-) Dissoziationsenergie bezieht sich auf die aufzuwendende Energie zur Trennung der Atome eines zweiatomigen Molekls. Die mittlere Bindungsenergie bezieht sich auf mehratomige Molekle und ist ein Mittelwert fr gleichartige Bindungen. + + + + Endotherme Reaktion + Chemische Reaktion unter Aufnahme von Wrme + + + Energie + Die Fhigkeit, Arbeit zu leisten + + + Exotherme Reaktion + Chemische Reaktion unter Abgabe von Wrme + + + Enthalpie + Es gilt [img]enthalpie.png[/img] Die Zustandsfunktion [i]H[/i] nennt man [b]Enthalpie[/b]. Die nderung der Enthalpie entspricht also der nderung der inneren Energie U und der Volumenarbeit pV bei konstantem Druck. Fr Reaktionen ohne Volumennderung ist also die nderung der inneren Energie gleich der Enthalpiedifferenz. + + + Innere Energie + Der Energieinhalt eines Systems mit dem Symbol [i]U[/i]. Die Reaktionsenergie ist die Differenz der inneren Energie von Produkten und Reaktanden, es gilt dabei [img]enthalpie.png[/img] + + + Joule + SI-Einheit fr die Energie. Dabei gilt: [img]joule.png[/img] + + + Kalorimeter + Gert zur Messung der umgesetzten Wrme bei chemischen oder physikalischen Vorgngen. + + + Kalorie + ltere Einheit fr Wrmeenergie. Sie entspricht der Energie, die zum Erwrmen von 1g Wasser von 14,5 auf 15,5 C bentigt wird; genaue Definition: 1 cal = 4.184 J (exakt). + + + Reaktionsenergie + Gesamtenergie, die bei einer chemischen Reaktion aufgenommen oder abgegeben wird; sie entspricht der Differenz der inneren Energien von Produkten und Reaktanden. + + + Reaktionsenthalpie + Energie, die als Wrme bei einer chemischen Reaktion aufgenommen oder abgeben werden kann: [img]enthalpie.png[/img] + + + Satz von Hess + Die Reaktionsenthalpie ist unabhngig davon, ob eine Reaktion in einem oder mehreren Schritten abluft. + + + Satz der konstanten Wrmesummen + Die Reaktionsenthalpie ist unabhngig davon, ob eine Reaktion in einem oder mehreren Schritten abluft. + + + Spezifische Wrme + Bentigte Wrmemenge, um 1 g einer Substanz um 1C zu erwrmen. + + + Thermochemie + Studium der bei chemischen Prozessen umgesetzten Wrmemengen + + + Volumenarbeit + Energieform, die spontan von einem Krper hherer Temperatur zu einem niedrigerer Temperatur fliet. + + + Wrmekapazitt + Bentigte Wrmemenge, um eine gegebene Masse um 1K zu erwrmen. + + + Wellenfunktion + Die Wellenfunktion (gr. Symbol Psi) ist eine mathematische Funktion zur Beschreibung eines Elektrons als Welle. Eine Wellenfunktion beschreibt nicht mehr die exakte Bewegung von Teilchen sondern sind ein Ma fr die Wahrscheinlichkeit mit der sich ein Teilchen an einem Ort aufhlt. + + + Valenzelektronen + Elektronen der uersten Schale eines Hauptgruppenelements, der uersten zwei Schalen eines Nebengruppenelements oder der uersten drei Schalen eines Lanthanoids oder Actinoids. + + + Unterschale + Durch die Nebenquantenzahl [i]l[/i] bezeichnete Gruppe von Orbitalen gleicher Energie in einer Schale. + + + Unschrferelation + W. Heisenberg hat 1927 die Unschrferelation aufgestellt. Diese Theorie sagt aus, dass man von einem Teilchen nicht gleichzeitig Ort ([i]x[/i]) und Impuls ([i]mv[/i]) exakt bestimmen kann. Es ergibt sich folgende Beziehung: [img]unschaerfe.png[/img] Die Unbestimmtheit des Ortes ist mit 70nm etwa 1300 Mal grer als der Radius im Bohr'schen Atommodell (r = 0.053 nm). Somit sind also Bahnmodelle wie bei Bohr nicht zulssig, denn diese mechanischen Modelle treffen Aussagen ber Ort und Impuls gleichzeitig. Daher spricht man bei modernen Modellen auch von [b]Wahrscheinlichkeiten[/b] mit denen sich Teilchen aufhalten. + + + SpinDONE-JB + Deutung des Magnetfelds eines Elektrons als Folge einer Drehung um seine eigene Achse. Nur zwei Spinzustnde sind mglich, die durch die Spinquantenzahl s = +0.5 oder -0.5 charakterisiert werden. + + + Spektrum + Durch Aufteilung von Licht in Abhngigkeit von der Wellenlnge erhaltenes Muster. Weies Licht, in dem alle Wellenlngen vorkommen, ergibt ein kontinuierliches Spektrum. Substanzen, die aus einem angeregten Zustand Licht emittieren, ergeben ein Linienspektrum. + + + Schrdinger Gleichung + Gleichung, mit der die Wellenfunktionen der Orbitale berechnet werden. Siehe [i]Wellenfunktion[/i] + + + Schale + Gruppe von Orbitalen eines Atoms mit gleicher Hauptquantenzahl n. + + + Photon + Kleinste Energieportion von elektromagnetischer Strahlung. Seine Energie E ist der Frequenz der Strahlung proportional: [img]energie.png[/img] + + + Actinoide + Die Elemente, die im Periodensystem dem Actinium (Z = 89) folgen und bei denen als letztes ein 5f-Orbital besetzt wird. + + + Angeregter Zustand + Zustand eines Atoms oder Molekls mit einer Elektronenkonfiguration mit hherer Energie als im Grundzustand. + + + Aufbauprinzip + Prinzip zum Aufbau der Atome durch sukzessives Hinzufgen von Protonen und Elektronen. + + + Ausschlieungsprinzip (Pauli-Prinzip) + Es drfen keine zwei Elektronen in einem Atom in allen vier Quantenzahlen (n, l, m und s) bereinstimmen. + + + Bohr-Atommodell + Modell fr das Wasserstoff-Atom, bei dem das Elektron nur auf definierten Kreisbahnen umlaufen kann. + Atom + + + de Broglie-Beziehung + Beziehung zwischen der Wellenlnge und dem Impuls eines Quants, wenn ein Teilchen als Welle beschrieben wird. + + + Diamagnetismus + Substanz, in der alle Elektronen gepaart sind. Sie wird von einem Magnetfeld abgestoen. + + + Edelgase + Elemente der 0. Gruppe (VIII. Hauptgruppe) des Periodensystems. Es sind: Helium, Neon, Argon, Krypton, Xenon und Radon. Sie zeichnen sich durch besondere chemische Reaktionstrgheit aus, woher auch der Name kommt. + + + Elektromagnetische Strahlung + Strahlung, die sich mit Lichtgeschwindigkeit (c = 2997.9 Kilometer pro Sekunde) ausbreitet und je nach Experiment als Welle oder als Strahl von Photonen beschrieben werden. + + + Elektronenkonfiguration + Anordnung der Elektronen in einem Atom (Verteilung auf die Orbitale). + Grundzustand + + + Grundzustand + Zustand mit der geringsten mglichen Energie fr ein Atom oder Molekl. + + + Ionisierungsenergie + Aufzuwendende Energie, um einem Atom oder Ion das am schwchsten gebundene Elektron zu entreien. Die erste Ionisierungsenergie betrifft das erste Elektron eines Atoms, die zweite das zweite Elektron usw. + + + Orbital + Wellenfunktion eines Elektrons in einem Atom; sie ist durch die Quantenzahlen n, l und m charakterisiert. Zu jedem Orbital gehrt ein definierter Energiezustand und eine definierte Verteilung der Ladungsdichte. Maximal zwei Elektronen mit entgegengesetztem Spin knnen das gleiche Orbital besetzen. Das folgende Bild zeigt die fnf D-Orbitale: [img]d_orbitale.jpg[/img] + + + Paramagnetismus + Substanzen, die ungepaarte Elektronen enthalten, sind paramagnetisch und werden in ein magnetisches Feld hineingezogen + + + Periodensystem + Tabelle der chemischen Elemente, geordnet nach ihrer Ordnungszahl und nach ihren chemischen Eigenschaften.[img]pse.png[/img] + + + Periode + Elemente, die in einer Zeile des Periodensystems stehen. + + + Bindungslnge + Abstand zwischen den Atomkernen zweier aneinander gebundener Atome. + + + Born-Haber-Kreisprozess + Berechnungsverfahren fr die Gitterenergie einer Ionenverbindung aus mebaren Enthalpiewerten + + + Abschirmung + Verringerung der auf die Auenelektronen wirksamen Kernladung durch innere Elektronen. + + + Effektive Atomgre + Aufgrund des Abstands zwischen Atomen ermittelte Gre eines Atoms. Je nach der Art der Bindung variiert die effektive Gre, die als Kovalenz-, Ionen-, Metall- oder van der Waals-Radius zum Ausdruck gebracht wird. + Atom + + + Elektronenaffinitt + Die erste Elektronenaffinitt ist die Energie, die umgesetzt wird, wenn in einem Gas ein Atom im Grundzustand ein Elektron aufnimmt. Die zweite Elektronenaffinitt bezieht sich auf die Aufnahme eines zweiten Elektrons usw. + + + Gitterenergie + Freigesetzte Energie, wenn Ionen aus dem Gaszustand zu einem Ionenkristall zusammengefgt werden. + + + Ionenbindung + Anziehende Kraft, die negative und positive Ionen zusammenhlt und zu einem Ionenkristall fhrt. Sie kommt durch den bergang von Elektronen von einer Atomsorte auf eine andere zustande. + + + Ionenradius + Radius fr die effektive Gre eines einatomigen Ions in einem Ionengitter. Er wird aus den Abstnden zwischen den Ionen berechnet. + + + Ionenverbindung + Verbindung, die aus Kationen und Anionen aufgebaut ist und durch die elektrostatische Anziehung zwischen ihnen zusammengehalten wird. + + + Isoelektronisch + Zwei Teilchen sind dann isoelektronisch wenn sie die gleiche Elektronenkonfiguration haben. + + + Kation + Positiv geladenes Ion, entstanden durch Abgabe von einem oder mehreren Elektronen aus einem Atom oder einer Gruppe von kovalent miteinander verbundenen Atomen. + + + Koordinationszahl + Die Anzahl der nchsten Nachbarionen um ein Ion in einem Ionenkristall oder die Anzahl der an ein Zentralatom direkt gebundenen Atome. + + + Kovalenzradius + Radius fr die effektive Gre eines Atoms, das durch kovalente Bindung mit einem anderen Atom verknpft ist. + + + van der Waals-Radius + Radius fr die effektive Gre eines Atoms, das nur durch die schwachen van der Waals-Krfte in Kontakt zu einem anderen Atom gehalten wird. + + + Binre Verbindung + Verbindung, die aus zwei Elementen aufgebaut ist. Zum Beispiel Salzsure (HCl) oder Kochsalz (NaCl) + + + Bindendes Elektronenpaar + Elektronenpaar, das eine kovalente Bindung zwischen zwei Atomen vermittelt. + + + Dipolmoment + Produkt aus dem Abstand zwischen den Ladungen und dem Betrag der Ladungen eines elektrischen Dipols. + + + Einsames Elektronenpaar + Valenzelektronenpaar, das nicht an einer kovalenten Bindung beteiligt ist. + + + Freies Elektronenpaar + + Einsames Elektronenpaar + + + Formalladung + Eine willkrlich einem Atom zugewiesene elektrische Ladung, die sich ergibt, wenn die Bindungselektronen gleichmig auf die beteiligten Atome aufgeteilt werden. Formalladungen sind ntzlich zur Bewertung und Interpretation von Formeln, Strukturen und Eigenschaften von Moleklen und Molekl-Ionen, geben aber nicht die tatschliche Ladungsverteilung wieder. + + + Kovalente Bindung + Bindung die durch gemeinsame Elektronen zwischen zwei Atomen bewirkt wird. Bei einer Einfachbindung ist ein gemeinsames Elektronenpaar vorhanden, bei einer Doppel- und einer Dreifachbindung sind es zwei bzw. drei gemeinsame Elektronenpaare. + + + Mesomerie + Bindung die durch gemeinsame Elektronen zwischen zwei Atomen bewirkt wird. Bei einer Einfachbindung ist ein gemeinsames Elektronenpaar vorhanden, bei einer Doppel- und einer Dreifachbindung sind es zwei bzw. drei gemeinsame Elektronenpaare. + + + Resonanz + + Mesomerie + + + Oktett-Regel + Nichtmetalle (auer Wasserstoff) gehen so viele kovalente Bindungen ein, bis sie die acht Elektronen der folgenden Edelgaskonfiguration um sich haben. Das sind in der Regel 8 - N kovalente Bindungen, wenn N die Hauptgruppennummer ist. + + + Partieller Ionencharakter + Ein Zahlenwert in Prozent, der die tatschliche Polaritt einer kovalenten Bindung im Verhltnis zur hypothetischen Polaritt angibt, die vorlge, wenn zwischen den Atomen eine Ionenbindung bestnde. + + + Antibindendes Moleklorbital + Moleklorbital mit geringer Elektronendichte im Bereich zwischen zwei Atomen. Elektronen eines antibindenden Moleklorbitals liegen energetisch hher als Elektronen der Atomorbitale, von denen sie abgeleitet wurden. Die Besetzung eines antibindenden Orbitals mit Elektronen schwcht die Bindung zwischen den Atomen. + + + Bindendes Moleklorbital + Moleklorbital mit hoher Elektronendichte im Bereich zwischen zwei Atomen. Elektronen eines bindenden Moleklorbitals liegen energetisch tiefer als Elektronen der Atomorbitale, von denen sie abgeleitet wurden. + + + Bindungsordnung + Die Hlfte aus dem Betrag der Anzahl der bindenden minus der Anzahl der antibindenden Elektronen einer Bindung. + + + Delokalisierte Bindung + Moleklorbital, dessen Ladungswolke sich ber mehr als zwei Atome erstreckt (s. auch Mehrzentrenbindung). + + + Hybridisierung + Mathematisches Verfahren, bei dem Wellenfunktionen von Atomorbitalen kombiniert werden, um Wellenfunktion fr einen neuen Satz von gleichwertigen Orbitalen zu erhalten. Hybridorbitale werden so gewhlt, dass sie der tatschlichen Struktur eines Molekls entsprechen. + + + Moleklorbital + Orbital, das zu einem Molekl und nicht zu einem einzelnen Atom gehrt. + + + Pi-Bindung + Kovalente Bindung, deren Ladungsdichte sich auf zwei Bereiche neben der Verbindungslinie zwischen den Atomkernen erstreckt. + Sigma-Bindung + + + Sigma-Bindung + Kovalente Bindung mit hoher, rotationssymmetrisch verteilter Ladungsdichte im Bereich zwischen zwei Atomkernen. + Pi-Bindung + + + Valenzelektronenpaar-Abstoungs-Theorie + Theorie zur Voraussage der Moleklgestalt durch Beachtung der gegenseitigen Abstoung zwischen bindenden wie auch nichtbindenden Valenzelektronenpaaren eines Atoms. Druck, Volumen und Temperatur sind die Zustandsgren eines Gases. + + + VSEPR + + Valenzelektronenpaar-Abstoungs-Theorie + + + Atmosphrendruck + Gasdruck der Atmosphre. Der mittlere Atmosphrendruck auf Hhe des Meeresspiegels betrgt 101,325 kPa = 1,01325 bar und entspricht der alten Einheit einer physikalischen Atmosphre (1 atm). + Bar + + + Avogadro-Gesetz + Gleiche Volumina beliebiger Gase enthalten bei gleichem Druck und gleicher Temperatur gleich viele Teilchen. + + + Bar + Einheit fr den Druck; 1 bar = 105 Pa. + Druck + + + Barometer + Gert zum Messen des Atmosphrendrucks. + Druck + + + Boyle-Mariotte-Gesetz + Bei konstanter Temperatur ist das Volumen eines Gases umgekehrt proportional zu seinem Druck. + + + Dalton-Gesetz der Partialdrcke + Der Gesamtdruck eines Gasgemisches ist gleich der Summe der Partialdrcke aller anwesenden Gase. + Druck,Barometer + + + Druck + Kraft pro Flche. + + + Effusion + Als Effusion bezeichnet man das Ausstrmen eines Gases. + Graham-Effusionsgesetz + + + Gay-Lussag-Gesetze + Bei konstantem Druck ist das Volumen eines Gases proportional zur absoluten Temperatur. Bei konstantem Volumen ist der Druck eines Gases proportional zur absoluten Temperatur. + + + Graham-Effusionsgesetz + Die Ausstrmungsgeschwindigkeit eines Gases ist umgekehrt proportional zur Wurzel seiner Dichte oder zur Wurzel seiner molaren Masse. + Effusion + + + Ideale Gaskonstante R + Proportionalittskonstante im idealen Gasgesetz; [img]r.png[/img] + + + Ideales Gasgesetz + Druck p, Volumen V, Stoffmenge n und Temperatur T eines Gases hngen ber die ideale Gaskonstante R wie folgt miteinander zusammen: [img]idealesgg.png[/img] + Ideale Gaskonstante R + + + Kelvin + SI-Einheit zur Temperaturmessung auf der absoluten Temperaturskala. Die Temperatur in Kelvin ergibt sich aus der Temperatur in C durch Addition von 273,15. + Temperatur + + + Kinetische Gastheorie + Modell zur Erklrung der Eigenschaften von Gasen und zur Ableitung des idealen Gasgesetzes. + + + Kompressibilittsfaktor + pV/RT; fr 1 mol eines idealen Gases ist er immer gleich 1. + + + Kritischer Druck + Druck, der mindestens ausgebt werden muss, um ein Gas bei der kritischen Temperatur zu verflssigen. + Kritischer Druck + + + Kritische Temperatur + Hchste Temperatur, bei der ein Gas durch Druckausbung verflssigt werden kann. + + + Manometer + Gert zur Messung des Druckes in einem Behlter. + Barometer + + + Maxwell-Boltzmann-Geschwindigkeitsverteilung + Statistische Verteilung der Geschwindigkeiten der Teilchen in einem Gas. + + + Mittlere freie Weglnge + Mittlere Weglnge, die ein Teilchen in einem Gas zwischen zwei Kollisionen mit anderen Teilchen zurcklegt. + + + Molvolumen + Volumen, das ein Mol eines Gases einnimmt. Bei Normbedingungen ist das Volumen 22,414 L + + + Normbedingungen + Druck p = 101,325 kPa und Temperatur T = 273,15 K. + + + Partialdruck + Druck, den eine Komponente eines Gasgemisches ausben wrde, wenn sie als einzige im gleichen Volumen anwesend wre. + Bar,Druck,Pascal + + + Pascal + SI-Einheit fr den Druck [img]pascal.png[/img] + Bar,Druck + + + Temperatur + Zustandsgre von Materie, die bestimmt, in welcher Richtung Wrme fliet. Bei einem Gas ist sie der mittleren kinetischen Energie der Teilchen proportional. + + + Amorpher Feststoff + Feststoff, in dem die Teilchen nicht zu einem regelmig geordneten Muster angeordnet sind; er hat keinen definierten Schmelzpunkt. Glser sind amorphe Feststoffe. + + + Dampfdruck + Druck des Dampfes, der mit einer Flssigkeit oder einem Feststoff im Gleichgewicht steht. + + + Dipol-Dipol-Krfte + Anziehungskrfte zwischen polaren Moleklen aufgrund der Anziehung zwischen entgegengesetzten Polen. + Intermolekulare Krfte,van der Waals-Krfte + + + Gefrierpunkt + Temperatur, bei der Flssigkeit und Feststoff miteinander im Gleichgewicht sind. + Siedepunkt + + + Schmelzpunkt + + Gefrierpunkt + + + Intermolekulare Krfte + Krfte zwischen Moleklen, die diese in Feststoffen und Flssigkeiten aneinander halten. + + + van der Waals-Krfte + Anziehungskrfte zwischen polaren Moleklen aufgrund der Anziehung zwischen entgegengesetzten Polen. + Intermolekulare Krfte,Dipol-Dipol-Krfte + + + London-Krfte + Stets vorhandene, zwischenmolekulare Anziehungskrfte. Sie werden durch Anziehung zwischen momentanen Dipolen bewirkt, die durch die Bewegung der Elektronen zustande kommen. + + + Dispersionskrfte + + London-Krfte + + + Modifikationen + Unterschiedliche Kristallstrukturen bei ein und derselben Substanz. + + + Oberflchenspannung + In das Innere einer Flssigkeit gerichtete Kraft, bedingt durch die intermolekularen Anziehungen. + + + Phasendiagramm + Diagramm, aus dem sich die Existenzbereiche der Phasen einer Substanz in Abhngigkeit von Druck und Temperatur ersehen lassen. + + + Polymorphie + Das Auftreten mehrerer Modifikationen fr eine feste Substanz. + + + Schmelzenthalpie + Aufzuwendende Energie, um eine gegebene Menge eines Feststoffes bei gegebener Temperatur zu verflssigen; die Kristallisationsenthalpie hat den gleichen Betrag, jedoch negatives Vorzeichen. + + + Siedepunkt + Temperatur, bei welcher der Dampfdruck einer Flssigkeit gleich gro ist wie der uere Atmosphrendruck; der normale Siedepunkt wird bei einem Dampfdruck von 101,3 kPa beobachtet. + Gefrierpunkt + + + Sublimation + Direkte Verdampfung eines Feststoffes ohne zwischenzeitliche Verflssigung. Bekannt ist dieser Vorgang beim sog. Trockeneis. Hierbei handelt es sich um gefrorenen Kohlendioxid der direkt gasfrmig wird. + + + Tripelpunkt + Temperatur und Druck, bei dem von einer Substanz die feste, flssige und gasfrmige Phase miteinander im Gleichgewicht stehen. + + + Verdampfungsenthalpie + Aufzuwendende Energie, um eine gegebene Flssigkeitsmenge bei gegebener Temperatur zu verdampfen; die Kondensationsenthalpie hat den gleichen Betrag, jedoch negatives Vorzeichen. + + + Viskositt + Widerstand, den eine Flssigkeit dem Flieen entgegensetzt. + + + Wasserstoffbrcke + Intermolekulare Anziehung zwischen dem Wasserstoff-Atom eines Molekls und einem einsamen Elektronenpaar eines anderen Molekls; das Wasserstoff-Atom muss eine relativ hohe Partialladung haben, das einsame Elektronenpaar muss zu einem elektronegativen Atom gehren (vorzugsweise F, O oder N). + + + Azeotropes Gemisch + Eine Lsung, die einen hheren oder niedrigeren Dampfdruck als jede ihrer Reinkomponenten hat. Durch Destillation kann sie nicht in ihre Reinkomponenten getrennt werden. + + + Clausius-Clapeyron-Gleichung + Beziehung zwischen der Verdampfungsenthalpie und den Dampfdrcken p1 und p2 einer Flssigkeit bei zwei verschiedenen Temperaturen: [img]clausius.png[/img] + + + Elektrolyt + Ein Stoff, der in wssriger Lsung Ionen bildet. Elektrolyten leiten Strom. + + + Gefrierpunktserniedrigung + Absenkung des Gefrierpunkts eines Lsungsmittels, wenn ein nichtflchtiger Stoff darin gelst ist: [img]gfperniedrigung.png[/img] + Siedepunktserhhung,Siedepunkt + + + Henry-Dalton-Gesetz + Die Lslichkeit eines Gases in einer Flssigkeit, mit der es nicht reagiert, ist proportional zum Partialdruck des Gases ber der Lsung. + + + Hydratation + Umhllung von in Wasser gelsten Teilchen durch Wasser-Molekle aufgrund von anziehenden Krften. + + + Hydrathlle + In Wasser gelste Teilchen werden von Wassermoleklen umgeben. Diesen Vorgang nennt man auch Hydratation. Die vergrert den Ionenradius auf den sogenannten [b]effektiven Radius[/b]. Dieser Unterschied kann sehr gro sein. Beispielsweise ist hydratisiertes Lithium (das 3.kleinste Ion) grer als die des Csium-Ions (Elementnmmer 55). + + + Hydratationsenthalpie + Energie, die freigesetzt wird, wenn Ionen aus dem Gaszustand in hydratisierte Ionen in wssriger Lsung berfhrt werden. + Hydrathlle + + + Ideale Lsung + Lsung, die dem Raoult-Gesetz gehorcht. + + + Lsungsenthalpie + Beim Lsen einer bestimmten Stoffmenge freigesetzte oder aufgenommene Wrme; sie hngt von der Temperatur und der Konzentration der Lsung ab. + + + Massenkonzentration + Konzentrationsangabe einer Lsung als Masse gelster Stoff pro Volumen Lsung. + Masse + + + Molalitt + Konzentrationsangabe einer Lsung in Mol gelster Stoffe pro kg Lsungsmittel. Symbol [i]b[/i] + Molare Masse + + + Osmose + Fluss von Lsungsmittel-Moleklen durch eine semipermeable Membran von einer verdnnten in eine konzentriertere Lsung. + + + Prinzip des kleinsten Zwanges + Wird auf ein im Gleichgewicht befindliches System ein Zwang ausgebt, so weicht es aus und ein verlagertes Gleichgewicht stellt sich ein. + + + Le Chatelier-Prinzip + + Prinzip des kleinsten Zwanges + + + Raoult-Gesetz + Der Partialdruck einer Komponente einer idealen Lsung ist gleich Stoffmengenanteil der Komponente mal Dampfdruck der einen Komponente. + Dalton-Gesetz der Partialdrcke + + + Siedepunktserhhung + Erhhung des Siedepunkts eines Lsungsmittels, wenn ein nichtflchtiger Stoff darin gelst ist: [img]sdperhoehung.png[/img] + Gefrierpunktserniedrigung,Siedepunkt + + + Gesttigte Lsung + Wenn man in ein Lsungsmittel eine grere Menge eines Stoffes hinzufgt, als sich darin lsen kann, so stellt sich eine Gleichgewicht zwischen der Lsung und dem Bodensatz ein. Es geht also stndig ungelster Stoff in Lsung und gelster Stoff wird ausgeschieden. Die Konzentration der Lsung bleibt dabei konstant. + + + Solvatation + Umhllung von gelsten Teilchen durch Lsungsmittel-Molekle aufgrund von anziehenden Krften. + + + Van't Hoff-Faktor + Verhltnis der beobachteten Gefrierpunktserniedrigung, Siedepunktserhhung, Dampfdruckerniedrigung oder des osmotischen Druckes einer Elektrolyt-Lsung relativ zum Erwartungswert fr eine Nichtelektrolyt-Lsung. + Siedepunktserhhung,Gefrierpunktserniedrigung,Osmose + + + Volumenanteil + Konzentrationsangabe als Verhltnis des Volumens einer Komponente zur Summe der Volumina aller Komponenten. + + + Amphotere Verbindungen + Verbindungen, die sowohl saure wie basische Eigenschaften hat und sowohl mit Basen als auch mit Suren reagiert. + + + quivalentkonzentration + Stoffmengenkonzentration multipliziert mit der quivalentzahl (alte Bezeichnung: Normalitt). + + + quivalentmasse + Molare Masse geteilt durch die quivalentzahl. + + + quivalentzahl + Anzahl [i]z[/i] der fr eine Reaktion mageblichen Teilchen (Protonen, Hydroxyd-Ionen, Elektronen), die von einem Molekl eines Reagenzes zur Verfgung gestellt werden kann. + + + quivalenzpunkt + Punkt whrend einer Titration, bei dem quivalente Mengen der Reaktanden zusammengegeben wurden. + + + Arrhenius-Base + Verbindung, die in Wasser Hydroxyd-Ionen bildet. + Arrhenius-Sure + + + Arrhenius-Neutralisation + Reaktion zwischen H+(aq)- und OH-(aq)-Ionen unter Bildung von Wasser. + + + Arrhenius-Sure + Verbindung, die in Wasser Protonen abgibt. + Arrhenius-Base + + + Base + Nach Arrhenius ein Stoff, der in wssriger Lsung Hydroxyd-Ionen bildet. Nach Brnstedt ein Stoff, der Protonen anlagern kann. Nach Lewis ein Elektronenpaar-Donator. + Sure + + + Basisches Oxid + Oxid, das mit Wasser eine Base und mit Suren Salze bildet. + + + Disproportionierung + Reaktion, bei der eine Substanz gleichzeitig zum Teil oxidiert und zum Teil reduziert wird. + Komproportionierung + + + Einprotonige Sure + Sure, die nur ein Proton pro Molekl abgeben kann. + + + Fllung + Reaktion in einer Lsung, bei der eine unlsliche Verbindung, ein Niederschlag, gebildet wird. + + + Indikator + Substanz, die z.B. bei einer Titration das Erreichen des quivalenzpunktes anzeigt. Ein Sure-Base-Indikator hat verschiedene Farben bei verschiedenen pH-Werten. + + + Komproportionierung + Reaktion, bei der zwei Verbindungen, in denen das gleiche Element mit unterschiedlichen Oxidationszahlen vorliegt, zu einer Verbindung mit einer dazwischen liegenden Oxidationszahl reagieren. + Disproportionierung + + + Mehrprotonige Sure + Sure, die mehr als ein Proton pro Molekl abgeben kann. + + + Metathese-Reaktion + Reaktion zwischen zwei Verbindungen, bei der Kationen und Anionen ihre Partner tauschen. + + + Netto-Ionengleichung + Reaktionsgleichung, bei der nur die miteinander reagierenden Ionen bercksichtigt werden. + + + Neutralisation + Reaktion zwischen einer Sure und einer Base. + + + Normallsung + Lsung mit einer definierten quivalentkonzentration. + + + Oxidation + Teil einer Reaktion, bei der es zur Abgabe von Elektronen, d.h. zur Erhhung der Oxidationszahl kommt. + + + Oxidationsmittel + Substanz, die bei einer chemischen Reaktion reduziert wird und dadurch die Oxidation einer anderen Substanz bewirkt. + Oxidation + + + Oxidationszahl + Fiktive Ionenladung an einem Atom, die sich ergibt, wenn man alle Elektronenpaare von kovalenten Bindungen dem jeweils elektronegativeren Bindungspartner zuteilt. + Oxidation + + + Oxonium-Ion (Hydronium-Ion) + Ion, das aus einem Proton und einem Wasser-Molekl gebildet wird. + + + Reduktion + Teil einer Reaktion, bei der es zur Aufnahme von Elektronen, d.h. zur Erniedrigung der Oxidationszahl kommt. + + + Reduktionsmittel + Substanz, die bei einer chemischen Reaktion oxidiert wird und dadurch die Reduktion einer anderen Substanz bewirkt. + + + Sure + Nach Arrhenius, eine Wasserstoff-Verbindung, die in wssriger Lsung unter Abgabe von H(+)-Ionen und Bildung von Hydronium-Ionen dissoziiert. Nach Brnstedt eine Verbindung, die H(+)-Ionen abgeben kann (Protonen-Donator). Nach Lewis ein Elektronenpaar-Akzeptor. + Base + + + Sureanhydrid, saures Oxid + Nichtmetalloxid, das mit Wasser eine Sure bildet. + + + Schwache Suren und Basen + Suren und Basen, die nur partiell Hydronium- bzw. Hydroxyd-Ionen in wssriger Lsung bilden, also nicht vollstndig dissoziieren. + + + Starke Suren und Basen + Suren und Basen, die in wssriger Lsung vollstndig dissoziieren. + + + Volumetrische Analyse + Quantitative chemische Analyse, die auf der Messung von Lsungsvolumina basiert. + + + Adsorption + Vorgang, bei dem Molekle an der Oberflche eines Feststoffs haften bleiben. + + + Aktivierter Komplex (bergangszustand) + Instabile Atom-Anordnung, die vorbergehend im Verlaufe einer chemischen Reaktion auftritt. + + + Aktivierungsenergie + Energiedifferenz zwischen der potentiellen Energie des aktivierten Komplexes und derjenigen der Reaktanden. + + + Arrhenius-Gleichung + Beziehung zwischen der Geschwindigkeitskonstanten, der Aktivierungsenergie und der Temperatur fr eine chemische Reaktion[img]arrhenius.png[/img] + + + Chemisorption + Adsorption aufgrund von chemischen Bindungen zwischen einem adsorbierten Stoff und der Oberflche des adsorbierenden Feststoffes; dadurch werden die chemischen Eigenschaften der adsorbierten Molekle verndert und Katalyseprozesse ermglicht. + + + Effektive Kollision + Kollision zwischen Teilchen, die zu einer Reaktion fhrt. + + + Geschwindigkeitsbestimmender Schritt + Der langsamste Schritt bei einer mehrstufigen Reaktion; von ihm hngt die Geschwindigkeit der Gesamtreaktion ab. + + + Geschwindigkeitsgesetz + Mathematischer Ausdruck, der die Reaktionsgeschwindigkeit und die Reaktandenkonzentrationen in Beziehung setzt.[img]rggeschwindigkeit.png[/img] + + + Geschwindigkeitskonstante + Proportionalittskonstante in einem Geschwindigkeitsgesetz. + + + Halbwertszeit + Bentigte Zeit, bis bei einer Reaktion die Hlfte der Reaktanden verbraucht ist. Bei radioaktiven Substanzen: Zeit, die vergeht, bis die Hlfte der Probe zerfallen ist. + + + Heterogene Katalyse + Reaktionsbeschleunigung an einem Katalysator, der in einer anderen Phase als die Reaktanden vorliegt. + Homogene Katalyse,Katalysator + + + Homogene Katalyse + Reaktionsbeschleunigung durch einen Katalysator, der in der gleichen Phase wie die Reaktanden vorliegt. + Heterogene Katalyse,Katalysator + + + Katalysator + Substanz, die eine chemische Reaktion beschleunigt, ohne selbst verbraucht zu werden. Es findet dabei keine Gleichgewichtsverlagerung statt da sowohl die Hin- als auch die Rck-Reaktion beschleunigt werden. + Homogene Katalyse,Heterogene Katalyse + + + Kettenreaktion + Vielstufige Reaktion, bei der nach einem Startschritt zwei Reaktionsschritte abwechselnd vielfach wiederholt werden. + + + Nucleophile Substitution + Reaktion, bei der in einem Molekl eine nucleophile Gruppe (Lewis-Base) durch eine andere substituiert wird. Bei der SN1-Reaktion wird zuerst die eine Gruppe abgespalten, dann die neue Gruppe angelagert; bei der SN2-Reaktion verlaufen Anlagerung und Abspaltung synchron. + Substitution + + + Reaktionsgeschwindigkeit + Konzentrationsabnahme eines Reaktanden oder Konzentrationszunahme eines Reaktionsprodukts pro Zeiteinheit; sie ndert sich in der Regel im Verlaufe der Reaktion + Reaktionskinetik + + + Reaktionskinetik + Lehre der Reaktionsgeschwindigkeiten und Reaktionsmechanismen. + Reaktionsgeschwindigkeit + + + Reaktionsmechanismus + Beschreibung des Ablaufs einer chemischen Reaktion im einzelnen. + + + Reaktionsordnung + Die Summe der Exponenten der Konzentrationen im Geschwindigkeitsgesetz. + Reaktionskinetik + + + Theorie des bergangszustands + Theorie, bei der das vorbergehende Auftreten eines bergangszustands (oder aktivierten Komplexes) im Verlaufe eine Reaktionsschrittes angenommen wird. + + + Zwischenprodukt + Substanz, die im Verlaufe einer chemischen Reaktion entsteht und wieder verbraucht wird. + + + Chemisches Gleichgewicht + Zustand einer reversiblen chemischen Reaktion, bei dem die Hinreaktion gleich schnell wie die Rckreaktion abluft. + + + Gleichgewichtskonstante + Die Konstante im Massenwirkungsgesetz. Wird es mit Stoffmengenkonzentrationen formuliert, so erhlt man das Symbol Kc, wird es mit Partialdrcken von Gasen formuliert, so ist das Symbol Kp. + + Chemisches Gleichgewicht,Massenwirkungsgesetz + + + Heterogenes Gleichgewicht + Gleichgewicht, an dem Substanzen in verschiedenen Phasen beteiligt sind. + Chemisches Gleichgewicht + + + Massenwirkungsgesetz + Fr ein System im chemischen Gleichgewicht gilt: Das Produkt aus den Stoffmengenkonzentrationen (oder Partialdrcken) der Substanzen auf der rechten Seite der Reaktionsgleichung, jeweils potenziert mit den zugehrigen Koeffizienten der Reaktionsgleichung, geteilt durch das entsprechende Produkt der Substanzen auf der linken Seite der Reaktionsgleichung, ist gleich der Gleichgewichtskonstanten. [img]mwg.png[/img] + Chemisches Gleichgewicht + + + Reaktionsquotient + Zahlenwert, der sich ergibt, wenn beliebige Stoffmengenkonzentrationen (oder Partialdrcke) in den Ausdruck des Massenwirkungsgesetzes eingesetzt werden. Wenn Q = K, so herrscht Gleichgewicht; wenn Q kleiner K, so luft die Reaktion nach rechts ab, wenn Q grer K, so luft sie nach links ab. + Massenwirkungsgesetz + + + Elektrophile Verdrngungsreaktion + Reaktion, bei der eine Lewis-Sure eine andere, schwchere Lewis-Sure verdrngt. + Nucleophile Verdrngungsreaktion + + + Konjugiertes Sure-Base-Paar + Brnsted-Sure-Base-Paar, das durch Abgabe bzw. Aufnahme eines Protons in Beziehung steht. In folgendem Beispiel ist steht S fr Sure und B fr Base: [img]konjsbpaar.png[/img] + + + Lewis-Base + Teilchenart, die ein Elektronenpaar zur Verfgung stellen kann unter Ausbildung einer kovalenten Bindung: eine nucleophile Spezies. + Lewis-Sure,Base,Sure + + + Lewis-Sure + Teilchenart, die eine kovalente Bindung mit dem von einer Base zur Verfgung gestellten Elektronenpaar bilden kann: eine elektrophile Spezies. + Lewis-Base,Base,Sure + + + Lsungsmittelbezogene Base + Substanz, die in Lsung das charakteristische Anion des Lsungsmittel bildet. + Lsungsmittelbezogene Sure + + + Lsungsmittelbezogene Sure + Substanz, die in Lsung das charakteristische Kation des Lsungsmittel bildet. + Lsungsmittelbezogene Base + + + Nivellierender Effekt + Effekt des Lsungsmittels auf die Surestrke von Brnsted-Suren und -Basen. Eine gelste Sure kann nicht strker sauer wirken als die zum Lsungsmittel konjugierte Sure; eine gelste Base kann nicht strker basisch wirken als die zum Lsungsmittel konjugierte Base. + + + Nucleophile Verdrngungsreaktion + Nucleophile Substitution, bei der eine Lewis-Base eine andere, schwchere Lewis-Base verdrngt. + Elektrophile Verdrngungsreaktion + + + Aktivitt + Mit dem Aktivittskoeffizienten [i]f[/i] korrigierte Stoffmengenkonzentration mit dem Symbol [i]a[/i] um Abweichungen vom Massenwirkungsgesetz zu korrigieren. Je grer die Konzentration der Lsung, umso mehr weicht [i]f[/i] von 1 ab. + + + Basenkonstante + Gleichgewichtskonstante fr die Reaktion einer Base mit Wasser. + + + Dissoziationsgrad + Anteil der Gesamtkonzentration eines schwachen Elektrolyten, der zu Ionen dissoziiert ist. + + + Henderson-Hasselbalch-Gleichung + Gleichung zur Berechnung des pH-Werts einer Pufferlsung: [img]henderson.png[/img] + + + Ionenprodukt des Wassers + Produkt aus der Protonenkonzentration mit der Hydroxydionenkonzentration in wssrigen Lsungen; bei 25C gilt: [img]ionenprodukt.png[/img] + + + pH-Wert + Der negative Logarithmus der H+(aq)-Ionenkonzentration: [img]ph.png[/img] + pOH-Wert,pH-Wert + + + pK-Wert + Der negative Logarithmus einer Gleichgewichtskonstanten: [img]pk.png[/img] + + + pOH-Wert + Der negative Logarithmus der OH-(aq)-Ionenkonzentration. + pH-Wert,pK-Wert + + + Pufferlsung + Lsung, die eine schwache Sure und ihre konjugierte Base enthlt. Sie ndert ihren pH-Wert nur geringfgig bei Zugabe begrenzter Mengen von Suren oder Basen. + + + Suredissoziationskonstante + Gleichgewichtskonstante fr die Dissoziation einer Sure. + + + Titrationskurve + Graph zur Darstellung des pH-Werts oder des Reduktionspotentials als Funktion der zugegebenen Reagenzmenge im Verlaufe einer Titration. + + + Amphoteres Hydroxid + Schwerlsliches Hydroxid, das sowohl bei Zusatz von Basen wie auch von Suren in Lsung geht. + + + Gleichionige Zustze + Wird eine an einem Gleichgewicht beteiligte Ionenart einer Lsung zugesetzt, so verschiebt sich das Gleichgewicht. Gleichionige Zustze verringern im allgemeinen die Lslichkeit von schwerlslichen Verbindungen. + + + + Ionenprodukt bei schwerlslichen Verbindungen + Das wie beim Lslichkeitsprodukt gebildete mathematische Produkt der Ionenkonzentrationen einer Lsung. Ist es grer als das Lslichkeitsprodukte, so kommt es zur Fllungsreaktion. + + + Komplex + Verbindung, die durch Anlagerung von Liganden (Lewis-Basen) an ein Zentralatom (Lewis-Sure) entsteht. + + + Komplexbildungskonstante + Gleichgewichtskonstante fr die Bildungsreaktion eines Komplexes. + Komplexzerfallskonstante + + + Komplexzerfallskonstante + Gleichgewichtskonstante fr den Zerfall eines Komplexes: [img]kp.png[/img] + Komplexbildungskonstante + + + Dissoziationskonstante + Komplexzerfallskonstante + Komplexzerfallskonstante + + + Lslichkeitsprodukt + Gleichgewichtskonstante fr den Vorgang der Auflsung einer schwerlslichen Verbindung. Die schwerlsliche Verbindung ("Bodenkrper") befindet sich im Gleichgewicht mit Ionen in der Lsung. + + + Salzeffekt + Zusatz von Salzen zu einer Lsung erhht die Lslichkeit von schwerlslichen Verbindungen. + + + Thermodynamik + Die Thermodynamik beschreibt die Vernderung von Energien im Laufe eines Prozesses + + + 1. Hauptsatz der Thermodynamik + Energie kann von einer Form in eine andere Form umgewandelt werden. Die Gesamtsumme aller Energieformen ist konstant, sie kann weder erzeugt noch vernichtet werden. + + + 2. Hauptsatz der Thermodynamik + Bei spontanen Zustandsnderungen eines Systems vergrert sich dessen Entropie, die Unordnung des Systems nimmt zu. + + + Zustandsgre + Die Zustandsgre eines Systems ist nur von den momentanen Bedingungen, z.B. Druck und Temperatur abhngig, nicht jedoch davon wie dieser Zustand erreicht wurde, z.B. die Innere Energie [i]U[/i] + + + Verfahrensgre + Die Verfahrensgre eines Systems ist von der Art und Weise wie der momentane Zustand des Systems erreicht wurde abhngig, z.B. die Volumenarbeit + + + System + Eingegrenzter Bereich, der fr den aktuell ablaufenden Vorgang betrachtet wird. ber die Grenzen des Systems knnen je nach Randbedingungen Energie und Stoffe ausgetauscht werden + + + Umgebung + Alles was auerhalb des Systems ist. Die Umgebung kann Stoff und Energie mit dem System austauschen + + + Innere Energie + Die Summe aller mglichen Energien, die ein System abgeben kann + + + Entropie + Ist ein Ma fr die Unordnung in einem System. Bei freiwillig ablaufenden Prozessen nimmt die Entropie und somit die Unordnung immer zu. + + + Absolute Standardentropie + Ist die Entropie die 1 mol eines Stoffes enthlt, wenn er von einem perfekten Kristallgitter bei 0 K in den momentanen Zustand berfhrt wurde + + + Standardreaktionsentropie + Ist die Differenz der Entropie zwischen den Edukten und den Produkten einer Reaktion. + + + Freie Enthalpie + Auch Gibbsche Enthalpie genannt. Sie beinhaltet die Enthalpienderungen des betrachteten Systems sowie der Umgebung. Es gilt: [img]freieenthalpie.png[/img] + + + Freie Standardenthalpie + Beschreibt die Vernderung der Enthalpien einer Reaktion wenn diese bei Standardbedingungen, Druck = 1013 hPa, Temperatur meist 298 K durchgefhrt wird. Die Edukte und Produkte liegen dabei im Standardzustand vor. + + + Freie Standardbildungsenthalpie + Gibt die Reaktionsenthalpie fr 1 mol einer Substanz an, wenn diese aus den Elementen im Standardzustand hergestellt wird. + + + Gleichgewicht + Zustand bei dem die Reaktionsenthalpie eines Systems = 0 ist. + + + Anode + Elektrode, an der die Oxidation erfolgt. + Kathode + + + Bezugselektrode + Elektrode, deren Potential unabhngig von den Verhltnissen in der Lsung ist. + + + Brennstoffzelle + Galvanisches Element, bei dem die Reaktionsenthalpie eines Verbrennungsvorgangs direkt in elektrische Energie umgewandelt wird. + + + Daniell-Element + Galvanische Zelle mit Zink als Anode und Kupfer als Kathode. + Elektrode,Elektrolyse + + + Elektrode + Metallisch leitender Gegenstand, der zur Zu- oder Ableitung von elektrischem Strom in einen Elektrolyten eingetaucht ist. + + + Elektrolyse + Chemische Reaktion, die durch elektrischen Strom bewirkt wird. + + + Elektrolytische Leitung + Leitung von elektrischem Strom durch die Wanderung von Ionen durch eine Salzschmelze oder -lsung. Auch Leitung zweiter Ordnung + + + Elektromotorische Kraft (EMK) + Potentialdifferenz zwischen den Elektroden einer galvanischen Zelle; sie ist ein Ma fr die Tendenz zum Ablaufen einer Redoxreaktion. + Elektrode + + + Faraday-Gesetz + Um durch Elektrolyse ein quivalent eines Stoffes umzusetzen, werden F = 96485 C bentigt; F ist die Faraday-Konstante, sie entspricht der elektrischen Ladung von 1 mol Elektronen. + + + Galvanische Zelle + Zelle, in der eine Redoxreaktion zur Gewinnung von elektrischer Energie ausgenutzt wird. + + + Halbzelle + Hlfte einer galvanischen Zelle, in der entweder eine Oxidation oder eine Reduktion abluft. + Galvanische Zelle + + + Kathode + Elektrode, an der die Reduktion erfolgt. + Anode + + + Konzentrationskette + Galvanische Zelle, deren Halbzellen die gleichen Stoffe in unterschiedlichen Konzentrationen enthalten. + + + Lokalelement + Kleines, kurzgeschlossenes galvanisches Element an der Berhrungsstelle von zwei verschiedenen Metallen; ist eine Elektrolytflssigkeit anwesend, so wird das unedlere Metall oxidiert. + + + Nernst-Gleichung + Gleichung zur Berechnung des Reduktionspotentials in Abhngigkeit von Temperatur und Konzentrationen: [img]nernst.png[/img] + Oxidation,Reduktion,Elektromagnetische Kraft (EMK) + + + Normalpotential + Halbzellenpotential relativ zur Norm-Wasserstoffelektrode; alle anwesenden Stoffe mssen im Standardzustand vorliegen. + Norm-Wasserstoffelektrode + + + Norm-Wasserstoffelektrode + Bezugselektrode, deren Normalpotential willkrlich auf0V festgelegt ist. Sie besteht aus einem Platindraht, der von Wasserstoff bei 101,3 kPa umsplt wird und in eine Lsung mit Protonenaktivitt von 1 taucht. + + + Potentiometrische Titration + Titration, bei welcher der quivalenzpunkt durch Messung des Potentials einer Elektrode ermittelt wird, das von der Konzentration des zu bestimmenden Stoffes abhngt. + + + Reduktionspotential + Halbzellenpotential fr einen Reduktionsprozess. + + + Salzbrcke + Rohr, das mit einer Salzlsung gefllt ist und die zwei Halbzellen einer galvanischen Zelle verbindet. + + + Silbercoulombmeter + Elektrolysezelle, in der Silber abgeschieden wird; aus der abgeschiedenen Silbermenge kann die durchflossene Elektrizittsmenge berechnet werden. + + + Spannungsreihe + + Werden zwei Metalle in einen Behlter mit einer Sure getaucht, so luft eine chemische Reaktion ab, bei der Ionen vom einen Stoff zum anderen wandern und zum Schluss eine ungleichgewichtige Verteilung von freien Elektronen an den beiden Stoffen angelagert ist (Redoxreaktion). Aus der unterschiedlichen Verteilung der Elektronen ergibt sich stets ein bestimmtes Ma der elektrischen Spannung. Metalle, die dabei gegenber dem Wasserstoff in der Sure eine positive Spannung haben, werden edle, die mit einer negativen Spannung als unedle Metalle bezeichnet. Die Auflistung in der Reihenfolge der einzelnen Element-Spannungen ergibt die elektrochemische Spannungsreihe. + + Nernst-Gleichung,Reduktion,Oxidation,Spannung + + + Spannung + + Die Elektrische Spannung ist eine physikalische Gre, die angibt, wie viel Arbeit ntig ist bzw. frei wird, wenn ein Objekt mit einer bestimmten Ladung entlang eines elektrischen Feldes bewegt wird. Die Einheit ist Volt (V). + + Spannungsreihe + + + berspannung + Zustzliche Spannung, die ber das theoretische Zellenpotential hinaus angelegt werden muss, um eine Elektrolysereaktion in Gang zu bringen. + Spannung + + + Substitution + Reaktion, bei der ein Substituent durch einen anderen Substituent ersetzt wird. + Nucleophile Substitution + + diff --git a/kalzium/src/data/toolpics/Makefile.am b/kalzium/src/data/toolpics/Makefile.am new file mode 100644 index 00000000..a47cff52 --- /dev/null +++ b/kalzium/src/data/toolpics/Makefile.am @@ -0,0 +1,42 @@ +xml_DATA = abzug.jpg \ + becherglas.jpg \ + brechungsmesser.jpg \ + brenner.jpg \ + destillierbruecke.jpg \ + dsc.jpg \ + erlenmeyerkolben.jpg \ + exikator.jpg \ + halter.jpg \ + heizplatte.jpg \ + hplc.jpg \ + kolbenprober.png \ + korkring.jpg \ + messzylinder.jpg \ + moerser.jpg \ + phpapier.jpg \ + pileusball.jpg \ + pipette.jpg \ + rg-halter.jpg \ + rg.jpg \ + rg-staender.jpg \ + rotationsverdampfer.jpg \ + rueckflusskuehler.jpg \ + ruehrfisch.jpg \ + rundkolben.jpg \ + scheidetrichter.jpg \ + schutzbrille.jpg \ + spatel.jpg \ + spritzflasche.jpg \ + thermometer2.jpg \ + thermometer.jpg \ + tonschale.jpg \ + trichter.jpg \ + trockenrohr.jpg \ + tropftrichter.jpg \ + uhrglas.jpg \ + verteiler.jpg \ + vollpipette.jpg \ + waage.jpg \ + wasserstrahlpumpe.jpg + +xmldir = $(kde_datadir)/kalzium/data/toolpics diff --git a/kalzium/src/data/toolpics/abzug.jpg b/kalzium/src/data/toolpics/abzug.jpg new file mode 100644 index 00000000..36c81b2c Binary files /dev/null and b/kalzium/src/data/toolpics/abzug.jpg differ diff --git a/kalzium/src/data/toolpics/becherglas.jpg b/kalzium/src/data/toolpics/becherglas.jpg new file mode 100644 index 00000000..10b5d6f3 Binary files /dev/null and b/kalzium/src/data/toolpics/becherglas.jpg differ diff --git a/kalzium/src/data/toolpics/brechungsmesser.jpg b/kalzium/src/data/toolpics/brechungsmesser.jpg new file mode 100644 index 00000000..d7cb3c08 Binary files /dev/null and b/kalzium/src/data/toolpics/brechungsmesser.jpg differ diff --git a/kalzium/src/data/toolpics/brenner.jpg b/kalzium/src/data/toolpics/brenner.jpg new file mode 100644 index 00000000..44cd5f1a Binary files /dev/null and b/kalzium/src/data/toolpics/brenner.jpg differ diff --git a/kalzium/src/data/toolpics/destillierbruecke.jpg b/kalzium/src/data/toolpics/destillierbruecke.jpg new file mode 100644 index 00000000..83cc45db Binary files /dev/null and b/kalzium/src/data/toolpics/destillierbruecke.jpg differ diff --git a/kalzium/src/data/toolpics/dsc.jpg b/kalzium/src/data/toolpics/dsc.jpg new file mode 100644 index 00000000..f69c96e8 Binary files /dev/null and b/kalzium/src/data/toolpics/dsc.jpg differ diff --git a/kalzium/src/data/toolpics/erlenmeyerkolben.jpg b/kalzium/src/data/toolpics/erlenmeyerkolben.jpg new file mode 100644 index 00000000..eaf6fe44 Binary files /dev/null and b/kalzium/src/data/toolpics/erlenmeyerkolben.jpg differ diff --git a/kalzium/src/data/toolpics/exikator.jpg b/kalzium/src/data/toolpics/exikator.jpg new file mode 100644 index 00000000..f4bc8080 Binary files /dev/null and b/kalzium/src/data/toolpics/exikator.jpg differ diff --git a/kalzium/src/data/toolpics/halter.jpg b/kalzium/src/data/toolpics/halter.jpg new file mode 100644 index 00000000..564057c4 Binary files /dev/null and b/kalzium/src/data/toolpics/halter.jpg differ diff --git a/kalzium/src/data/toolpics/heizplatte.jpg b/kalzium/src/data/toolpics/heizplatte.jpg new file mode 100644 index 00000000..304de198 Binary files /dev/null and b/kalzium/src/data/toolpics/heizplatte.jpg differ diff --git a/kalzium/src/data/toolpics/hplc.jpg b/kalzium/src/data/toolpics/hplc.jpg new file mode 100644 index 00000000..aad79ca5 Binary files /dev/null and b/kalzium/src/data/toolpics/hplc.jpg differ diff --git a/kalzium/src/data/toolpics/kolbenprober.png b/kalzium/src/data/toolpics/kolbenprober.png new file mode 100644 index 00000000..1d17b95a Binary files /dev/null and b/kalzium/src/data/toolpics/kolbenprober.png differ diff --git a/kalzium/src/data/toolpics/korkring.jpg b/kalzium/src/data/toolpics/korkring.jpg new file mode 100644 index 00000000..0c668605 Binary files /dev/null and b/kalzium/src/data/toolpics/korkring.jpg differ diff --git a/kalzium/src/data/toolpics/messzylinder.jpg b/kalzium/src/data/toolpics/messzylinder.jpg new file mode 100644 index 00000000..4a6b79a7 Binary files /dev/null and b/kalzium/src/data/toolpics/messzylinder.jpg differ diff --git a/kalzium/src/data/toolpics/moerser.jpg b/kalzium/src/data/toolpics/moerser.jpg new file mode 100644 index 00000000..2020dc6d Binary files /dev/null and b/kalzium/src/data/toolpics/moerser.jpg differ diff --git a/kalzium/src/data/toolpics/phpapier.jpg b/kalzium/src/data/toolpics/phpapier.jpg new file mode 100644 index 00000000..3a5d0328 Binary files /dev/null and b/kalzium/src/data/toolpics/phpapier.jpg differ diff --git a/kalzium/src/data/toolpics/pileusball.jpg b/kalzium/src/data/toolpics/pileusball.jpg new file mode 100644 index 00000000..cea0871e Binary files /dev/null and b/kalzium/src/data/toolpics/pileusball.jpg differ diff --git a/kalzium/src/data/toolpics/pipette.jpg b/kalzium/src/data/toolpics/pipette.jpg new file mode 100644 index 00000000..e250da88 Binary files /dev/null and b/kalzium/src/data/toolpics/pipette.jpg differ diff --git a/kalzium/src/data/toolpics/rg-halter.jpg b/kalzium/src/data/toolpics/rg-halter.jpg new file mode 100644 index 00000000..99574f83 Binary files /dev/null and b/kalzium/src/data/toolpics/rg-halter.jpg differ diff --git a/kalzium/src/data/toolpics/rg-staender.jpg b/kalzium/src/data/toolpics/rg-staender.jpg new file mode 100644 index 00000000..d07476d0 Binary files /dev/null and b/kalzium/src/data/toolpics/rg-staender.jpg differ diff --git a/kalzium/src/data/toolpics/rg.jpg b/kalzium/src/data/toolpics/rg.jpg new file mode 100644 index 00000000..6e21d0b2 Binary files /dev/null and b/kalzium/src/data/toolpics/rg.jpg differ diff --git a/kalzium/src/data/toolpics/rotationsverdampfer.jpg b/kalzium/src/data/toolpics/rotationsverdampfer.jpg new file mode 100644 index 00000000..4e19bc62 Binary files /dev/null and b/kalzium/src/data/toolpics/rotationsverdampfer.jpg differ diff --git a/kalzium/src/data/toolpics/rueckflusskuehler.jpg b/kalzium/src/data/toolpics/rueckflusskuehler.jpg new file mode 100644 index 00000000..74852992 Binary files /dev/null and b/kalzium/src/data/toolpics/rueckflusskuehler.jpg differ diff --git a/kalzium/src/data/toolpics/ruehrfisch.jpg b/kalzium/src/data/toolpics/ruehrfisch.jpg new file mode 100644 index 00000000..3952fa42 Binary files /dev/null and b/kalzium/src/data/toolpics/ruehrfisch.jpg differ diff --git a/kalzium/src/data/toolpics/rundkolben.jpg b/kalzium/src/data/toolpics/rundkolben.jpg new file mode 100644 index 00000000..fce2ddf6 Binary files /dev/null and b/kalzium/src/data/toolpics/rundkolben.jpg differ diff --git a/kalzium/src/data/toolpics/scheidetrichter.jpg b/kalzium/src/data/toolpics/scheidetrichter.jpg new file mode 100644 index 00000000..c4f79a36 Binary files /dev/null and b/kalzium/src/data/toolpics/scheidetrichter.jpg differ diff --git a/kalzium/src/data/toolpics/schutzbrille.jpg b/kalzium/src/data/toolpics/schutzbrille.jpg new file mode 100644 index 00000000..6a9bd0dc Binary files /dev/null and b/kalzium/src/data/toolpics/schutzbrille.jpg differ diff --git a/kalzium/src/data/toolpics/spatel.jpg b/kalzium/src/data/toolpics/spatel.jpg new file mode 100644 index 00000000..ec9a6e50 Binary files /dev/null and b/kalzium/src/data/toolpics/spatel.jpg differ diff --git a/kalzium/src/data/toolpics/spritzflasche.jpg b/kalzium/src/data/toolpics/spritzflasche.jpg new file mode 100644 index 00000000..abeec492 Binary files /dev/null and b/kalzium/src/data/toolpics/spritzflasche.jpg differ diff --git a/kalzium/src/data/toolpics/thermometer.jpg b/kalzium/src/data/toolpics/thermometer.jpg new file mode 100644 index 00000000..b4c79210 Binary files /dev/null and b/kalzium/src/data/toolpics/thermometer.jpg differ diff --git a/kalzium/src/data/toolpics/thermometer2.jpg b/kalzium/src/data/toolpics/thermometer2.jpg new file mode 100644 index 00000000..375d94ea Binary files /dev/null and b/kalzium/src/data/toolpics/thermometer2.jpg differ diff --git a/kalzium/src/data/toolpics/tonschale.jpg b/kalzium/src/data/toolpics/tonschale.jpg new file mode 100644 index 00000000..8cabf844 Binary files /dev/null and b/kalzium/src/data/toolpics/tonschale.jpg differ diff --git a/kalzium/src/data/toolpics/trichter.jpg b/kalzium/src/data/toolpics/trichter.jpg new file mode 100644 index 00000000..3980f3d1 Binary files /dev/null and b/kalzium/src/data/toolpics/trichter.jpg differ diff --git a/kalzium/src/data/toolpics/trockenrohr.jpg b/kalzium/src/data/toolpics/trockenrohr.jpg new file mode 100644 index 00000000..1cc5d809 Binary files /dev/null and b/kalzium/src/data/toolpics/trockenrohr.jpg differ diff --git a/kalzium/src/data/toolpics/tropftrichter.jpg b/kalzium/src/data/toolpics/tropftrichter.jpg new file mode 100644 index 00000000..5f565559 Binary files /dev/null and b/kalzium/src/data/toolpics/tropftrichter.jpg differ diff --git a/kalzium/src/data/toolpics/uhrglas.jpg b/kalzium/src/data/toolpics/uhrglas.jpg new file mode 100644 index 00000000..50821e97 Binary files /dev/null and b/kalzium/src/data/toolpics/uhrglas.jpg differ diff --git a/kalzium/src/data/toolpics/verteiler.jpg b/kalzium/src/data/toolpics/verteiler.jpg new file mode 100644 index 00000000..25f48114 Binary files /dev/null and b/kalzium/src/data/toolpics/verteiler.jpg differ diff --git a/kalzium/src/data/toolpics/vollpipette.jpg b/kalzium/src/data/toolpics/vollpipette.jpg new file mode 100644 index 00000000..0cfefec6 Binary files /dev/null and b/kalzium/src/data/toolpics/vollpipette.jpg differ diff --git a/kalzium/src/data/toolpics/waage.jpg b/kalzium/src/data/toolpics/waage.jpg new file mode 100644 index 00000000..ef9b448d Binary files /dev/null and b/kalzium/src/data/toolpics/waage.jpg differ diff --git a/kalzium/src/data/toolpics/wasserstrahlpumpe.jpg b/kalzium/src/data/toolpics/wasserstrahlpumpe.jpg new file mode 100644 index 00000000..4e1caeaf Binary files /dev/null and b/kalzium/src/data/toolpics/wasserstrahlpumpe.jpg differ diff --git a/kalzium/src/data/tools.xml b/kalzium/src/data/tools.xml new file mode 100644 index 00000000..ccccb90e --- /dev/null +++ b/kalzium/src/data/tools.xml @@ -0,0 +1,227 @@ + + + + uhrglas.jpg + Watchglass + Watchglasses are round glass panes with a diameter of around 5 - 10 cm which are used in the various experimental techniques. The border is bent upwards to allow the watchglass to hold small amounts of liquids in order to let them evaporate. The evaporation can be accelerated by heating the watchglass with a Bunsen burner. Watchglasses can also be used to cover petri dishes or beakers. Moreover watchglasses are suited to weighing small amounts of matter or alternatively drying them in the airing cupboard. The term watchglass is derived from the former pocket watches' protection glass which was often domed. + + + exikator.jpg + Dehydrator + A dehydrator is a laboratory apparatus which is often made of glass and serves to dry chemical matters, that is, to remove water or liquid from a sample. + In principle it is a glass bowl with cap which has a planar grinding so that the bowl is air tight closeable. The dehydrator's lower part is ordinarily filled with a drying agent e.g. calcium chloride, silica gel, phosphoric anhydride or sulphuric acid. The sample to be dried is placed on a diaphanous cartridge of plastic or ceramics above the drying agent. + The drying agent is hygroscopic, which means that it dehumidifies its environment by absorbing water vapor. The dry atmosphere then takes up water from the sample to be dried. + + + spatel.jpg + Spatula + The spatula is a laboratory tool to scrape off, grind and transport chemicals. The material they are made of (e.g. iron, titanium, platinum) and their design (e.g. flat spatula or spoon spatula) can be different. + + + wasserstrahlpumpe.jpg + Water Jet Pump + The water jet pump has two entry pipes and one exit and consists in principle of two pipes one inside the other. At the water entry a water jet shoots under full pressure out of a nozzle into a slightly larger pipe. Thereby the water jet carries away air or fluid from the second entry. <br> this is caused by the negative pressure in a drifting fluid. Thus it is an application of the hydrodynamic paradox. This says that objects close to drifting fluids are aspirated instead of being pushed away. + + + brechungsmesser.jpg + Refractometer + With a refractometer the refractive index of optical media is determined. If the refractive index of a chemical is known it can be used after a synthesis to determine the sample's purity or to audit the synthesis' success. + + + moerser.jpg + Mortar + A mortar is used for manually grinding solids. It can also be used to homogenize a mixture of powders by grinding. A club-shaped tool known as a pestle is used with the mortar for grinding. + + + heizplatte.jpg + Heating Coil + Heating coils are used to heat flasks and other containers. Multiple heating coils can be connected with a thermometer so that the heat will not exceed a specified temperature. It is possible to use a magnetic field inside the heating coil to stir fluids with a magnetic stirrer. This will homogenize the fluid in terms of temperature and composition. + + + korkring.jpg + Cork Ring + Large containers like round-bottomed flasks are placed on rings made of cork, a special soft lightweight wood with good insulating qualities to protect fragile instruments. + + + tropftrichter.jpg + Dropping Funnel + A dropping funnel can be used to drop precise amounts of fluid. You can control the dropping speed with a valve. + + + scheidetrichter.jpg + Separating Funnel + A separating funnel can be used to separate a mixture of fluids by differing density. A valve at the bottom allows you to drain the more dense fluid for transfer to another container. + + + rg-staender.jpg + Test Tube Rack + This rack comes in handy when you want to test many small amounts of chemicals in a row, or if you want to dry test tubes. + + + + Vortexer + A vortexer serves to homogenize reagents found in laboratories. The container containing liquid to be homogenized is put on a platform. The platform shakes by rotary agitation up to 3000RPM at which point a contact sensor is activated. In this way extremely small volumes of fluid can be homogenized quickly as well. It is the opposite of a centrifuge, used to separate fluids. + + + spritzflasche.jpg + Wash Bottle + These bottles are used for many purposes. In most laboratories they are usually filled with water, salt, acid or other commonly used fluids. They make it easy to apply the fluid if you do not need to measure a precise amount. + + + rotationsverdampfer.jpg + Rotary Evaporator + A rotary evaporator consists of a round flask in a bath of hot water that is designed to evaporate solvents. The flask is rotated and the solvent collects under a vacuum onto a condenser and drips into a condensate collecting flask. in this way solutions can be concentrated or purified. By attaching a vacuum pump, the air pressure and therefore the boiling point of the fluid can be decreased. + + + rueckflusskuehler.jpg + Reflux Condenser + A reflux condenser subjects fluid to a process where a gas produced by heating is collected on the reflux condenser. The fluid is cooled until it condenses and runs back into the original fluid. Usually it is put on a round-bottomed flask or several neck flasks. + + + pileusball.jpg + Pipette Bulb + A pipette bulb is used to fill pipettes. It produces a negative pressure which makes the fluid go into the pipette. If one lets air back into the ball the fluid will run out of the pipette. + + + rg.jpg + Test Tube + In a test tube small reactions or experiements are performed. There are many different types of tubes. For example some have connectors, some are etched for measurements, some are hardened for durability. + + + schutzbrille.jpg + Protective Goggles + Most laboratories insist that everyone wears protective goggles. Without them, it is too risky to work with most chemicals. Usually, the lens is a special type of plastic which protects you from both mechanical impacts and acid and base chemicals. + + + rundkolben.jpg + Round-bottomed Flask + A round-bottomed flask is used for a lot of reactions. Some can be connected to other items, as the frosting on the neck shows. With cork rings they can be placed on a table. + + + vollpipette.jpg + Full Pipette + Unlike a regular pipette, a full pipette only has one marking for a specific volume. + + + trockenrohr.jpg + Drying Tube + There are reactions which need to be kept free of water. To make this possible one uses a drying tube, which contains a hygroscopic chemical to absorb water in the atmosphere. + + + rg-halter.jpg + Test tube fastener + With a test tube fastener you can easily hold test tubes. If you use a fastener there is a safe distance between the hand and the test tube when the tube is hot. In particular, it is used when you hold a test tube over an open flame. + + + messzylinder.jpg + Measuring Cylinder + In a measuring cylinder you can fill amounts of liquids relatively precisely. Furthermore, the cylinder allows particulate matter to sink. Following this, you can separate particulates from the fluid by decanting. + + + thermometer.jpg + Thermometer + With a thermometer you can determine the temperature of a sample. In a laboratory special thermometers are used, which can also be used within acids or bases. + + + ruehrfisch.jpg + Magnetic stir bar + Magnetic stir bars are highly chemically inert, small magnetic bars. Most heaters have a built-in magnet which can rotate. This causes the stir bar to rotate and the mixture to be homogenized. + + + + Magnetic Stir Bar Retriever + With a magnetic stir bar retriever you can remove magnetic stir bars from a container. The retriever is a bar with a magnet at the end which attracts the stir bars. + + + pipette.jpg + Pipette + Pipettes are used to introduce small quantities of liquids in laboratories. A pipette has a volume scale and as a rule pileusballs are used as droppers for liquids. Both sorts of pipettes are calibrated for fluids with a temperature of 20°C and for time of outflow (signified by "Ex."). If needed times of outflow are indicated on the pipettes. + + + erlenmeyerkolben.jpg + Erlenmeyer Flask + This flask named after the chemist Emil Erlenmeyer (1825-1909) comes - unlike the beaker - with an inverted conical base and a cylindrical neck. There are different types of Erlenmeyer flasks for laboratory applications, the narrow and wide neck form. Depending on the application the flask may have precision grinding to allow good connection to other containers. + <br> + The narrow neck reduces the risk of fluid escaping, especially when boiling or during reactions which agitate the contents. + <br> + An Erlenmeyer flask is useful for mixing fluids or accelerating reactions by stirring or shaking, for example. The Erlenmeyer flask is particularly suited for a magnetic stirrer, since it can be placed directly on the stirring platform. A round-bottomed flask, by contrast, must be placed on a cork ring on the stirring platform. + + + + + + Ultrasonic Bath + For some chemical reactions it is important that the solvent is gas free. To achieve this the reaction vessel is put for some time into a ultrasonic bath. Through the high sound frequency the vapor locks peel away and ascend. This procedure is called outgassing. + + + waage.jpg + Scales + In a laboratory you often have to weigh out very precise amounts of reagents. High precise scales can measure masses down to 1/10000 gram.Therefor they stand on granite blocks to avoid vibrancies and are protected against blasts by a dome. + + + destillierbruecke.jpg + Distillation bridge + To separate a mixture you can use distillation amongst others. The distillation bridge is thereby the way between the two pots. In the one pot there is the mixture to be separated. Through heating, a gas forms which is lead through the bridge. At the end of the bridge the gas phase is condensed again and drips in a round flask. As a rule, the bridge is cooled by return flow. In addition, there is often a thermometer for controlling the temperature on the distillation bridge. + + + + kolbenprober.png + Syringe + A syringe consists of two parts: A glass tube and a punch. Both are normally made of glass. A gas floats into the glass tube. As the syringe is a closed system the punch has to give way. This can be used measuring the volume of an reaction. + + + verteiler.jpg + Separation Beaker + At the four ends of this separation beaker you put four small caps. While distilling, you can turn the beaker by 60 degree after a certain temperate has been reached. This way, at the end of the distillation all four caps have a specific liquid in it, depending on the boiling points of the liquid distilled. + + + brenner.jpg + Burner + There are several types of burners. The picture shows a Teclu-Burner. Each type has specific uses. They vary in the peak temperature and overall heating capability. + + + abzug.jpg + Extractor Hood + Most laboratories use extractor hoods. They filter the gasses from chemical reactions and pump the cleaned air outside of the building. + + + thermometer2.jpg + Contact Thermometer + A contact thermometer is different from a regular thermometer because of its sensor for the current temperature. Such a thermometer is connected with a heating coild. If the sensor notices that the aimed temperature has been reached the contact thermometer will make the heating coild stop heating. Therefore in an experiment it is possible to have a constant temperature. + + + halter.jpg + Clamps + With clamps as used in a laboratory you can easily hold all kinds of tools. + + + phpapier.jpg + Litmus Paper + There are multiple way to measure the pH-Value of an solution. With a litmus paper it is easy to get a pretty precise pH-Value. The color indicates the value. If you need a more precise value you can for example use a pH-Meter which is using the conductivity of a solution. + + + trichter.jpg + Short-stem Funnel + A funnel is used in the laboratory to fill powder into something. + + + + Buret + A buret is used to titrate liquids. The buret is filled with a specified volume of a liquid. Below it a container like an Erlenmeyer flask is placed. By opening the valve the liquid in the container will be titrated. High-quality buret have a venting-mechanism with which they can be very easily refilled with the exact volume for which the buret is calibrated. + + + becherglas.jpg + Beaker + Beakers are used in many places for a lot of tasks. They are used to store chemicals are to perform chemical reactions. They are also often used for titrations. + + + dsc.jpg + DSC (Differencial Scanning Calorimetry) + The DSC measures the heat flow volume of a compound. This value is very specific for every kind of matter. Thus, the DSC is used to identify chemicals or to describe them. + + + + Dewar vessel + A dewar vessel (or dewar flask) is designed for a good thermal insulation. Its hull is a double-layer construction with vacuum between the two layers. Because of this they are appropriote for keeping liquids cold or warm. A thermos flawsk is an example of a dewar vessel. + + diff --git a/kalzium/src/data/tools.xml.todo b/kalzium/src/data/tools.xml.todo new file mode 100644 index 00000000..eb746de7 --- /dev/null +++ b/kalzium/src/data/tools.xml.todo @@ -0,0 +1,50 @@ +See: http://www.labdepotinc.com/default.aspx + + + Rhrfischangel + Mit der Rhrfischangel kann man Rhrfische wieder aus Gefen entfernen. Die Angel ist ein Stab mit einem Magneten am Ende an dem der Rhrfisch haften bleibt. + + + Exsikkator + + Ein Exsikkator (von lat. exsiccare = austrocknen) ist ein Laborgert aus der Chemie, das meist aus Glas gefertigt wird und zum Trocknen von chemischen Stoffen verwendet wird, das heit zum Entzug von Wasser bzw. Feuchtigkeit. + Bei einem Exsikkator handelt es sich im Prinzip um eine Glasschssel mit Deckel (siehe Bild unten), wobei der Deckel das Gef ber einen Planschliff verschliet, was gewhrleistet, da es luftdicht verschliebar ist. Den unteren Teil des Exsikkators befllt man gewhnlich mit einem Trocknungsmittel, z.B. Calciumchlorid, Silicagel, Phosphorpentoxid oder Schwefelsure. Auf einem durchlssigen Einsatz aus Kunststoff oder Keramik oberhalb des Trockenmittels wird die zu trocknende Substanz abgelegt. + Das Trocknungsmittel hat die Eigenschaft hygroskopisch zu sein, das heit, es entzieht aus seiner Umgebung Feuchtigkeit und nimmt diese auf. Die durch das Trocknungsmittel getrocknete Atmosphre im Exsikkator entzieht selbst wiederum Wasser bzw. Lsungsmittel aus dem zu trocknenden Stoff. + + + + Spatel + Der Spatel ist ein Laborgert zum Abkratzen, Zerkleinern und Transportieren von Chemikalien. Spatel bestehen aus verschiedenen Materialien (Eisen, Titan, Platin) und knnen verschiedene Formen haben (z.B. Flachspatel oder Lffelspatel). + + + Wasserstrahlpumpe + + Die Wasserstrahlpumpe besitzt zwei Eingnge und einen Ausgang und besteht im Prinzip aus zwei ineinander gesteckten Rohren. Am Wassereingang spritzt ein Wasserstrahl unter dem vollen Leitungsdruck aus einer Dse in ein etwas weiteres Rohr. Dabei reit der Wasserstrahl Luft oder Flssigkeiten vom zweiten Eingang mit. <br> Dies geschieht aufgrund des Unterdrucks in einer strmenden Flssigkeit. Es ist somit eine Anwendung des Hydrodynamischen Paradoxon. Dies besagt, dass Gegenstnde, die in der Nhe von strmenden Flssigkeiten sind, angesaugt statt abgestoen werden. + + + + Refraktometer + Mit einem Refraktometer wird der Brechungsindex von optischen Medien bestimmt. Wenn von einer Chemikalie der Brechungsindex bekannt ist kann somit nach einer Synthese die Reinheit des Produktes oder der Erfolg einer Synthese berprft werden. + + + Pipette + Pipetten dienen im Labor zum Dosieren von Flssigkeiten. Auf der Pipette findet sich eine Volumenskala. Als Pipettierhilfe dient in der Regel ein Pileusball. Beide Pipettenarten sind auf Flssigkeiten mit der Temperatur von 20C und auf Ausfluss (Ex.) geeicht, Auslaufzeiten werden, wenn ntig, auf den Pipetten angegeben. + + + Erlenmeyerkolben + + Dieser nach dem Chemiker Emil Erlenmeyer (1825-1909) benannte Kolben verfgt - im Gegensatz zum Becherglas - ber einen nach oben hin enger werdenden Hals. Im Laborgebrauch existieren verschiedene Varianten des Erlenmeyerkolbens, die Enghals- und die Weithals-Form und je nach Anwendung auch Kolben mit Normschliff. + <br> + Durch den verjngenden Hals ist die Gefahr, dass bei Zugabe von Substanzen, beim Schwenken, Rhren oder Sieden Flssigkeiten aus dem Kolben unkontrolliert entweichen deutlich kleiner, als bei Becherglsern. + <br> + So knnen im Erlenmeyerkolben bequem z.B. Flssigkeiten vermischt oder Lsungsvorgnge durch - auch relativ heftiges - Schwenken oder Rhren beschleunigt werden. Er eignet sich - wie der Rundkolben - auch gut fr den Magnetrhrer, kann aber wegen seines flachen Bodens direkt abgestellt werden. (Der Rundkolben hingegen bentigt einen Korkring oder ein Stativ fr den festen Stand, letzteres macht ein Schwenken mit der Hand oder ein hufiges Prfen durch Halten ins Gegenlicht unmglich.) + + + + Ultraschallbad + Bei einigen chemischen Reaktionen kommt es darauf an, dass die Lsungsmittel gasfrei sind. Um dies zu erreichen wird das Reaktionsgef fr einige Zeit in ein Ultraschallbad gegeben. Durch die hohe Schallfrequenz lsen sich Gasblasen und steigen auf. Diesen Vorgang nennt man Entgasen. + + + Waage + Im Labor muss man hufig sehr genaue Mengen von Reagenzien abwiegen. Feinwaagen messen bis auf eine 1/10000 Gramm genaue Mengen ab. Dazu stehen sie auf Granitblcken um Erschtterungen zu vermeiden und sind durch Hauben von Windsten geschtzt. + diff --git a/kalzium/src/detailedgraphicaloverview.cpp b/kalzium/src/detailedgraphicaloverview.cpp new file mode 100644 index 00000000..56c086ff --- /dev/null +++ b/kalzium/src/detailedgraphicaloverview.cpp @@ -0,0 +1,232 @@ +/*************************************************************************** + +copyright : (C) 2004, 2005 by Carsten Niehaus +email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ +#include "detailedgraphicaloverview.h" +#include "element.h" +#include "kalziumutils.h" + +//KDE-Includes +#include +#include +#include +#include + +//QT-Includes +#include +#include +#include +#include + +DetailedGraphicalOverview::DetailedGraphicalOverview( Element *el, QWidget *parent, const char *name ) +: QWidget( parent, name ) +{ + init( el ); +} + +DetailedGraphicalOverview::DetailedGraphicalOverview( QWidget *parent, const char *name ) +: QWidget( parent, name ) +{ + init( 0L ); +} + +void DetailedGraphicalOverview::init( Element *el ) +{ + setBackgroundMode( NoBackground ); + + m_element = el; + setMinimumSize( 300, 200 ); + update(); +} + +void DetailedGraphicalOverview::paintEvent( QPaintEvent* ) +{ + int h = height(); + int w = width(); + + QPixmap pm( w, h ); + + QPainter p; + p.begin( &pm ); + + p.setBrush(Qt::SolidPattern); + + if ( !m_element ) + { + pm.fill( paletteBackgroundColor() ); + p.drawText( 0, 0, w, h, Qt::AlignCenter | Qt::WordBreak, i18n( "No element selected" ) ); + } + else + { + + h_t = 20; //height of the texts + + x1 = 0; + y1 = 0; + + x2 = w; + y2 = h; + + p.setBrush( m_element->elementColor() ); + p.drawRect( x1 , y1 , x2 , y2 ); + + p.setBrush( Qt::black ); + p.setBrush(Qt::NoBrush); + + QFont fA = KGlobalSettings::generalFont(); + QFont fB = KGlobalSettings::generalFont(); + QFont fC = KGlobalSettings::generalFont(); + + QString strLocalizedMass = KalziumUtils::localizedValue( m_element->mass(), 6 ); + + fA.setPointSize( fA.pointSize() + 20 ); //Huge font + fA.setBold( true ); + fB.setPointSize( fB.pointSize() + 6 ); //Big font + fC.setPointSize( fC.pointSize() + 4 ); //Big font + fC.setBold( true ); + QFontMetrics fmA = QFontMetrics( fA ); + QFontMetrics fmB = QFontMetrics( fB ); + + //coordinates for element symbol: near the center + int xA = 4 * w / 10; + int yA = h / 2; + + //coordinates for the atomic number: offset from element symbol to the upper left + int xB = xA - fmB.width( QString::number( m_element->number() ) ); + int yB = yA - fmA.height() + fmB.height(); + + //Element Symbol + p.setFont( fA ); + p.drawText( xA, yA , m_element->symbol() ); + + //Atomic number + p.setFont( fB ); + p.drawText( xB, yB, QString::number( m_element->number() )); + + QRect rect( 0, 20, w/2, h ); + + p.setFont( fC ); + + int size = KalziumUtils::maxSize(m_element->elname(), rect , fC, &p); + int size2 = KalziumUtils::maxSize(m_element->oxstage(), rect, fC, &p); + int size3 = KalziumUtils::maxSize( strLocalizedMass , rect , fC, &p); + + //Name and other data + fC.setPointSize( size ); + p.setFont( fC ); + + //Name + p.drawText( 1, 0, w/2, h, Qt::AlignLeft, m_element->elname() ); + + //Oxidationstates + fC.setPointSize( size2 ); + p.setFont( fC ); + int offsetOx = KalziumUtils::StringHeight( strLocalizedMass , fC, &p ); + p.drawText( 1, h-offsetOx, w/2, offsetOx, Qt::AlignLeft, m_element->oxstage() ); + + //Mass + fC.setPointSize( size3 ); + p.setFont( fC ); + + int offset = KalziumUtils::StringHeight( strLocalizedMass, fC, &p ); + p.drawText( w/2, h-offset, w/2, offset, Qt::AlignRight, strLocalizedMass ); + + drawBiologicalSymbol( &p ); + } + + p.end(); + + + bitBlt( this, 0, 0, &pm ); +} + +void DetailedGraphicalOverview::drawBiologicalSymbol( QPainter *p ) +{ + if ( !m_element ) return; + const int db = h_t; //diameter of the big circle + const int ds = db/2; //diameter of the inner circle + + int d_ds = ( db/2 )-( ds/2 ); //the delta-x/y of the inner circle + + int pos_x = width() - 4 - db; + int pos_y = 4; + + if ( m_element->biological() > 0 ) + { + const int radius = db + 8; + p->setBrush( Qt::SolidPattern ); + p->setBrush( Qt::white ); + p->setPen( Qt::black ); + p->drawRoundRect( QRect( width() - radius, + -radius, + 2 * radius, + 2 * radius ), 70, 70 ); + } + + switch ( m_element->biological() ) + { + case 0: //nothing + break; + case 1: //red, red + p->setBrush( Qt::red ); + p->setBrush(Qt::NoBrush); + p->setPen( Qt::red ); + p->drawEllipse( pos_x,pos_y,db,db ); + p->setBrush(Qt::SolidPattern); + p->setBrush( Qt::red ); + p->drawEllipse( pos_x+d_ds, pos_y+d_ds, ds, ds ); + break; + case 2: //green, red + p->setBrush( Qt::red ); + p->setBrush(Qt::NoBrush); + p->setPen( Qt::red ); + p->drawEllipse( pos_x,pos_y,db,db ); + p->setBrush(Qt::SolidPattern); + p->setBrush( Qt::green ); + p->setPen( Qt::green ); + p->drawEllipse( pos_x+d_ds, pos_y+d_ds, ds, ds ); + break; + case 3: //green + p->setBrush(Qt::SolidPattern); + p->setBrush( Qt::green ); + p->setPen( Qt::green ); + p->drawEllipse( pos_x+d_ds, pos_y+d_ds, ds, ds ); + break; + case 4: //green, blue + p->setBrush( Qt::blue ); + p->setBrush(Qt::NoBrush); + p->setPen( Qt::blue ); + p->drawEllipse( pos_x,pos_y,db,db ); + p->setBrush(Qt::SolidPattern); + p->setBrush( Qt::green ); + p->setPen( Qt::green ); + p->drawEllipse( pos_x+d_ds, pos_y+d_ds, ds, ds ); + break; + case 5: //blue + p->setBrush(Qt::SolidPattern); + p->setBrush( Qt::blue ); + p->setPen( Qt::blue ); + p->drawEllipse( pos_x+d_ds, pos_y+d_ds, ds, ds ); + break; + case 6: //blue, blue + p->setBrush( Qt::blue ); + p->setBrush(Qt::NoBrush); + p->setPen( Qt::blue ); + p->drawEllipse( pos_x,pos_y,db,db ); + p->setBrush(Qt::SolidPattern); + p->drawEllipse( pos_x+d_ds, pos_y+d_ds, ds, ds ); + break; + } +} + +#include "detailedgraphicaloverview.moc" diff --git a/kalzium/src/detailedgraphicaloverview.h b/kalzium/src/detailedgraphicaloverview.h new file mode 100644 index 00000000..2f095be7 --- /dev/null +++ b/kalzium/src/detailedgraphicaloverview.h @@ -0,0 +1,69 @@ +#ifndef DETAILEDGRAPHICALOVERVIEW_H +#define DETAILEDGRAPHICALOVERVIEW_H +/*************************************************************************** + copyright : (C) 2004 by Carsten Niehaus + email : cniehaus@kde.org + + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include + +class Element; + + +/** + * @short The widget which displays the most important information + * in one widget like a lot people know it from school + * @author Carsten Niehaus + */ +class DetailedGraphicalOverview : public QWidget +{ + Q_OBJECT + + public: + DetailedGraphicalOverview( Element *el, QWidget *parent, const char *name=0 ); + DetailedGraphicalOverview( QWidget *parent, const char *name=0 ); + + /** + * sets the elements whose data will be used to @p el + */ + void setElement( Element* el ){ + m_element = el; + update(); + } + + /** + * draw the small symbol which symbolises the + * relevence for humans + */ + void drawBiologicalSymbol( QPainter *p ); + + //calculation of the corners + int x1,x2,y1,y2,h_t; + + private: + /** + * the element whose data will be used + */ + Element *m_element; + + protected: + virtual void paintEvent( QPaintEvent* ); + + /** + * initialization method + */ + virtual void init( Element* ); +}; + +#endif // DETAILEDGRAPHICALOVERVIEW_H + diff --git a/kalzium/src/detailinfodlg.cpp b/kalzium/src/detailinfodlg.cpp new file mode 100644 index 00000000..c099ccd8 --- /dev/null +++ b/kalzium/src/detailinfodlg.cpp @@ -0,0 +1,497 @@ +/*************************************************************************** + begin : Tue Apr 8 2003 + copyright : (C) 2003, 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "detailinfodlg.h" +#include "isotope.h" +#include "kalziumutils.h" +#include "kalziumdataobject.h" + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include + +#include "element.h" +#include "orbitswidget.h" +#include "detailedgraphicaloverview.h" +#include "spectrum.h" +#include "spectrumviewimpl.h" + +//TODO add bondxx-radius (H-H-distance for example) + +DetailedInfoDlg::DetailedInfoDlg( Element *el , QWidget *parent, const char *name) + : KDialogBase( IconList, name, Help|User1|User2|Close, Close, parent, name, + false, //non modal + false, + KGuiItem(i18n("Next element", "Next"), "1rightarrow"), + KGuiItem(i18n("Previous element", "Previous"), "1leftarrow")) +{ + m_element = el; + + m_baseHtml = KGlobal::dirs()->findResourceDir("data", "kalzium/data/" ); + m_baseHtml.append("kalzium/data/htmlview/"); + m_baseHtml.append("style.css"); + + m_picsdir = KGlobal::dirs()->findResourceDir( "appdata", "elempics/" ) + "elempics/"; + + ( actionButton( KDialogBase::Close ) )->setFocus(); + + // creating the tabs but not the contents, as that will be done when + // setting the element + createContent(); + + m_actionCollection = new KActionCollection(this); + KStdAction::quit(this, SLOT(slotClose()), m_actionCollection); + + setButtonTip( User2, i18n( "Goes to the previous element" ) ); + setButtonTip( User1, i18n( "Goes to the next element" ) ); + + setElement( el ); +} + +void DetailedInfoDlg::setElement(Element *element) +{ + if ( !element ) return; + + m_element = element; + m_elementNumber = element->number(); + + reloadContent(); + + enableButton( User1, true ); + enableButton( User2, true ); + if ( m_elementNumber == 1 ) + enableButton( User2, false ); + else if ( m_elementNumber == KalziumDataObject::instance()->numberOfElements() ) + enableButton( User1, false ); +} + +KHTMLPart* DetailedInfoDlg::addHTMLTab( const QString& title, const QString& icontext, const QString& iconname ) +{ + QFrame *frame = addPage(title, icontext, BarIcon(iconname)); + QVBoxLayout *layout = new QVBoxLayout( frame ); + layout->setMargin( 0 ); + KHTMLPart *w = new KHTMLPart( frame, "html-part", frame ); + layout->addWidget( w->view() ); + + return w; +} + +void DetailedInfoDlg::fillHTMLTab( KHTMLPart* htmlpart, const QString& htmlcode ) +{ + if ( !htmlpart ) return; + + htmlpart->begin(); + htmlpart->write( htmlcode ); + htmlpart->end(); +} + +QString DetailedInfoDlg::getHtml(DATATYPE type) +{ + QString html = "Chemical data
"; + + //get the list of ionisation-energies + QValueList ionlist = m_element->ionisationList(); + + html.append( "
" ); + html.append( m_element->symbol() ); + html.append( "" ); + html.append( i18n( "Block: %1" ).arg( m_element->block() ) ); + html.append( "
" ); + html.append( ""); + switch ( type ) + { + case CHEMICAL: + html.append( "" ); + html.append( "" ); + html.append( "" ); + if ( m_element->radius(Element::IONIC) > 0.0 ) + { + html.append( "" ); + } + if ( m_element->radius(Element::VDW) > 0.0 ) + { + html.append( "" ); + } + + if ( m_element->radius(Element::ATOMIC) > 0.0 ) + { + html.append( "" ); + } + + html.append( "" ); + if ( !m_element->isotopes().isEmpty() ) + { + html.append( "" ); + } + break; + case MISC: + html.append( "" ); + + if ( m_element->abundance() > 0 ){ + html.append( "" ); + } + + html.append( "" ); + if ( !m_element->nameOrigin().isEmpty() ) + { + html.append( "" ); + } + if ( m_element->artificial() || m_element->radioactive() ) + { + html.append( "" ); + } + break; + case ENERGY: + html.append( "" ); + html.append( "" ); + html.append( "" ); + html.append( "" ); + + + uint i = 0; + for ( ; i < ionlist.count() ; ++i ) + { + html.append( "" ); + } + break; + } + + html += ( "
\"icon\"/" ); + html.append( "" + i18n( "Electronic configuration: %1" ).arg( m_element->parsedOrbits() ) + "" ); + html.append( "
\"icon\"/" ); + html.append( "" + i18n( "Density: %1" ).arg( m_element->adjustUnits( Element::DENSITY ) ) + "" ); + html.append( "
\"icon\"/" ); + html.append( "" + i18n( "Covalent Radius: %1" ).arg( m_element->adjustRadius( Element::COVALENT ) ) + "" ); + html.append( "
\"icon\"/" ); + html.append( i18n( "Ionic Radius (Charge): %1 (%2)" ).arg( m_element->adjustRadius(Element::IONIC) ).arg( m_element->ioncharge() ) ); + html.append( "
\"icon\"/" ); + html.append( "" + i18n( "van der Waals Radius: %1" ).arg( m_element->adjustRadius(Element::VDW) ) + "" ); + html.append( "
\"icon\"/" ); + html.append( "" + i18n( "Atomic Radius: %1" ).arg( m_element->adjustRadius(Element::ATOMIC) ) + "" ); + html.append( "
\"icon\"/" ); + html.append( "" + i18n( "Mass: %1" ).arg( m_element->adjustUnits( Element::MASS ) ) + "" ); + html.append( "
\"icon\"/" ); + html.append( isotopeTable() ); + html.append( "
\"icon\"/" ); + html.append( m_element->adjustUnits( Element::DATE ) ); + if ( !m_element->scientist( ).isEmpty() ) + html += "
" + i18n("It was discovered by %1").arg(m_element->scientist() ); + html.append( "
\"icon\"/" ); + html.append( i18n( "Abundance in crustal rocks: %1 ppm" ).arg( KGlobal::locale()->formatLong( m_element->abundance() ) ) ); + html.append( "
\"icon\"/" ); + html.append( i18n( "Mean mass: %1 u" ).arg( KalziumUtils::localizedValue( m_element->meanmass(), 6 ) ) ); + html.append( "
\"icon\"/" ); + html.append( i18n( "Origin of the name: %1" ).arg( m_element->nameOrigin() ) ); + html.append( "
\"icon\"/" ); + if ( !m_element->radioactive() ) + html.append( i18n( "This element is artificial" )); + else if ( !m_element->artificial() ) + html.append( i18n( "This element is radioactive" )); + else + html.append( i18n( "This element is radioactive and artificial" )); + html.append( "
\"icon\"/" ); + html.append( i18n( "Melting Point: %1" ).arg( m_element->adjustUnits( Element::MELTINGPOINT ) ) ); + html.append( "
\"icon\"/" ); + html.append( i18n( "Boiling Point: %1" ).arg( m_element->adjustUnits( Element::BOILINGPOINT ) ) ); + html.append( "
\"icon\"/" ); + html.append( i18n( "Electronegativity: %1" ).arg( m_element->adjustUnits( Element::EN ) ) ); + html.append( "
\"icon\"/" ); + html.append( i18n( "Electron affinity: %1 " ).arg( m_element->adjustUnits(Element::EA) ) ); + html.append( "
\"icon\"/" ); + html.append( i18n("the first variable is a number. The result is for example '1.' or '5.', the second is the value of the ionisation energy", + "%1. Ionization energy: %2" ).arg( QString::number( i+1 ), m_element->adjustUnits( Element::IE, ionlist[i] ) ) ); + html.append( "
" ); + html += "
"; + + return html; +} + +QString DetailedInfoDlg::isotopeTable() +{ + QValueList list = m_element->isotopes(); + + QString html; + + html = ""; + + QValueList::const_iterator it = list.begin(); + const QValueList::const_iterator itEnd = list.end(); + + for ( ; it != itEnd; ++it ) + { + html.append( "" ); + + } + + html += "
"; + html += i18n( "Isotope-Table" ); + html += "
"; + html += i18n( "Mass" ); + html += ""; + html += i18n( "Neutrons" ); + html += ""; + html += i18n( "Percentage" ); + html += ""; + html += i18n( "Half-life period" ); + html += ""; + html += i18n( "Energy and Mode of Decay" ); + html += ""; + html += i18n( "Spin and Parity" ); + html += ""; + html += i18n( "Magnetic Moment" ); + html += "
" ); + if ( ( *it )->weight() > 0.0 ) + html.append( i18n( "%1 u" ).arg( KalziumUtils::localizedValue( ( *it )->weight(), 6 ) ) ); + // html.append( i18n( "%1 u" ).arg( QString::number( ( *it )->weight() ) )); + html.append( "" ); + html.append( QString::number( ( *it )->neutrons() ) ); + html.append( "" ); + if ( ( *it )->percentage() > 0.0 ) + html.append( i18n( "this can for example be '24%'", "%1%" ).arg( KalziumUtils::localizedValue( ( *it )->percentage(), 6 ) ) ); + html.append( "" ); + if ( ( *it )->halflife() > 0.0 ) { + html.append( ( *it )->halflifeAsString() ); + } + html.append( "" ); + if ( ( *it )->alphapercentage() > 0.0 ){ + if ( ( *it )->alphadecay() > 0.0 ) + html.append( i18n( "%1 MeV" ).arg( KalziumUtils::localizedValue( ( *it )->alphadecay(), 6 ) ) ); + html.append( i18n( " %1" ).arg( QChar( 945 ) ) ); + if ( ( *it )->alphapercentage() < 100.0) + html.append( i18n( "(%1%)" ).arg( KalziumUtils::localizedValue( (*it )->alphapercentage(), 6 ) ) ); + if ( ( *it )->betaminuspercentage() > 0.0 || ( *it )->betapluspercentage() > 0.0 || ( *it )->ecpercentage() > 0.0) + html.append( i18n( ", " ) ); + } + if ( ( *it )->betaminuspercentage() > 0.0 ){ + if ( ( *it )->betaminusdecay() > 0.0 ) + html.append( i18n( "%1 MeV" ).arg( KalziumUtils::localizedValue( ( *it )->betaminusdecay(), 6 ) ) ); + html.append( i18n( " %1-" ).arg( QChar( 946 ) ) ); + if ( ( *it )->betaminuspercentage() < 100.0) + html.append( i18n( "(%1%)" ).arg( KalziumUtils::localizedValue( ( *it )->betaminuspercentage(), 6 ) )); + if ( ( *it )->betapluspercentage() > 0.0 || ( *it )->ecpercentage() > 0.0 ) + html.append( i18n( ", " ) ); + } + if ( ( *it )->betapluspercentage() > 0.0 ){ + if ( ( *it )->betaplusdecay() > 0.0 ) + html.append( i18n( "%1 MeV" ).arg( KalziumUtils::localizedValue( ( *it )->betaplusdecay(), 6 ) ) ); + html.append( i18n( " %1+" ).arg(QChar( 946 ) ) ); + if ( ( *it )->betapluspercentage() == ( *it )->ecpercentage() ) { + if ( ( *it )->ecdecay() > 0.0 ) { + html.append( i18n( "%1 MeV" ).arg( KalziumUtils::localizedValue( ( *it )->ecdecay(), 6 ) ) ); + } + html.append( i18n( "Acronym of Electron Capture"," EC" ) ); + } + if ( ( *it )->betapluspercentage() < 100.0) + html.append( i18n( "(%1%)" ).arg( KalziumUtils::localizedValue( ( *it )->betapluspercentage(), 6 ) ) ); + html += " "; + } + if ( ( *it )->ecpercentage() > 0.0 && ( *it )->ecpercentage()!=( *it )->betapluspercentage()){ + if ( ( *it )->ecdecay() > 0.0 ) + html.append( i18n( "%1 MeV" ).arg( KalziumUtils::localizedValue( ( *it )->ecdecay(), 6 ) ) ); + html.append( i18n( "Acronym of Electron Capture"," EC" ) ); + if ( ( *it )->ecpercentage() < 100.0 ) + html.append( i18n( "(%1%)" ).arg( KalziumUtils::localizedValue( ( *it )->ecpercentage(), 6 ) ) ); + } + html.append( "" ); + html.append( ( *it )->spin() ); + html.append( "" ); + if ( !( *it )->magmoment().isEmpty() ) { + QString v = KGlobal::locale()->formatNumber( ( *it )->magmoment(), false, 6 ); + html.append( i18n( "%1 %2n" ).arg( v ).arg( QChar( 956 ) ) ); + } + html.append( "
"; + + return html; +} + +void DetailedInfoDlg::createContent( ) +{ + // overview tab + QFrame *m_pOverviewTab = addPage( i18n( "Overview" ), i18n( "Overview" ), BarIcon( "overview" ) ); + QVBoxLayout *overviewLayout = new QVBoxLayout( m_pOverviewTab ); + overviewLayout->setMargin( 0 ); + dTab = new DetailedGraphicalOverview( m_pOverviewTab, "DetailedGraphicalOverview" ); + overviewLayout->addWidget( dTab ); + + // picture tab + QFrame *m_pPictureTab = addPage( i18n( "Picture" ), i18n( "What does this element look like?" ), BarIcon( "elempic" ) ); + QVBoxLayout *mainLayout = new QVBoxLayout( m_pPictureTab ); + mainLayout->setMargin( 0 ); + piclabel = new QLabel( m_pPictureTab ); + piclabel->setMinimumSize( 400, 350 ); + mainLayout->addWidget( piclabel ); + + // atomic model tab + QFrame *m_pModelTab = addPage( i18n( "Atom Model" ), i18n( "Atom Model" ), BarIcon( "orbits" ) ); + QVBoxLayout *modelLayout = new QVBoxLayout( m_pModelTab ); + modelLayout->setMargin( 0 ); + wOrbits = new OrbitsWidget( m_pModelTab ); + modelLayout->addWidget( wOrbits ); + + // html tabs + m_htmlpages["chemical"] = addHTMLTab( i18n( "Chemical Data" ), i18n( "Chemical Data" ), "chemical" ); + m_htmlpages["energies"] = addHTMLTab( i18n( "Energies" ), i18n( "Energy Information" ), "energies" ); + m_htmlpages["misc"] = addHTMLTab( i18n( "Miscellaneous" ), i18n( "Miscellaneous" ), "misc" ); + + // spectrum widget tab + QFrame *m_pSpectrumTab = addPage( i18n("Spectrum"), i18n( "Spectrum" ), BarIcon( "spectrum" )); + QVBoxLayout *spectrumLayout = new QVBoxLayout( m_pSpectrumTab , 0, KDialog::spacingHint() ); + spectrumLayout->setMargin( 0 ); + m_spectrumStack = new QWidgetStack( m_pSpectrumTab ); + spectrumLayout->addWidget( m_spectrumStack ); + m_spectrumview = new SpectrumViewImpl( m_spectrumStack, "spectrumwidget" ); + m_spectrumStack->addWidget( m_spectrumview ); + m_spectrumLabel = new QLabel( m_spectrumStack ); + m_spectrumStack->addWidget( m_spectrumLabel ); +} + +void DetailedInfoDlg::reloadContent() +{ + // reading the most common data + const QString element_name = m_element->elname(); + const QString element_symbol = m_element->symbol(); + + // updating caption + setCaption( i18n( "For example Carbon (6)" , "%1 (%2)" ).arg( element_name ).arg( m_elementNumber ) ); + + // updating overview tab + dTab->setElement( m_element ); + + // updating picture tab + QString picpath = m_picsdir + element_symbol + ".jpg"; + if ( QFile::exists( picpath ) ) + { + QImage img( picpath, "JPEG" ); + img = img.smoothScale ( 400, 400, QImage::ScaleMin ); + QPixmap pic; + pic.convertFromImage( img ); + piclabel->setPixmap( pic ); + } + else + piclabel->setText( i18n( "No picture of %1 found." ).arg( element_name ) ); + + // updating atomic model tab + wOrbits->setElementNumber( m_elementNumber ); + QWhatsThis::add( wOrbits, + i18n( "Here you can see the atomic hull of %1. %2 has the configuration %3." ) + .arg( m_element->elname() ) + .arg( m_element->elname() ) + .arg( m_element->parsedOrbits() ) ); + + // updating html tabs + fillHTMLTab( m_htmlpages["chemical"], getHtml( CHEMICAL ) ); + fillHTMLTab( m_htmlpages["energies"], getHtml( ENERGY ) ); + fillHTMLTab( m_htmlpages["misc"], getHtml( MISC ) ); + + // updating spectrum widget + if ( m_element->hasSpectrum() ) + { + delete m_spectrumview; + + m_spectrumview = new SpectrumViewImpl( m_spectrumStack, "spectrumwidget" ); + m_spectrumview->setSpectrum( m_element->spectrum() ); + m_spectrumStack->addWidget( m_spectrumview ); + m_spectrumStack->raiseWidget( m_spectrumview ); + } + else + { + m_spectrumLabel->setText( i18n( "No spectrum of %1 found." ).arg( element_name ) ); + m_spectrumStack->raiseWidget( m_spectrumLabel ); + } +} + +void DetailedInfoDlg::slotHelp() +{ + emit helpClicked(); + + QString chapter = "infodialog_overview"; + switch ( activePageIndex() ){ + case 0: + chapter = "infodialog_overview"; + break; + case 1: + chapter = "infodialog_picture"; + break; + case 2: + chapter = "infodialog_orbits"; + break; + case 3: + chapter = "infodialog_chemical"; + break; + case 4: + chapter = "infodialog_energies"; + break; + case 5: + chapter = "infodialog_misc"; + break; + case 6: + chapter = "infodialog_spectrum"; + break; + } + + if ( kapp ) + kapp->invokeHelp ( chapter, "kalzium" ); +} + +void DetailedInfoDlg::wheelEvent( QWheelEvent *ev ) +{ + if ( ev->delta() < 0 ) + // setting the previous element + slotUser2(); + else + // setting the next element + slotUser1(); +} + +void DetailedInfoDlg::slotUser1() +{ +// setting the next element + if ( m_elementNumber < KalziumDataObject::instance()->numberOfElements() ) + { + setElement( KalziumDataObject::instance()->element( m_elementNumber + 1 ) ); + // no need to increment m_elementNumber here too, + // as it's already done by setElement + emit elementChanged( m_elementNumber ); + } +} + +void DetailedInfoDlg::slotUser2() +{ +// setting the previous element + if ( m_elementNumber > 1 ) + { + setElement( KalziumDataObject::instance()->element( m_elementNumber - 1 ) ); + // no need to decrement m_elementNumber here too, + // as it's already done by setElement + emit elementChanged( m_elementNumber ); + } +} + +#include "detailinfodlg.moc" diff --git a/kalzium/src/detailinfodlg.h b/kalzium/src/detailinfodlg.h new file mode 100644 index 00000000..d5dacc29 --- /dev/null +++ b/kalzium/src/detailinfodlg.h @@ -0,0 +1,122 @@ +/*************************************************************************** + begin : Tue Apr 2 20:43:44 2002 UTC + copyright : (C) 2003, 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#ifndef _DETAILINFODLG_H_ +#define _DETAILINFODLG_H_ + +#include + +#include + +class DetailedGraphicalOverview; +class Element; +class OrbitsWidget; +class SpectrumViewImpl; + +class QMouseEvent; +class QFrame; +class QLabel; +class QVBoxLayout; +class KActionCollection; +class KHTMLPart; + +/** + * @short The dialog which shows all available information of an element + * @author Carsten Niehaus + */ +class DetailedInfoDlg : public KDialogBase +{ + Q_OBJECT + + public: + DetailedInfoDlg( Element *el , QWidget *parent=0, const char *name=0); + + void setElement(Element *el); + + private: + enum DATATYPE + { + CHEMICAL = 0, + MISC, + ENERGY + }; + + Element *m_element; + int m_elementNumber; + + KActionCollection* m_actionCollection; + + SpectrumViewImpl *m_spectrumview; + + QString isotopeTable(); + + QMap m_htmlpages; + + QLabel *piclabel; + + QWidgetStack* m_spectrumStack; + QLabel* m_spectrumLabel; + + DetailedGraphicalOverview *dTab; + + OrbitsWidget *wOrbits; + + /** + * Create the inital set of tabs. Used it *ONLY* once in the + * constructor. + */ + void createContent(); + void reloadContent(); + + QString getHtml(DATATYPE); + + QString m_baseHtml; + QString m_picsdir; + + /** + * Add a new HTML page to the dialog. + * + * @param title The title of the tab, appears above the htmlview + * @param icontext The name of the tab, appears belov or instead + * of the icon + * @param iconname The name of the icon + * @returns the pointer to the resulting KHTMLPart, needed for + * writing HTML code on it + */ + KHTMLPart* addHTMLTab( const QString& title, const QString& icontext, const QString& iconname ); + /** + * Change the HTML code in an HTML page. + * + * @param htmlpart the KHTMLPart to edit + * @param htmlcode the HTML code to display + */ + void fillHTMLTab( KHTMLPart* htmlpart, const QString& htmlcode ); + + protected slots: + virtual void slotUser1(); + virtual void slotUser2(); + /** + * invoke the help of the correct chapter + */ + virtual void slotHelp(); + + protected: + virtual void wheelEvent ( QWheelEvent * ev ); + + signals: + void elementChanged( int ); +}; + +#endif diff --git a/kalzium/src/element.cpp b/kalzium/src/element.cpp new file mode 100644 index 00000000..a909a5ac --- /dev/null +++ b/kalzium/src/element.cpp @@ -0,0 +1,548 @@ +/*************************************************************************** + * Copyright (C) 2003, 2004, 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "element.h" +#include "prefs.h" +#include "spectrum.h" +#include "isotope.h" +#include "kalziumdataobject.h" +#include "kalziumutils.h" +#include "tempunit.h" + +#include +#include +#include +#include +#include + +#include +#include +#include +#include + +Element::Element() +{ + m_radioactive = false; + m_artificial = false; + m_abundance = 0; +} + +Isotope* Element::isotopeByNucleons( int numberOfNucleons ) +{ + QValueList::ConstIterator it = m_isotopeList.begin(); + const QValueList::ConstIterator itEnd = m_isotopeList.end(); + + for ( ; it != itEnd; ++it ) + { + if ( ( ( *it )->neutrons() + ( *it )->protones() ) == numberOfNucleons ) + return *it; + } + return 0; +} + +QString Element::parsedOrbits( bool canBeEmpty ) +{ + if ( m_orbits.isEmpty() ) + if ( !canBeEmpty ) + return i18n( "structure means orbital configuration in this case", "Unknown structure" ); + else + return ""; + + QString orbits = m_orbits; + QRegExp rxs("([a-z])([0-9]+)"); + QRegExp rxb("([a-z]{2}) ",false); + orbits.replace(rxs,"\\1\\2"); //superscript around electron number + orbits.replace(rxb,"\\1 "); //bold around element symbols + return orbits; +} + +Element::~Element() +{ +} + +double Element::meanmass() +{ + return m_mass/m_number; +} + +const QString Element::adjustRadius( RADIUSTYPE rtype ) +{ + double val = 0.0; + QString v; + + switch ( rtype ) + { + case ATOMIC: + val = m_RadiusAR; + break; + case IONIC: + val = m_RadiusIon; + break; + case COVALENT: + val = m_RadiusCR; + break; + case VDW: + val = m_RadiusVDW; + break; + } + + if ( val <= 0 ) + v = i18n( "Value unknown" ); + else + v = i18n( "%1 is a length, eg: 12.3 pm", "%1 pm" ).arg( KalziumUtils::localizedValue( val, 6 ) ); + return v; +} + +const QString Element::adjustUnits( const int type, double value ) +{ + QString v; + if ( type == IE ) //an ionization energy + { + if ( Prefs::energies() == 0 ) + { + value*=96.6; + v = KalziumUtils::localizedValue( value, 6 ); + v.append( " kJ/mol" ); + } + else // use electronvolt + { + v = KalziumUtils::localizedValue( value, 6 ); + v.append( " eV" ); + } + } + return v; +} + +const QString Element::adjustUnits( const int type ) +{ + QString v = QString::null; + + double val = 0.0; //the value to convert + + if ( type == BOILINGPOINT || type == MELTINGPOINT ) // convert a temperature + { + if ( type == BOILINGPOINT ) + val = boiling(); + else + val = melting(); + + if ( val <= 0 ) + v = i18n( "Value unknown" ); + else + { + double newvalue = TempUnit::convert( val, (int)TempUnit::Kelvin, Prefs::temperature() ); + QString strVal = KalziumUtils::localizedValue( newvalue, 6 ); + switch (Prefs::temperature()) { + case 0: //Kelvin + v = i18n( "%1 is the temperature in Kelvin", "%1 K" ).arg( strVal ); + break; + case 1://Kelvin to Celsius + v = i18n( "%1 is the temperature in Celsius", "%1 %2C" ).arg( strVal ).arg( QChar(0xB0) ); + break; + case 2: // Kelvin to Fahrenheit + v = i18n( "%1 is the temperature in Fahrenheit", "%1 %2F" ).arg( strVal ).arg( QChar(0xB0) ); + break; + case 3: // Kelvin to Rankine + v = i18n( "%1 is the temperature in Rankine", "%1 %2Ra" ).arg( strVal ).arg( QChar(0xB0) ); + break; + case 4: // Kelvin to Reaumur + v = i18n( "%1 is the temperature in Reaumur", "%1 %2R" ).arg( strVal ).arg( QChar(0xB0) ); + break; + } + } + } + else if ( type == EN ) //Electronegativity + { + val = electroneg(); + if ( val <= 0 ) + v = i18n( "Value not defined" ); + else { + v = KalziumUtils::localizedValue( val, 6 ); + } + } + else if ( type == EA ) //Electron affinity + { + val = electroaf(); + if ( val == 0.0 ) + v = i18n( "Value not defined" ); + else + { + if ( Prefs::energies() == 0 ) + { + v = i18n( "%1 kJ/mol" ).arg( KalziumUtils::localizedValue( val, 6 ) ); + } + else // use electronvolt + { + val/=96.6; + v = i18n( "%1 eV" ).arg( KalziumUtils::localizedValue( val, 6 ) ); + } + } + } + else if ( type == MASS ) // its a mass + { + val = mass(); + if ( val <= 0 ) + v = i18n( "Value unknown" ); + else + v = i18n( "%1 u" ).arg( KalziumUtils::localizedValue( val, 6 ) ); + } + else if ( type == DENSITY ) // its a density + { + val = density(); + + if ( val <= 0 ) + v = i18n( "Value unknown" ); + else + { + if ( boiling() < 295.0 && melting() < 295.0)//gasoline + { + v = i18n( "%1 g/L" ).arg( KalziumUtils::localizedValue( val, 6 ) ); + } + else//liquid or solid + { + v = i18n( "%1 g/cm3" ).arg( KalziumUtils::localizedValue( val, 6 )); + } + } + } + else if ( type == DATE ) //its a date + { + val = date(); + if ( val < 1600 ) + { + v = i18n( "This element was known to ancient cultures" ); + } + else + { + v = i18n( "This element was discovered in the year %1" ).arg( QString::number( val ) ); + } + } + + return v; +} + +void Element::drawStateOfMatter( QPainter* p, double temp ) +{ + //the height of a "line" inside an element + int h_small = 15; //the size for the small units like elementnumber + + //The X-coordiante + int X = xPos(); + + //The Y-coordinate + int Y = yPos(); + + QColor color = currentColor( temp ); + + p->setPen( color ); + p->fillRect( X, Y,ELEMENTSIZE,ELEMENTSIZE, color ); + + QString text; + QFont symbol_font = p->font(); + + symbol_font.setPointSize( 10 ); + QFont f = p->font(); + f.setPointSize( 9 ); + + p->setFont( f ); + + //top left + p->setPen( Qt::black ); + text = KalziumUtils::localizedValue( KalziumUtils::strippedValue( mass( ) ), 6 ); + p->drawText( X,Y ,ELEMENTSIZE,h_small,Qt::AlignCenter, text ); + + text = QString::number( number() ); + p->drawText( X,Y+ELEMENTSIZE-h_small , ELEMENTSIZE, h_small,Qt::AlignCenter, text ); + + p->setFont( symbol_font ); + p->drawText( X,Y, ELEMENTSIZE,ELEMENTSIZE,Qt::AlignCenter, symbol() ); + + //border + p->setPen( Qt::black ); + p->drawRect( X, Y,ELEMENTSIZE+1,ELEMENTSIZE+1); +} + +QColor Element::currentColor( const double temp ) +{ + QColor color; + + //take the colours for the given temperature + const double iButton_melting = melting(); + const double iButton_boiling = boiling(); + + //If either the mp or bp is not known return + //This is to avoid undefined behaviour +// if ( iButton_boiling <= 0.0 || iButton_melting <= 0.0 ) +// return Qt::lightGray; + + if ( temp < iButton_melting ) + { //the element is solid + color= Prefs::color_solid(); + } + else if ( temp > iButton_melting && + temp < iButton_boiling ) + { //the element is liquid + color= Prefs::color_liquid(); + } + else if ( temp > iButton_boiling && iButton_boiling > 0.0 ) + { //the element is vaporous + color= Prefs::color_vapor(); + } + else + color = Qt::lightGray; + + return color; +} + + +void Element::drawGradient( QPainter* p, const QString& value, const QColor& c) +{ + //Set the elementColor to c to make the overviewwidget show + //the correct color + setElementColor( c ); + + //the height of a "line" inside an element + int h_small = 10; //the size for the small units like elementnumber + + //The X-coordiante + int X = xPos(); + + //The Y-coordinate + int Y = yPos(); + + p->setPen( c ); + p->fillRect( X, Y,ELEMENTSIZE,ELEMENTSIZE, c ); + + p->setPen( Qt::black ); + QFont symbol_font = p->font(); + QFont f = p->font(); + + f.setPointSize( KalziumUtils::maxSize(value, QRect( X,Y+ELEMENTSIZE-h_small, ELEMENTSIZE, h_small ),f, p ) ); + p->setFont( f ); + + p->drawText( X,Y+ELEMENTSIZE-h_small , ELEMENTSIZE, h_small,Qt::AlignCenter, value ); + + const QRect rect = QRect( X,Y,ELEMENTSIZE-2,ELEMENTSIZE-10 ); + int goodsize = KalziumUtils::maxSize( symbol(), rect, symbol_font, p ); + symbol_font.setPointSize( goodsize ); + p->setFont( symbol_font ); + p->drawText( X+1,Y+5, ELEMENTSIZE-2,ELEMENTSIZE-10,Qt::AlignCenter, symbol() ); + + //border + p->setPen( Qt::black ); + p->drawRect( X, Y,ELEMENTSIZE+1,ELEMENTSIZE+1); +} + +void Element::drawGrayedOut( QPainter *p ) +{ + //The X-coordiante + int X = xPos(); + + //The Y-coordinate + int Y = yPos(); + + p->fillRect( X, Y,ELEMENTSIZE,ELEMENTSIZE, Qt::lightGray ); + + p->setPen( Qt::darkGray ); + + QFont symbol_font = p->font(); + const QRect rect = QRect( X,Y,ELEMENTSIZE-2,ELEMENTSIZE-10 ); + int goodsize = KalziumUtils::maxSize( symbol(), rect, symbol_font, p ); + symbol_font.setPointSize( goodsize ); + p->setFont( symbol_font ); + p->drawText( X+1,Y+5, ELEMENTSIZE-2,ELEMENTSIZE-10,Qt::AlignCenter, symbol() ); + + p->setPen( Qt::black ); + p->drawRect( X, Y,ELEMENTSIZE+1,ELEMENTSIZE+1); +} + +void Element::drawSelf( QPainter* p, bool simple, bool isCrystal ) +{ + //the height of a "line" inside an element + int h_small = 12; //the size for the small units like elementnumber + + //The X-coordiante + int X = xPos(); + + //The Y-coordinate + int Y = yPos(); + + p->setPen( elementColor() ); + p->fillRect( X, Y,ELEMENTSIZE,ELEMENTSIZE, elementColor() ); + p->setPen( Qt::black ); + + QString text; + QFont symbol_font = p->font(); + + const int max = ELEMENTSIZE-10; + + const QRect rect = QRect( X,Y,ELEMENTSIZE-2,max ); + + int goodsize = KalziumUtils::maxSize( symbol(), rect, symbol_font, p ); + symbol_font.setPointSize( goodsize ); + p->setFont( symbol_font ); + + if ( !simple ) + p->drawText( X+1,Y+5, ELEMENTSIZE-2,max,Qt::AlignCenter, symbol() ); + else + p->drawText( X+1,Y+5, ELEMENTSIZE-2,max,Qt::AlignHCenter, symbol() ); + + QFont f = p->font(); + + QRect smallRect( X,Y ,ELEMENTSIZE-4,h_small ); + f.setPointSize( KalziumUtils::maxSize( QString::number( number() ), smallRect, f, p ) ); + + p->setFont( f ); + + if ( !simple ) + {//the user only wants a simple periodic table, don't weight the cell + QString text; + if ( isCrystal ) + { + QString structure = crystalstructure(); + /** + * hcp: hexagonal close packed + * fcc: face centered cubic + * krz/bcc body centered cubic// kubisch raumzentriert + * kdp: kubisch dicht gepackt + * hdp: hexagonal dicht gepackt + * ccp: cubic close packed // kubisch dichteste Kugelpackung + * d : diamond + * sc : simple cubic + * tet: tetragonal + * rh : rhombohedral + * or : orthorhombic + * mono: monoclinic + */ + if ( structure == "own") + text = i18n( "this means, the element has its 'own' structur", "own" ); + else if ( structure == "bcc" ) + text = i18n( "Crystalsystem body centered cubic", "bcc" ); + else if ( structure == "hdp" ) + text = i18n( "Crystalsystem hexagonal dense packed", "hdp" ); + else if ( structure == "ccp" ) + text = i18n( "Crystalsystem cubic close packed", "ccp" ); + } + else + text = KalziumUtils::localizedValue( KalziumUtils::strippedValue( mass( ) ), 6 ); + p->drawText( X+2,Y ,ELEMENTSIZE-4 ,h_small,Qt::AlignCenter, text ); + } + + text = QString::number( number() ); + p->drawText( X+2,Y+ELEMENTSIZE-h_small , ELEMENTSIZE-4, h_small,Qt::AlignCenter, text ); + + p->drawRect( X, Y,ELEMENTSIZE+1,ELEMENTSIZE+1); +} + +/*! + This looks pretty evil and it is. The problem is that a PerodicTableView is pretty + irregular and you cannot "calculate" the position. + */ +void Element::setupXY() +{ + static const int posXRegular[111] = {1,18, + 1,2,13,14,15,16,17,18, + 1,2,13,14,15,16,17,18, + 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18, + 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18, //Element 54 (Xe) + 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17, //Element 71 (Lu) + 4,5,6,7,8,9,10,11,12,13,14,15,16,17,18, + 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17, //Element 71 (Lr) + 4,5,6,7,8,9,10,11}; + static const int posYRegular[111] = {1,1, + 2,2, 2, 2, 2, 2, 2, 2, + 3,3, 3, 3, 3, 3, 3, 3, + 4,4,4,4,4,4,4,4,4, 4, 4, 4, 4, 4, 4, 4, 4, 4, + 5,5,5,5,5,5,5,5,5, 5, 5, 5, 5, 5, 5, 5, 5, 5, //Element 54 (Xe) + 6,6,6,8,8,8,8,8,8, 8, 8, 8, 8, 8, 8, 8, 8, //Element 71 (Lr) + 6,6,6,6,6,6, 6, 6, 6, 6, 6, 6, 6, 6, 6, + 7,7,7,9,9,9,9,9,9, 9, 9, 9, 9, 9, 9, 9, 9, + 7,7,7,7,7,7,7,7}; + + x = posXRegular[m_number-1]; + y = posYRegular[m_number-1]; +} + +void Element::setRadius( RADIUSTYPE type, double value, const QString& name ) +{ + switch ( type ) + { + case ATOMIC: + m_RadiusAR = value; + break; + case IONIC: + m_RadiusIon = value; + m_ionvalue = name; + break; + case COVALENT: + m_RadiusCR = value; + break; + case VDW: + m_RadiusVDW = value; + break; + } +} + +double Element::radius( RADIUSTYPE type ) +{ + switch ( type ) + { + case ATOMIC: + return m_RadiusAR; + break; + case IONIC: + return m_RadiusIon; + break; + case COVALENT: + return m_RadiusCR; + break; + case VDW: + return m_RadiusVDW; + break; + } + return 0.0; +} + +int Element::xPos() const +{ + return ( x-1 )*ELEMENTSIZE; +} + +int Element::yPos() const +{ + // mind the small gap over rare earth! + int tmp_y = ( y-1 )*ELEMENTSIZE + ELEMENTSIZE; + + // 57=Lanthanum, 72=Hafnium, 89=Actinium & 104=Rutherfordium (i.e., if + // n_number is in rare earth's block) + if ( (m_number > 57 && m_number < 72) || (m_number > 89 && m_number < 104) ) + tmp_y += ELEMENTSIZE/3; + + return tmp_y; +} + +QPoint Element::pos() const +{ + return QPoint( xPos(), yPos() ); +} + +QPoint Element::coords() const +{ + return QPoint( x, y ); +} diff --git a/kalzium/src/element.h b/kalzium/src/element.h new file mode 100644 index 00000000..c3d2b091 --- /dev/null +++ b/kalzium/src/element.h @@ -0,0 +1,515 @@ +/*************************************************************************** + * Copyright (C) 2003, 2004, 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ +#ifndef ELEMENT_H +#define ELEMENT_H + +#define ELEMENTSIZE 40 + +#include +#include + +class Element; +class QDomDocument; +class QPainter; +class QPoint; +class QFont; +class QRect; +class Spectrum; +class Isotope; + +struct coordinate; + +typedef QValueList EList; +typedef QValueList CList; +typedef QValueList doubleList; + +struct coordinate{ + int x; + int y; +}; + +/** + * In this class all information about an element are stored. This means that + * both the chemical date and the data about the position are stored + * in this class. + * @short This class is the represention of a chemical element + * @author Carsten Niehaus +*/ +class Element{ + public: + Element(); + + virtual ~Element(); + + /** + * @returns a pointer to the istope with @p numberOfNucleons + * nucleons + */ + Isotope* isotopeByNucleons( int numberOfNucleons ); + + enum RADIUSTYPE + { + ATOMIC = 0, + IONIC, + VDW, //van der Waals radius + COVALENT + }; + + /** + * @return the number of the element + */ + int number() const { + return m_number; + } + + /** + * @return if the Element is radioactive + */ + bool radioactive() const{ + return m_radioactive; + } + + /** + * @return if the Element is artificial + */ + bool artificial() const{ + return m_artificial; + } + + /** + * @return the information where the name of the Element comes from + */ + QString nameOrigin() const{ + return m_origin; + } + + QString orbits() const{ + return m_orbits; + } + + void setMass( double value ) { m_mass = value; } + void setEN( double value ) { m_EN = value; } + void setEA( double value ) { m_EA = value; } + void setMeltingpoint( double value ) { m_MP = value; } + void setBoilingpoint( double value ) { m_BP = value; } + + /** + * sets the density of the Element + * @param value the density of the Element + */ + void setDensity( double value ) { m_Density = value; } + + /** + * set the radius of the radiustype @p type to the value @p value. + * The ionicradius also has a name @p name. This will store the charge of + * the ion (for example, +2 or -3 ) + */ + void setRadius( RADIUSTYPE type, double value, const QString& name = 0 ); + + void setDate( int date ) { m_date = date; } + void setPeriod( int period ){ m_period = period; } + void setBiologicalMeaning( int value ) { m_biological = value; } + void setNumber( int num ){ m_number = num; } + + /** + * set the abundance in crustal rocks [pm] + * @param abundance the abundace in crustal rocks + */ + void setAbundance( int abundance ){ m_abundance = abundance; } + + void setScientist( const QString& value ) { m_scientist = value; } + void setCrysatalstructure( const QString& value ) { m_crystalstructure = value; } + void setName( const QString& value ) { m_name = value; } + void setOrigin( const QString& value ) { m_origin = value; } + void setBlock( const QString& value ) { m_block = value; } + void setGroup( const QString& value ) { m_group = value; } + void setFamily( const QString& value ) { m_family = value; } + void setOrbits( const QString& value ) { m_orbits = value; } + void setSymbol( const QString& value ) { m_symbol = value; } + void setOxydation( const QString& value ) { m_oxstage = value; } + void setAcidicbehaviour( const QString& value ) { m_acidbeh = value; } + void setIsotopes( const QString& value ) { m_isotopes = value; } + + void setArtificial(){ m_artificial = true; } + void setRadioactive(){ m_radioactive = true; } + + void setIonisationList( doubleList l ){ m_ionenergies = l; } + + QValueList isotopes() const{ + return m_isotopeList; + } + + QValueList spectrumList() const{ + return m_spectrumList; + } + + void setIsotopeList( QValueList list ){ + m_isotopeList = list; + } + + /** + * sets the Spectrum of the Element + * @param spec the Spectrum of the Element + */ + void setSpectrum( Spectrum *spec ){ + m_spectrum = spec; + } + + /** + * @return if the element has information about spectra + */ + bool hasSpectrum() const{ + return m_hasSpectrum; + } + + /** + * define if the element has a known Spectrum + * @param value if true, the Element has a Spectrum + */ + void setHasSepctrum(bool value){ + m_hasSpectrum = value; + } + + /** + * @return the Spectrum of the element + */ + Spectrum* spectrum() const{ + return m_spectrum; + } + + doubleList ionisationList() const{ + return m_ionenergies; + } + + /** + * @return the date of discovery of the element + */ + int date() const { + return m_date; + } + + /** + * return the correct color of the element at the + * temperature @p temp + */ + QColor currentColor( const double temp ); + + /** + * mutator for the element's color + */ + void setElementColor( const QColor &c ) { m_Color = c; } + + /** + * @return the importance of the element for biological + * systems. + * @li 0: blah + * @li 1: blub + * @li 2: blub + * @li 3: blub + * @li 4: blub + * @li 5: blub + * @li 6: blub + */ + int biological() const { + return m_biological; + } + + /** + * @return the abundance in crustal rocks in parts per million + */ + int abundance() const { + return m_abundance; + } + + /** + * @return the symbol of the element + */ + QString symbol() const { + return m_symbol; + } + + /** + * @return the scientist who discovered the element + */ + QString scientist() const{ + return m_scientist; + } + + /** + * @return the crystal structure of the element + */ + QString crystalstructure() const{ + return m_crystalstructure; + } + + /** + * @return the name of the element + */ + QString elname() const { + return m_name; + } + + //FIXME I need to add a way to have more than one ionic radius + QString ioncharge() const{ + return m_ionvalue; + } + + /** + * @return the chemical block (s, p, d, f) of the element + */ + QString block() const { + return m_block; + } + + /** + * @return the group of the element + */ + QString group() const { + return m_group; + } + + int period() const { + return m_period; + } + + QString family() const { + return m_family; + } + + /** + * @return the acidic behavior of the element + */ + QString acidicbeh() const { + return m_acidbeh; + } + + /** + * @return the oxydationstages of the element + */ + QString oxstage() const { + return m_oxstage; + } + + /** + * @return the orbits of the element. The QString is already + * parsed so that the numbers are superscripts and the first + * block is bold. + * @param canBeEmpty specifies if the string returned can be + * empty instead of a "Unknown structure" one. + */ + QString parsedOrbits( bool canBeEmpty = false ); + + /** + * @return the boiling point of the element in Kelvin + */ + double boiling() const { + return m_BP; + } + + /** + * @return the melting point of the element in Kelvin + */ + double melting() const { + return m_MP; + } + + /** + * @return the electronegativity of the element in the + * Pauling-scale + */ + double electroneg() const { + return m_EN; + } + + /** + * @return the electroaffinity of the element + */ + double electroaf() const { + return m_EA; + } + + /** + * @return the atomic mass of the element in units + */ + double mass() const { + return m_mass; + } + + /** + * @return the density of the element in gramms per mol + */ + double density() const { + return m_Density; + } + + /** + * @return the radius of the element in picometers + */ + double radius( RADIUSTYPE type ); + + /** + * @return the mean mass of the element + */ + double meanmass(); + + int x, y; //for the RegularPerodicTableView + + /** + * adjusts the units for the data. The user can + * for example define if Fahrenheit, Kelvin or + * Degrees Celsius should be used for the temperature. + * This method takes care of that and adjust the + * values. + * @param type the TYPE of the data + * @return the adjusted datastring + */ + const QString adjustUnits( const int type ); + + const QString adjustRadius( RADIUSTYPE rtype ); + + /** + * adjusts the units for the data. The user can + * for example define if Fahrenheit, Kelvin or + * Degrees Celsius should be used for the temperature. + * This method takes care of that and adjust the + * values. Depending on @p type a unit will be + * added to the adjusted value. + * @param type the TYPE of the data + * @param value the value of the data. + * @return the adjusted datastring + */ + const QString adjustUnits( const int type, double value ); + + /** + * types of datas + */ + enum TYPE + { + NOGRADIENT = 0, + ATOMICRADIUS, + COVALENTRADIUS, + VDWRADIUS, + MASS, + DENSITY, + BOILINGPOINT, + MELTINGPOINT, + EN, + EA, + DATE, + IE, + IONICRADIUS + }; + + QPoint pos() const; + QPoint coords() const; + + /** + * accessor for the element's color + */ + QColor elementColor() const { + return m_Color; + } + + void setupXY(); + + private: + /** + * the integer num represents the number of the element + */ + int m_ElementNumber; + + Spectrum *m_spectrum; + + bool m_hasSpectrum; + + QValueList m_isotopeList; + + QValueList m_spectrumList; + + QColor m_Color; + + int xPos() const; + int yPos() const; + + double m_mass, + m_MP, + m_BP, + m_EN, + m_EA, + m_Density, + m_RadiusAR, + m_RadiusCR, + m_RadiusVDW, + m_RadiusIon; + + + int m_number, + m_date, + m_biological, + m_period, + m_abundance; + + QString m_symbol, + m_name, + m_origin, + m_oxstage, + m_block, + m_group, + m_family, + m_acidbeh, + m_orbits, + m_isotopes, + m_scientist, + m_crystalstructure, + m_ionvalue; + + bool m_artificial, + m_radioactive; + + doubleList m_ionenergies; + + public: + /** + * draw the rectangle with the information + * @param p painter to do the drawing on + * @param value the value to display as text + * @param c the color used to paint the element + */ + virtual void drawGradient( QPainter* p, const QString& value, const QColor& c); + + /** + * Draw the Element grayed out. Used in the timeline + * @param p the painter used for the painting + */ + virtual void drawGrayedOut( QPainter* p ); + + /** + * draw the rectangle with the information + * @param p painter to do the drawing on + * @param simple if True more information will be shown + * @param isCrystal whether the elements should draw its crystal structure + */ + virtual void drawSelf( QPainter* p, bool simple = false, bool isCrystal = false ); + + virtual void drawStateOfMatter( QPainter* p, double temperature ); +}; + + +#endif diff --git a/kalzium/src/elementdataviewer.cpp b/kalzium/src/elementdataviewer.cpp new file mode 100644 index 00000000..6fe8a3e3 --- /dev/null +++ b/kalzium/src/elementdataviewer.cpp @@ -0,0 +1,352 @@ +/*************************************************************************** + copyright : (C) 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "elementdataviewer.h" +#include "element.h" +#include "plotsetupwidget.h" +#include "plotwidget.h" +#include "kalziumdataobject.h" + +#include +#include +#include +#include +#include +#include + +//QT-Includes +#include +#include +#include + +ElementDataViewer::ElementDataViewer( QWidget *parent, const char* name ) + : KDialogBase( KDialogBase::Plain, + i18n( "Plot Data") , + Help | User1 | Close, + User1, + parent, name ) +{ + d = KalziumDataObject::instance(); + + yData = new AxisData(); + + QHBoxLayout *layout = new QHBoxLayout(plainPage(), 0, KDialog::spacingHint() ); + + m_pPlotSetupWidget = new PlotSetupWidget( plainPage(), "plotsetup" ); + m_pPlotSetupWidget->from->setMaxValue( d->numberOfElements() - 1 ); + m_pPlotSetupWidget->to->setMaxValue( d->numberOfElements() ); + m_pPlotWidget = new PlotWidget( 0.0, 12.0 ,0.0 ,22.0, plainPage(), "plotwidget" ); + m_pPlotWidget->setYAxisLabel(" "); + m_pPlotWidget->setMinimumWidth( 200 ); + m_pPlotWidget->resize( 400, m_pPlotWidget->height() ); + + layout->addWidget( m_pPlotSetupWidget ); + layout->addWidget( m_pPlotWidget ); + layout->setStretchFactor( m_pPlotSetupWidget, 0 ); + layout->setStretchFactor( m_pPlotWidget, 1 ); + + // setup the list of names + EList::iterator it = d->ElementList.begin(); + const EList::iterator itEnd = d->ElementList.end(); + for( ; it != itEnd ; ++it ) + { + names.append( (*it)->elname() ); + } + + resize(500, 500); + + setButtonText( User1, i18n("&Plot") ); + + m_actionCollection = new KActionCollection(this); + KStdAction::quit(this, SLOT(slotClose()), m_actionCollection); + + connect ( m_pPlotSetupWidget->KCB_y, SIGNAL( activated(int) ), + this, SLOT( drawPlot()) ); + + connect ( m_pPlotSetupWidget->connectPoints, SIGNAL( toggled(bool) ), + this, SLOT( drawPlot()) ); + connect ( m_pPlotSetupWidget->showNames, SIGNAL( toggled(bool) ), + this, SLOT( drawPlot()) ); + + // Draw the plot so that the user doesn't have to press the "Plot" + // button to seee anything. + drawPlot(); +} + +void ElementDataViewer::slotHelp() +{ + emit helpClicked(); + if ( kapp ) + kapp->invokeHelp ( "plot_data", "kalzium" ); +} + +// Reimplement slotUser1 from KDialogBase + +void ElementDataViewer::slotUser1() +{ + kdDebug() << "slotUser1" << endl; + + drawPlot(); +} + + +void ElementDataViewer::setLimits(int f, int t) +{ + kdDebug() << "setLimits()" << endl; + + double minY = yData->value(f); + double maxY = yData->value(f); + + for ( int _currentVal = f; _currentVal <= t; _currentVal++ ) + { + double v = yData->value( _currentVal ); + + if( minY > v ) + minY = v; + if( maxY < v) + maxY = v; + } + + // try to put a small padding to make the points on the axis visible + double dx = ( t - f + 1 ) / 25 + 1.0; + double dy = ( maxY - minY ) / 10.0; + // in case that dy is quite small (for example, when plotting a single + // point) + if ( dy < 1e-7 ) + dy = maxY / 10.0; + m_pPlotWidget->setLimits( f - dx, t + dx, minY - dy, maxY + dy ); +} + +void ElementDataViewer::paintEvent(QPaintEvent*) +{ + m_pPlotWidget->update(); +} + +void ElementDataViewer::keyPressEvent(QKeyEvent *e) +{ + switch ( e->key() ) + { + case Key_Plus: + case Key_Equal: + slotZoomIn(); + break; + case Key_Minus: + case Key_Underscore: + slotZoomOut(); + break; + case Key_Escape: + close(); + break; + } +} + +void ElementDataViewer::slotZoomIn(){} +void ElementDataViewer::slotZoomOut(){} + +void ElementDataViewer::setupAxisData() +{ + DoubleList l; + + const int selectedData = m_pPlotSetupWidget->KCB_y->currentItem(); + + //this should be somewhere else, eg in its own method + yData->m_currentDataType = selectedData; + + EList::iterator it = d->ElementList.begin(); + const EList::iterator itEnd = d->ElementList.end(); + switch(selectedData) + { + case AxisData::MASS: + for( ; it != itEnd ; ++it ) { + double value = (*it)->mass(); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Atomic Mass [u]")); + break; + case AxisData::MEANWEIGHT: + for( ; it != itEnd ; ++it ) { + double value =(*it)->meanmass(); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Mean Mass [u]")); + break; + case AxisData::DENSITY: + for( ; it != itEnd ; ++it ) { + double value =(*it)->density(); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Density")); + break; + case AxisData::EN: + for( ; it != itEnd ; ++it ) { + double value = (*it)->electroneg(); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Electronegativity")); + break; + case AxisData::MELTINGPOINT: + for( ; it != itEnd ; ++it ) { + double value = (*it)->melting(); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Melting Point [K]")); + break; + case AxisData::BOILINGPOINT: + for( ; it != itEnd ; ++it ) { + double value = (*it)->boiling(); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Boiling Point [K]")); + break; + case AxisData::ATOMICRADIUS: + for( ; it != itEnd ; ++it ) { + double value = (*it)->radius( Element::ATOMIC ); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Atomic Radius [pm]")); + break; + case AxisData::COVALENTRADIUS: + for( ; it != itEnd ; ++it ) { + double value = (*it)->radius( Element::COVALENT ); + if( value > 0.0 ) + l.append( value ); + else + l.append( 0.0 ); + } + m_pPlotWidget->setYAxisLabel(i18n("Covalent Radius [pm]")); + break; + } + + yData->setDataList( l ); +} + +void ElementDataViewer::drawPlot() +{ + kdDebug() << "drawPlot()" << endl; + + /* + * to be 100% safe delete the old list + */ + m_pPlotWidget->clearObjectList(); + + /* + * spare the next step in case everything is already set and done + */ + if( yData->currentDataType() != m_pPlotSetupWidget->KCB_y->currentItem() ) + initData(); + + /* + * if the user selected the elements 20 to 30 the list-values are 19 to 29!!! + */ + const int from = m_pPlotSetupWidget->from->value(); + const int to = m_pPlotSetupWidget->to->value(); + + /* + * The number of elements. #20 to 30 are 30-20+1=11 Elements + */ + const int num = to-from+1; + + setLimits(from,to); + + /* + * check if the users wants to see the elementnames or not + */ + bool showNames = m_pPlotSetupWidget->showNames->isChecked(); + bool connectPoints = m_pPlotSetupWidget->connectPoints->isChecked(); + + if ( connectPoints ) + m_pPlotWidget->setConnection( true ); + else + m_pPlotWidget->setConnection( false ); + + /* + * reserve the memory for the KPlotObjects + */ + //TODO QT4 replace QMemArray with QVector + QMemArray dataPoint(num); + QMemArray dataPointLabel(num); + + int number = 0; + + double max = 0.0, av = 0.0; + double min = yData->value( 1 ); + + /* + * iterate for example from element 20 to 30 and contruct + * the KPlotObjects + */ + for( int i = from; i < to+1 ; i++ ) + { + double v = yData->value( i ); + + if ( v >= 0.0 ) + { + if ( v < min ) + min = v; + if ( v > max ) + max = v; + av += v; + + dataPoint[number] = new KPlotObject( "whocares", "Blue", KPlotObject::POINTS, 4, KPlotObject::CIRCLE ); + dataPoint[number]->addPoint( new DPoint( (double)i , v ) ); + m_pPlotWidget->addObject( dataPoint[ number ] ); + + if (showNames) + { + dataPointLabel[number] = new KPlotObject( *(names.at(i-1)), "Red", KPlotObject::LABEL ); + dataPointLabel[number]->addPoint( new DPoint( (double)i , yData->value( i ) ) ); + m_pPlotWidget->addObject( dataPointLabel[number] ); + } + } + number++; + } + + //now set the values for the min, max and avarage value + m_pPlotSetupWidget->aValue->setText( QString::number( av/number ) ); + m_pPlotSetupWidget->minValue->setText( QString::number( min ) ); + m_pPlotSetupWidget->maxValue->setText( QString::number( max ) ); +} + +void ElementDataViewer::initData() +{ + setupAxisData(); +} + +/////////////////////////////////////////////// + +AxisData::AxisData() +{} + +#include "elementdataviewer.moc" diff --git a/kalzium/src/elementdataviewer.h b/kalzium/src/elementdataviewer.h new file mode 100644 index 00000000..4414377c --- /dev/null +++ b/kalzium/src/elementdataviewer.h @@ -0,0 +1,147 @@ +#ifndef ELEMENTDATAVIEWER_H +#define ELEMENTDATAVIEWER_H +/*************************************************************************** + copyright : (C) 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include + +typedef QValueList DoubleList; + +class Element; +class KalziumDataObject; +class PlotSetupWidget; +class PlotWidget; +class KActionCollection; + +/** + * @short the values of the y-Axis + * @author Carsten Niehaus + */ +class AxisData +{ + friend class ElementDataViewer; + + public: + AxisData(); + + /** + * sets the dataList to @p list + */ + void setDataList( DoubleList list ){ + dataList = list; + } + + /** + * @return the value of the selected dataset of element @p element + */ + double value( int element ){ + return *dataList.at( element-1 ); + } + + /** + * This represents the possible datasets. + * @li MASS: the mass of the element + * @li MELTINGPOINT: the meanmass of the element + */ + enum PAXISDATA{ + MASS=0, + MEANWEIGHT, + DENSITY, + EN, + MELTINGPOINT, + BOILINGPOINT, + ATOMICRADIUS, + COVALENTRADIUS + }; + + /** + * @return the currently selected data type + * @see AxisData::PAXISDATA + */ + int currentDataType(){ + return m_currentDataType; + } + + int numberOfElements() const{ + return dataList.count(); + } + + private: + /** + * the dataList contains the values off all elements + * but only of the currently selected data type. This + * means that it eg contains all boiling points + */ + DoubleList dataList; + + int m_currentDataType; +}; + +/** + * @short This widget shows the plot and the widget + * where you can setup the plot + * @author Carsten Niehaus + */ +class ElementDataViewer : public KDialogBase +{ + Q_OBJECT + + public: + ElementDataViewer( QWidget *parent=0 , const char *name =0 ); + + /** + * the AxixData for the y-Axis + */ + AxisData *yData; + + public slots: + void slotZoomIn(); + void slotZoomOut(); + + /** + * draws the plot + */ + void drawPlot(); + + void slotUser1(); + + protected: + virtual void paintEvent(QPaintEvent*); + virtual void keyPressEvent(QKeyEvent *e); + + protected slots: + /** + * invoke the help of the correct chapter + */ + virtual void slotHelp(); + + private: + PlotWidget *m_pPlotWidget; + PlotSetupWidget *m_pPlotSetupWidget; + + KalziumDataObject *d; + + QStringList names; + + KActionCollection* m_actionCollection; + + void initData(); + void setupAxisData(); + + void setLimits(int, int); + +}; + +#endif // ELEMENTDATAVIEWER_H + diff --git a/kalzium/src/elementpics/Al.jpg b/kalzium/src/elementpics/Al.jpg new file mode 100644 index 00000000..5937304c Binary files /dev/null and b/kalzium/src/elementpics/Al.jpg differ diff --git a/kalzium/src/elementpics/As.jpg b/kalzium/src/elementpics/As.jpg new file mode 100644 index 00000000..56705664 Binary files /dev/null and b/kalzium/src/elementpics/As.jpg differ diff --git a/kalzium/src/elementpics/Au.jpg b/kalzium/src/elementpics/Au.jpg new file mode 100644 index 00000000..3c066c25 Binary files /dev/null and b/kalzium/src/elementpics/Au.jpg differ diff --git a/kalzium/src/elementpics/B.jpg b/kalzium/src/elementpics/B.jpg new file mode 100644 index 00000000..562122cc Binary files /dev/null and b/kalzium/src/elementpics/B.jpg differ diff --git a/kalzium/src/elementpics/Be.jpg b/kalzium/src/elementpics/Be.jpg new file mode 100644 index 00000000..f7d8fb1e Binary files /dev/null and b/kalzium/src/elementpics/Be.jpg differ diff --git a/kalzium/src/elementpics/Bi.jpg b/kalzium/src/elementpics/Bi.jpg new file mode 100644 index 00000000..950f092f Binary files /dev/null and b/kalzium/src/elementpics/Bi.jpg differ diff --git a/kalzium/src/elementpics/Br.jpg b/kalzium/src/elementpics/Br.jpg new file mode 100644 index 00000000..69471528 Binary files /dev/null and b/kalzium/src/elementpics/Br.jpg differ diff --git a/kalzium/src/elementpics/C.jpg b/kalzium/src/elementpics/C.jpg new file mode 100644 index 00000000..58f237a3 Binary files /dev/null and b/kalzium/src/elementpics/C.jpg differ diff --git a/kalzium/src/elementpics/Ca.jpg b/kalzium/src/elementpics/Ca.jpg new file mode 100644 index 00000000..2278505d Binary files /dev/null and b/kalzium/src/elementpics/Ca.jpg differ diff --git a/kalzium/src/elementpics/Cd.jpg b/kalzium/src/elementpics/Cd.jpg new file mode 100644 index 00000000..b62212de Binary files /dev/null and b/kalzium/src/elementpics/Cd.jpg differ diff --git a/kalzium/src/elementpics/Cl.jpg b/kalzium/src/elementpics/Cl.jpg new file mode 100644 index 00000000..0ec815d4 Binary files /dev/null and b/kalzium/src/elementpics/Cl.jpg differ diff --git a/kalzium/src/elementpics/Co.jpg b/kalzium/src/elementpics/Co.jpg new file mode 100644 index 00000000..906cc778 Binary files /dev/null and b/kalzium/src/elementpics/Co.jpg differ diff --git a/kalzium/src/elementpics/Cr.jpg b/kalzium/src/elementpics/Cr.jpg new file mode 100644 index 00000000..ffcc9a1b Binary files /dev/null and b/kalzium/src/elementpics/Cr.jpg differ diff --git a/kalzium/src/elementpics/Cu.jpg b/kalzium/src/elementpics/Cu.jpg new file mode 100644 index 00000000..c45df8d7 Binary files /dev/null and b/kalzium/src/elementpics/Cu.jpg differ diff --git a/kalzium/src/elementpics/F.jpg b/kalzium/src/elementpics/F.jpg new file mode 100644 index 00000000..dfcd8cdd Binary files /dev/null and b/kalzium/src/elementpics/F.jpg differ diff --git a/kalzium/src/elementpics/Fe.jpg b/kalzium/src/elementpics/Fe.jpg new file mode 100644 index 00000000..6c8969b8 Binary files /dev/null and b/kalzium/src/elementpics/Fe.jpg differ diff --git a/kalzium/src/elementpics/Ga.jpg b/kalzium/src/elementpics/Ga.jpg new file mode 100644 index 00000000..a829673f Binary files /dev/null and b/kalzium/src/elementpics/Ga.jpg differ diff --git a/kalzium/src/elementpics/Ge.jpg b/kalzium/src/elementpics/Ge.jpg new file mode 100644 index 00000000..42c006b0 Binary files /dev/null and b/kalzium/src/elementpics/Ge.jpg differ diff --git a/kalzium/src/elementpics/H.jpg b/kalzium/src/elementpics/H.jpg new file mode 100644 index 00000000..ab879efc Binary files /dev/null and b/kalzium/src/elementpics/H.jpg differ diff --git a/kalzium/src/elementpics/He.jpg b/kalzium/src/elementpics/He.jpg new file mode 100644 index 00000000..71c1a311 Binary files /dev/null and b/kalzium/src/elementpics/He.jpg differ diff --git a/kalzium/src/elementpics/Hg.jpg b/kalzium/src/elementpics/Hg.jpg new file mode 100644 index 00000000..b5051c8f Binary files /dev/null and b/kalzium/src/elementpics/Hg.jpg differ diff --git a/kalzium/src/elementpics/I.jpg b/kalzium/src/elementpics/I.jpg new file mode 100644 index 00000000..ecacd84a Binary files /dev/null and b/kalzium/src/elementpics/I.jpg differ diff --git a/kalzium/src/elementpics/In.jpg b/kalzium/src/elementpics/In.jpg new file mode 100644 index 00000000..224454a1 Binary files /dev/null and b/kalzium/src/elementpics/In.jpg differ diff --git a/kalzium/src/elementpics/K.jpg b/kalzium/src/elementpics/K.jpg new file mode 100644 index 00000000..b9291c3f Binary files /dev/null and b/kalzium/src/elementpics/K.jpg differ diff --git a/kalzium/src/elementpics/Kr.jpg b/kalzium/src/elementpics/Kr.jpg new file mode 100644 index 00000000..317ff190 Binary files /dev/null and b/kalzium/src/elementpics/Kr.jpg differ diff --git a/kalzium/src/elementpics/Li.jpg b/kalzium/src/elementpics/Li.jpg new file mode 100644 index 00000000..e2d54208 Binary files /dev/null and b/kalzium/src/elementpics/Li.jpg differ diff --git a/kalzium/src/elementpics/Makefile.am b/kalzium/src/elementpics/Makefile.am new file mode 100644 index 00000000..ede0d0af --- /dev/null +++ b/kalzium/src/elementpics/Makefile.am @@ -0,0 +1,3 @@ +elempic_DATA = Al.jpg Be.jpg Br.jpg Ca.jpg Cl.jpg Co.jpg Fe.jpg Ge.jpg H.jpg Kr.jpg Mn.jpg Nb.jpg N.jpg Pd.jpg Re.jpg Se.jpg Sn.jpg Th.jpg V.jpg Zn.jpg As.jpg Bi.jpg Cd.jpg Cr.jpg F.jpg He.jpg In.jpg I.jpg Li.jpg Mo.jpg Ne.jpg O.jpg P.jpg Rh.jpg Si.jpg Ta.jpg Ti.jpg W.jpg Zr.jpg Au.jpg B.jpg C.jpg Cu.jpg Ga.jpg Hg.jpg K.jpg Mg.jpg Na.jpg Ni.jpg Pb.jpg Pt.jpg Sb.jpg S.jpg Te.jpg U.jpg Xe.jpg +elempicdir = $(kde_datadir)/kalzium/elempics + diff --git a/kalzium/src/elementpics/Mg.jpg b/kalzium/src/elementpics/Mg.jpg new file mode 100644 index 00000000..54974861 Binary files /dev/null and b/kalzium/src/elementpics/Mg.jpg differ diff --git a/kalzium/src/elementpics/Mn.jpg b/kalzium/src/elementpics/Mn.jpg new file mode 100644 index 00000000..5736d07b Binary files /dev/null and b/kalzium/src/elementpics/Mn.jpg differ diff --git a/kalzium/src/elementpics/Mo.jpg b/kalzium/src/elementpics/Mo.jpg new file mode 100644 index 00000000..e21f786c Binary files /dev/null and b/kalzium/src/elementpics/Mo.jpg differ diff --git a/kalzium/src/elementpics/N.jpg b/kalzium/src/elementpics/N.jpg new file mode 100644 index 00000000..6b8ed8fa Binary files /dev/null and b/kalzium/src/elementpics/N.jpg differ diff --git a/kalzium/src/elementpics/Na.jpg b/kalzium/src/elementpics/Na.jpg new file mode 100644 index 00000000..c3f7556f Binary files /dev/null and b/kalzium/src/elementpics/Na.jpg differ diff --git a/kalzium/src/elementpics/Nb.jpg b/kalzium/src/elementpics/Nb.jpg new file mode 100644 index 00000000..f2f61093 Binary files /dev/null and b/kalzium/src/elementpics/Nb.jpg differ diff --git a/kalzium/src/elementpics/Ne.jpg b/kalzium/src/elementpics/Ne.jpg new file mode 100644 index 00000000..ef16d8a7 Binary files /dev/null and b/kalzium/src/elementpics/Ne.jpg differ diff --git a/kalzium/src/elementpics/Ni.jpg b/kalzium/src/elementpics/Ni.jpg new file mode 100644 index 00000000..dcc23d55 Binary files /dev/null and b/kalzium/src/elementpics/Ni.jpg differ diff --git a/kalzium/src/elementpics/O.jpg b/kalzium/src/elementpics/O.jpg new file mode 100644 index 00000000..308e6272 Binary files /dev/null and b/kalzium/src/elementpics/O.jpg differ diff --git a/kalzium/src/elementpics/P.jpg b/kalzium/src/elementpics/P.jpg new file mode 100644 index 00000000..51333f7c Binary files /dev/null and b/kalzium/src/elementpics/P.jpg differ diff --git a/kalzium/src/elementpics/Pb.jpg b/kalzium/src/elementpics/Pb.jpg new file mode 100644 index 00000000..c42604f7 Binary files /dev/null and b/kalzium/src/elementpics/Pb.jpg differ diff --git a/kalzium/src/elementpics/Pd.jpg b/kalzium/src/elementpics/Pd.jpg new file mode 100644 index 00000000..607ec7d7 Binary files /dev/null and b/kalzium/src/elementpics/Pd.jpg differ diff --git a/kalzium/src/elementpics/Pt.jpg b/kalzium/src/elementpics/Pt.jpg new file mode 100644 index 00000000..2d16eaea Binary files /dev/null and b/kalzium/src/elementpics/Pt.jpg differ diff --git a/kalzium/src/elementpics/Re.jpg b/kalzium/src/elementpics/Re.jpg new file mode 100644 index 00000000..6ac696a7 Binary files /dev/null and b/kalzium/src/elementpics/Re.jpg differ diff --git a/kalzium/src/elementpics/Rh.jpg b/kalzium/src/elementpics/Rh.jpg new file mode 100644 index 00000000..b6cd3e22 Binary files /dev/null and b/kalzium/src/elementpics/Rh.jpg differ diff --git a/kalzium/src/elementpics/S.jpg b/kalzium/src/elementpics/S.jpg new file mode 100644 index 00000000..385fb1fc Binary files /dev/null and b/kalzium/src/elementpics/S.jpg differ diff --git a/kalzium/src/elementpics/Sb.jpg b/kalzium/src/elementpics/Sb.jpg new file mode 100644 index 00000000..fee1fe81 Binary files /dev/null and b/kalzium/src/elementpics/Sb.jpg differ diff --git a/kalzium/src/elementpics/Se.jpg b/kalzium/src/elementpics/Se.jpg new file mode 100644 index 00000000..8c27b652 Binary files /dev/null and b/kalzium/src/elementpics/Se.jpg differ diff --git a/kalzium/src/elementpics/Si.jpg b/kalzium/src/elementpics/Si.jpg new file mode 100644 index 00000000..e7aad9fa Binary files /dev/null and b/kalzium/src/elementpics/Si.jpg differ diff --git a/kalzium/src/elementpics/Sn.jpg b/kalzium/src/elementpics/Sn.jpg new file mode 100644 index 00000000..608c5b6a Binary files /dev/null and b/kalzium/src/elementpics/Sn.jpg differ diff --git a/kalzium/src/elementpics/Ta.jpg b/kalzium/src/elementpics/Ta.jpg new file mode 100644 index 00000000..aec4e4c8 Binary files /dev/null and b/kalzium/src/elementpics/Ta.jpg differ diff --git a/kalzium/src/elementpics/Te.jpg b/kalzium/src/elementpics/Te.jpg new file mode 100644 index 00000000..1a00465a Binary files /dev/null and b/kalzium/src/elementpics/Te.jpg differ diff --git a/kalzium/src/elementpics/Th.jpg b/kalzium/src/elementpics/Th.jpg new file mode 100644 index 00000000..0e4b7228 Binary files /dev/null and b/kalzium/src/elementpics/Th.jpg differ diff --git a/kalzium/src/elementpics/Ti.jpg b/kalzium/src/elementpics/Ti.jpg new file mode 100644 index 00000000..65781f79 Binary files /dev/null and b/kalzium/src/elementpics/Ti.jpg differ diff --git a/kalzium/src/elementpics/U.jpg b/kalzium/src/elementpics/U.jpg new file mode 100644 index 00000000..8f0246b3 Binary files /dev/null and b/kalzium/src/elementpics/U.jpg differ diff --git a/kalzium/src/elementpics/V.jpg b/kalzium/src/elementpics/V.jpg new file mode 100644 index 00000000..f5723643 Binary files /dev/null and b/kalzium/src/elementpics/V.jpg differ diff --git a/kalzium/src/elementpics/W.jpg b/kalzium/src/elementpics/W.jpg new file mode 100644 index 00000000..78d554d3 Binary files /dev/null and b/kalzium/src/elementpics/W.jpg differ diff --git a/kalzium/src/elementpics/Xe.jpg b/kalzium/src/elementpics/Xe.jpg new file mode 100644 index 00000000..0c716194 Binary files /dev/null and b/kalzium/src/elementpics/Xe.jpg differ diff --git a/kalzium/src/elementpics/Zn.jpg b/kalzium/src/elementpics/Zn.jpg new file mode 100644 index 00000000..d11dea36 Binary files /dev/null and b/kalzium/src/elementpics/Zn.jpg differ diff --git a/kalzium/src/elementpics/Zr.jpg b/kalzium/src/elementpics/Zr.jpg new file mode 100644 index 00000000..cb0bf7e9 Binary files /dev/null and b/kalzium/src/elementpics/Zr.jpg differ diff --git a/kalzium/src/eqchemview.cpp b/kalzium/src/eqchemview.cpp new file mode 100644 index 00000000..6b5a9476 --- /dev/null +++ b/kalzium/src/eqchemview.cpp @@ -0,0 +1,121 @@ +/*************************************************************************** + * Copyright (C) 2004, 2005 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include + +#include "config.h" +#include "eqresult.h" +#include "eqchemview.h" + +#include + +#ifdef HAVE_FACILE +extern "C" { + char* solve_equation(const char *); +} +#endif + +#ifndef HAVE_FACILE +char* solve_equation(const char *) { return NULL; } +#endif + +eqchemView::eqchemView(QWidget *parent) : QWidget(parent) +{ + settingsChanged(); + + QGridLayout *l = new QGridLayout(this, 2, 2, 11, 6, "eqchemView::eqchemView layout"); + + m_eqResult = new EqResult(this); + m_eqedit = new KLineEdit(this); + m_eqclear = new KPushButton(this); + + l->addMultiCellWidget(m_eqResult, 0, 0, 0, 1); + l->addWidget(m_eqedit, 1, 1); + l->addWidget(m_eqclear, 1, 0); + + m_eqclear->setIconSet( KGlobal::instance()->iconLoader()->loadIconSet("locationbar_erase", + KIcon::NoGroup, 22 /*KIcon::SizeSmallMedium*/) ); + + connect(m_eqclear, SIGNAL(clicked()), m_eqedit, SLOT(clear()) ); +} + +eqchemView::~eqchemView() +{ + +} + +void eqchemView::settingsChanged() +{ + // i18n : internationalization + emit signalChangeStatusbar( i18n("Settings changed") ); +} + + +void eqchemView::clear() +{ + kdWarning()<<"eqchemView::clear"<clear(); +} + +void eqchemView::compute() +{ + QString equation( m_eqedit->text() ); + equation.replace("+", "+"); + equation.replace("->", " -> "); + equation.append(" "); + equation.prepend(" "); + + char * result = solve_equation( equation.latin1() ); + QString disp = QString(result); + + // mem leak ? + free(result); + + // add the equation in the result window + m_eqResult->add( equation, disp ); +} + +EQChemDialog::EQChemDialog( QWidget *parent ) + : KDialogBase(parent, "EQChemDialog", true, i18n( "Solve Chemical Equations" ), + KDialogBase::Apply|KDialogBase::Close|KDialogBase::Help, KDialogBase::Apply, true ) +{ +} + +void EQChemDialog::slotHelp() +{ + emit helpClicked(); + if ( kapp ) + kapp->invokeHelp ( "eq_solver", "kalzium" ); +} + +#include "eqchemview.moc" + diff --git a/kalzium/src/eqchemview.h b/kalzium/src/eqchemview.h new file mode 100644 index 00000000..4e381fc2 --- /dev/null +++ b/kalzium/src/eqchemview.h @@ -0,0 +1,104 @@ +/*************************************************************************** + * Copyright (C) 2004, 2005 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#ifndef _EQCHEMVIEW_H_ +#define _EQCHEMVIEW_H_ + +#include +#include + +class QPainter; +class KURL; +class EqResult; + +class KLineEdit; +class KPushButton; + +/** + * This is the main view class for eqchem. Most of the non-menu, + * non-toolbar, and non-statusbar (e.g., non frame) GUI code should go + * here. + * + * @short Main view + * @author Thomas Nagy + * @version 0.1 + */ +class eqchemView : public QWidget +{ + Q_OBJECT +public: + /** + * Default constructor + */ + eqchemView(QWidget *parent); + + /** + * Destructor + */ + virtual ~eqchemView(); + +signals: + /** + * Use this signal to change the content of the statusbar + */ + void signalChangeStatusbar(const QString& text); + + /** + * Use this signal to change the content of the caption + */ + void signalChangeCaption(const QString& text); + +public slots: + void clear(); + void compute(); + + +private slots: + void settingsChanged(); + +private: + KLineEdit * m_eqedit; + KPushButton * m_eqclear; + EqResult * m_eqResult; +}; + +/** + * @author Carsten Niehaus + */ +class EQChemDialog : public KDialogBase +{ + Q_OBJECT + + public: + /** + * public constructor + * + * @param parent the parent widget + */ + EQChemDialog( QWidget *parent ); + + private slots: + /** + * invokes the help for this widget + */ + void slotHelp(); +}; + +#endif // _EQCHEMVIEW_H_ diff --git a/kalzium/src/eqresult.cpp b/kalzium/src/eqresult.cpp new file mode 100644 index 00000000..a1ebf555 --- /dev/null +++ b/kalzium/src/eqresult.cpp @@ -0,0 +1,128 @@ +/*************************************************************************** + * Copyright (C) 2004, 2005 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include +#include +#include + +#include + +#include "eqresult.h" + +// inspired by speedcrunch + +QuestionItem::QuestionItem( QListBox* listBox, const QString& e, QColor bg ): +QListBoxItem ( listBox ) +{ + m_msg = e; + m_bgcolor = bg; +} + +AnswerItem::AnswerItem( QListBox* listBox, const QString& e, const QString &r, QColor bg ): +QListBoxItem ( listBox ) +{ + m_msg = "

"+r+"

"; + m_origmsg = e; + m_bgcolor = bg; + m_richtext = new QSimpleRichText(m_msg, listBox->font()); + m_richtext->setWidth( listBox->width() ); +} + +void QuestionItem::paint( QPainter* painter ) +{ + int tf = Qt::NoAccel | Qt::SingleLine | Qt::AlignVCenter; + + QRect r ( 0, 0, listBox()->contentsWidth(), height( listBox() ) ); + painter->fillRect( r, m_bgcolor ); + painter->drawText( r, tf, m_msg ); +} + +void AnswerItem::paint( QPainter* painter ) +{ + checkSize(); + + QRect r ( 0, 0, listBox()->contentsWidth(), height( listBox() ) ); + painter->fillRect( r, m_bgcolor ); + + QColorGroup cg = listBox()->colorGroup(); + cg.setColor( QColorGroup::Background, m_bgcolor ); + + m_richtext->draw(painter, 0, 0, r, cg ); +} + +int QuestionItem::width( const QListBox*lb ) const +{ + QFont font = lb->font(); + return QFontMetrics( font ).width( m_msg ); +} + +int QuestionItem::height( const QListBox*lb ) const +{ + QFont font = lb->font(); + return QFontMetrics( font ).height() + 4; +} + +void AnswerItem::checkSize() +{ + QFont font = listBox()->font(); + int t1 = QFontMetrics( font ).width( m_origmsg+"padding" ); + int t2 = listBox()->width() - 20; + + // take the maximum + m_richtext->setWidth( (t1>t2)?t1:t2 ); +} + +EqResult::EqResult(QWidget *parent) : QListBox(parent) +{ + m_alternate_color = false; + setMinimumWidth(140); +} + +EqResult::~EqResult() +{ +} + +void EqResult::add(const QString & question, const QString & answer) +{ + QColor bgcolor = colorGroup().base(); + + if ( m_alternate_color ) + bgcolor = bgcolor.dark( 120 ); + + m_alternate_color = !m_alternate_color; + + new QuestionItem( this, question, bgcolor ); + new AnswerItem( this, question, answer, bgcolor ); + + QTimer::singleShot( 100, this, SLOT( scrollToEnd() ) ); +} + +void EqResult::scrollToEnd() +{ + ensureVisible( 0, contentsHeight()-1 ); +} + +void EqResult::resizeEvent( QResizeEvent* ) +{ + triggerUpdate( true ); +} + +#include "eqresult.moc" + diff --git a/kalzium/src/eqresult.h b/kalzium/src/eqresult.h new file mode 100644 index 00000000..7b229cde --- /dev/null +++ b/kalzium/src/eqresult.h @@ -0,0 +1,90 @@ +/*************************************************************************** + * Copyright (C) 2004, 2005 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#ifndef _EQRESULT_H_ +#define _EQRESULT_H_ + +#include +#include + +/** + * @author Thomas Nagy + */ +class QuestionItem : public QListBoxItem +{ + public: + QuestionItem( QListBox*, const QString&, QColor bg ); + protected: + void paint( QPainter* p ); + int width( const QListBox* ) const; + int height( const QListBox* ) const; + private: + QString m_msg; + QColor m_bgcolor; +}; + +/** + * @author Thomas Nagy + */ +class AnswerItem : public QListBoxItem +{ + public: + AnswerItem( QListBox*, const QString&, const QString&, QColor bg ); + ~AnswerItem() { delete m_richtext; } + void checkSize(); + protected: + void paint( QPainter* p ); + int width( const QListBox* ) const{ + return m_richtext->height(); + } + + int height( const QListBox* ) const{ + return m_richtext->height(); + } + + private: + QString m_msg; + QString m_origmsg; + QColor m_bgcolor; + QSimpleRichText * m_richtext; +}; + +/** + * @author Thomas Nagy + */ +class EqResult : public QListBox +{ + Q_OBJECT +public: + + EqResult(QWidget *parent); + ~EqResult(); + +public slots: + void add(const QString &, const QString &); + void scrollToEnd(); + void resizeEvent( QResizeEvent* ); + +private: + bool m_alternate_color; +}; + +#endif // _EQRESULT_H_ + diff --git a/kalzium/src/exporter.cpp b/kalzium/src/exporter.cpp new file mode 100644 index 00000000..48f50170 --- /dev/null +++ b/kalzium/src/exporter.cpp @@ -0,0 +1,62 @@ +/* Copyright (C) 2005 by Martin Pfeiffer * + * hubipete@gmx.net * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "exporter.h" + +#include + +#include +#include + +Exporter::Exporter() +{ + static bool kimageioRegistered = false; + if ( ! kimageioRegistered ) + { + KImageIO::registerFormats(); + kimageioRegistered = true; + } + +} + +Exporter::~Exporter() +{ +} + +bool Exporter::saveAsImage( const QPixmap* pixmap, const QString& fileName, int x, int y, int width, int height ) +{ + if ( x != 0 || y != 0 || width != 0 || height != 0 ) + { + QPixmap* tmpPixmap = new QPixmap(); + + copyBlt( tmpPixmap, 0, 0, pixmap, x, y, width, height ); + + if ( tmpPixmap->isNull() ) + kdDebug() << "empty pixmap" << endl; + return tmpPixmap->save( fileName, "PNG" ); + } + + return pixmap->save( fileName, "PNG" ); +} + +QString Exporter::supportedImageFormats() +{ + return KImageIO::pattern( KImageIO::Writing ); +} + diff --git a/kalzium/src/exporter.h b/kalzium/src/exporter.h new file mode 100644 index 00000000..c780a394 --- /dev/null +++ b/kalzium/src/exporter.h @@ -0,0 +1,54 @@ +#ifndef EXPORTER_H +#define EXPORTER_H + +/*************************************************************************** + + The header for the exporter class of Kalzium + ------------------- + begin : June 2005 + copyright : (C) 2005 by Martin Pfeiffer + email : hubipete@gmx.net + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +class QPixmap; +class QString; + +/** + * Small class that provides some exporting functions for graphics. + * + * @author Martin Pfeiffer + */ +class Exporter +{ +public: + Exporter(); + ~Exporter(); + + /** + * Export the image @p pixmap to the file @p fileName. + * If specified, @p x, @p y, @p width and @p height gives the region of + * @p pixmap we should export. Otherwise, the entire @p pixmap will be + * exported. + * @return whether the image was saved successfully + */ + bool saveAsImage( const QPixmap* pixmap, const QString& fileName, int x = 0, int y = 0, int width = 0, int height = 0 ); + + /** + * Which image type can we export to? + * @return a string representing a filter string for file dialogs with + * the image type we can export to + */ + QString supportedImageFormats(); +}; + +#endif + diff --git a/kalzium/src/hi128-app-kalzium.png b/kalzium/src/hi128-app-kalzium.png new file mode 100644 index 00000000..d48e0d86 Binary files /dev/null and b/kalzium/src/hi128-app-kalzium.png differ diff --git a/kalzium/src/hi16-app-kalzium.png b/kalzium/src/hi16-app-kalzium.png new file mode 100644 index 00000000..418badba Binary files /dev/null and b/kalzium/src/hi16-app-kalzium.png differ diff --git a/kalzium/src/hi22-app-kalzium.png b/kalzium/src/hi22-app-kalzium.png new file mode 100644 index 00000000..b686ab9c Binary files /dev/null and b/kalzium/src/hi22-app-kalzium.png differ diff --git a/kalzium/src/hi32-app-kalzium.png b/kalzium/src/hi32-app-kalzium.png new file mode 100644 index 00000000..1aabbbb6 Binary files /dev/null and b/kalzium/src/hi32-app-kalzium.png differ diff --git a/kalzium/src/hi48-app-kalzium.png b/kalzium/src/hi48-app-kalzium.png new file mode 100644 index 00000000..292766ac Binary files /dev/null and b/kalzium/src/hi48-app-kalzium.png differ diff --git a/kalzium/src/hi64-app-kalzium.png b/kalzium/src/hi64-app-kalzium.png new file mode 100644 index 00000000..6c4059be Binary files /dev/null and b/kalzium/src/hi64-app-kalzium.png differ diff --git a/kalzium/src/hisc-app-kalzium.svgz b/kalzium/src/hisc-app-kalzium.svgz new file mode 100644 index 00000000..f814bd18 Binary files /dev/null and b/kalzium/src/hisc-app-kalzium.svgz differ diff --git a/kalzium/src/icons/Makefile.am b/kalzium/src/icons/Makefile.am new file mode 100644 index 00000000..8cbc0bbb --- /dev/null +++ b/kalzium/src/icons/Makefile.am @@ -0,0 +1,4 @@ +SUBDIRS = $(AUTODIRS) + +kalziumiconsdir = $(kde_datadir)/kalzium/icons +kalziumicons_ICON = AUTO diff --git a/kalzium/src/icons/cr16-action-calculate.png b/kalzium/src/icons/cr16-action-calculate.png new file mode 100644 index 00000000..7b15c0f3 Binary files /dev/null and b/kalzium/src/icons/cr16-action-calculate.png differ diff --git a/kalzium/src/icons/cr16-action-chemical.png b/kalzium/src/icons/cr16-action-chemical.png new file mode 100644 index 00000000..4877508a Binary files /dev/null and b/kalzium/src/icons/cr16-action-chemical.png differ diff --git a/kalzium/src/icons/cr16-action-elempic.png b/kalzium/src/icons/cr16-action-elempic.png new file mode 100644 index 00000000..6741ae0a Binary files /dev/null and b/kalzium/src/icons/cr16-action-elempic.png differ diff --git a/kalzium/src/icons/cr16-action-energies.png b/kalzium/src/icons/cr16-action-energies.png new file mode 100644 index 00000000..540874e6 Binary files /dev/null and b/kalzium/src/icons/cr16-action-energies.png differ diff --git a/kalzium/src/icons/cr16-action-eqchem.png b/kalzium/src/icons/cr16-action-eqchem.png new file mode 100644 index 00000000..6814438a Binary files /dev/null and b/kalzium/src/icons/cr16-action-eqchem.png differ diff --git a/kalzium/src/icons/cr16-action-glossary.png b/kalzium/src/icons/cr16-action-glossary.png new file mode 100644 index 00000000..f02fb32a Binary files /dev/null and b/kalzium/src/icons/cr16-action-glossary.png differ diff --git a/kalzium/src/icons/cr16-action-isotopemap.png b/kalzium/src/icons/cr16-action-isotopemap.png new file mode 100644 index 00000000..057a9be5 Binary files /dev/null and b/kalzium/src/icons/cr16-action-isotopemap.png differ diff --git a/kalzium/src/icons/cr16-action-legend.png b/kalzium/src/icons/cr16-action-legend.png new file mode 100644 index 00000000..7330bc5b Binary files /dev/null and b/kalzium/src/icons/cr16-action-legend.png differ diff --git a/kalzium/src/icons/cr16-action-misc.png b/kalzium/src/icons/cr16-action-misc.png new file mode 100644 index 00000000..97e5e77a Binary files /dev/null and b/kalzium/src/icons/cr16-action-misc.png differ diff --git a/kalzium/src/icons/cr16-action-orbits.png b/kalzium/src/icons/cr16-action-orbits.png new file mode 100644 index 00000000..79717952 Binary files /dev/null and b/kalzium/src/icons/cr16-action-orbits.png differ diff --git a/kalzium/src/icons/cr16-action-overview.png b/kalzium/src/icons/cr16-action-overview.png new file mode 100644 index 00000000..1be350fc Binary files /dev/null and b/kalzium/src/icons/cr16-action-overview.png differ diff --git a/kalzium/src/icons/cr16-action-plot.png b/kalzium/src/icons/cr16-action-plot.png new file mode 100644 index 00000000..c5484d74 Binary files /dev/null and b/kalzium/src/icons/cr16-action-plot.png differ diff --git a/kalzium/src/icons/cr16-action-sidebar.png b/kalzium/src/icons/cr16-action-sidebar.png new file mode 100644 index 00000000..fc6ef0a7 Binary files /dev/null and b/kalzium/src/icons/cr16-action-sidebar.png differ diff --git a/kalzium/src/icons/cr16-action-spectrum.png b/kalzium/src/icons/cr16-action-spectrum.png new file mode 100644 index 00000000..1adc2d45 Binary files /dev/null and b/kalzium/src/icons/cr16-action-spectrum.png differ diff --git a/kalzium/src/icons/cr16-action-statematter.png b/kalzium/src/icons/cr16-action-statematter.png new file mode 100644 index 00000000..1f48c762 Binary files /dev/null and b/kalzium/src/icons/cr16-action-statematter.png differ diff --git a/kalzium/src/icons/cr16-action-timeline.png b/kalzium/src/icons/cr16-action-timeline.png new file mode 100644 index 00000000..46bf7b07 Binary files /dev/null and b/kalzium/src/icons/cr16-action-timeline.png differ diff --git a/kalzium/src/icons/cr16-action-tooltip.png b/kalzium/src/icons/cr16-action-tooltip.png new file mode 100644 index 00000000..c6c96d68 Binary files /dev/null and b/kalzium/src/icons/cr16-action-tooltip.png differ diff --git a/kalzium/src/icons/cr22-action-calculate.png b/kalzium/src/icons/cr22-action-calculate.png new file mode 100644 index 00000000..2f4de681 Binary files /dev/null and b/kalzium/src/icons/cr22-action-calculate.png differ diff --git a/kalzium/src/icons/cr22-action-chemical.png b/kalzium/src/icons/cr22-action-chemical.png new file mode 100644 index 00000000..c70b1105 Binary files /dev/null and b/kalzium/src/icons/cr22-action-chemical.png differ diff --git a/kalzium/src/icons/cr22-action-elempic.png b/kalzium/src/icons/cr22-action-elempic.png new file mode 100644 index 00000000..efd036c1 Binary files /dev/null and b/kalzium/src/icons/cr22-action-elempic.png differ diff --git a/kalzium/src/icons/cr22-action-energies.png b/kalzium/src/icons/cr22-action-energies.png new file mode 100644 index 00000000..205db932 Binary files /dev/null and b/kalzium/src/icons/cr22-action-energies.png differ diff --git a/kalzium/src/icons/cr22-action-eqchem.png b/kalzium/src/icons/cr22-action-eqchem.png new file mode 100644 index 00000000..56248dae Binary files /dev/null and b/kalzium/src/icons/cr22-action-eqchem.png differ diff --git a/kalzium/src/icons/cr22-action-glossary.png b/kalzium/src/icons/cr22-action-glossary.png new file mode 100644 index 00000000..5f748aab Binary files /dev/null and b/kalzium/src/icons/cr22-action-glossary.png differ diff --git a/kalzium/src/icons/cr22-action-isotopemap.png b/kalzium/src/icons/cr22-action-isotopemap.png new file mode 100644 index 00000000..fe9fd7a1 Binary files /dev/null and b/kalzium/src/icons/cr22-action-isotopemap.png differ diff --git a/kalzium/src/icons/cr22-action-legend.png b/kalzium/src/icons/cr22-action-legend.png new file mode 100644 index 00000000..ec3006cf Binary files /dev/null and b/kalzium/src/icons/cr22-action-legend.png differ diff --git a/kalzium/src/icons/cr22-action-orbits.png b/kalzium/src/icons/cr22-action-orbits.png new file mode 100644 index 00000000..8b0ee15b Binary files /dev/null and b/kalzium/src/icons/cr22-action-orbits.png differ diff --git a/kalzium/src/icons/cr22-action-overview.png b/kalzium/src/icons/cr22-action-overview.png new file mode 100644 index 00000000..23691881 Binary files /dev/null and b/kalzium/src/icons/cr22-action-overview.png differ diff --git a/kalzium/src/icons/cr22-action-plot.png b/kalzium/src/icons/cr22-action-plot.png new file mode 100644 index 00000000..3462547b Binary files /dev/null and b/kalzium/src/icons/cr22-action-plot.png differ diff --git a/kalzium/src/icons/cr22-action-sidebar.png b/kalzium/src/icons/cr22-action-sidebar.png new file mode 100644 index 00000000..e9a6134c Binary files /dev/null and b/kalzium/src/icons/cr22-action-sidebar.png differ diff --git a/kalzium/src/icons/cr22-action-spectrum.png b/kalzium/src/icons/cr22-action-spectrum.png new file mode 100644 index 00000000..a8617501 Binary files /dev/null and b/kalzium/src/icons/cr22-action-spectrum.png differ diff --git a/kalzium/src/icons/cr22-action-statematter.png b/kalzium/src/icons/cr22-action-statematter.png new file mode 100644 index 00000000..4e786c39 Binary files /dev/null and b/kalzium/src/icons/cr22-action-statematter.png differ diff --git a/kalzium/src/icons/cr22-action-timeline.png b/kalzium/src/icons/cr22-action-timeline.png new file mode 100644 index 00000000..03e6ff87 Binary files /dev/null and b/kalzium/src/icons/cr22-action-timeline.png differ diff --git a/kalzium/src/icons/cr22-action-tooltip.png b/kalzium/src/icons/cr22-action-tooltip.png new file mode 100644 index 00000000..a095926f Binary files /dev/null and b/kalzium/src/icons/cr22-action-tooltip.png differ diff --git a/kalzium/src/icons/cr32-action-calculate.png b/kalzium/src/icons/cr32-action-calculate.png new file mode 100644 index 00000000..e4d462da Binary files /dev/null and b/kalzium/src/icons/cr32-action-calculate.png differ diff --git a/kalzium/src/icons/cr32-action-chemical.png b/kalzium/src/icons/cr32-action-chemical.png new file mode 100644 index 00000000..585f78b8 Binary files /dev/null and b/kalzium/src/icons/cr32-action-chemical.png differ diff --git a/kalzium/src/icons/cr32-action-elempic.png b/kalzium/src/icons/cr32-action-elempic.png new file mode 100644 index 00000000..21225366 Binary files /dev/null and b/kalzium/src/icons/cr32-action-elempic.png differ diff --git a/kalzium/src/icons/cr32-action-energies.png b/kalzium/src/icons/cr32-action-energies.png new file mode 100644 index 00000000..a416beae Binary files /dev/null and b/kalzium/src/icons/cr32-action-energies.png differ diff --git a/kalzium/src/icons/cr32-action-eqchem.png b/kalzium/src/icons/cr32-action-eqchem.png new file mode 100644 index 00000000..6f49f2bb Binary files /dev/null and b/kalzium/src/icons/cr32-action-eqchem.png differ diff --git a/kalzium/src/icons/cr32-action-glossary.png b/kalzium/src/icons/cr32-action-glossary.png new file mode 100644 index 00000000..6b00ccd5 Binary files /dev/null and b/kalzium/src/icons/cr32-action-glossary.png differ diff --git a/kalzium/src/icons/cr32-action-isotopemap.png b/kalzium/src/icons/cr32-action-isotopemap.png new file mode 100644 index 00000000..8f7080b9 Binary files /dev/null and b/kalzium/src/icons/cr32-action-isotopemap.png differ diff --git a/kalzium/src/icons/cr32-action-legend.png b/kalzium/src/icons/cr32-action-legend.png new file mode 100644 index 00000000..a0d02f56 Binary files /dev/null and b/kalzium/src/icons/cr32-action-legend.png differ diff --git a/kalzium/src/icons/cr32-action-misc.png b/kalzium/src/icons/cr32-action-misc.png new file mode 100644 index 00000000..f22e77a6 Binary files /dev/null and b/kalzium/src/icons/cr32-action-misc.png differ diff --git a/kalzium/src/icons/cr32-action-orbits.png b/kalzium/src/icons/cr32-action-orbits.png new file mode 100644 index 00000000..accabc36 Binary files /dev/null and b/kalzium/src/icons/cr32-action-orbits.png differ diff --git a/kalzium/src/icons/cr32-action-overview.png b/kalzium/src/icons/cr32-action-overview.png new file mode 100644 index 00000000..6de624f1 Binary files /dev/null and b/kalzium/src/icons/cr32-action-overview.png differ diff --git a/kalzium/src/icons/cr32-action-plot.png b/kalzium/src/icons/cr32-action-plot.png new file mode 100644 index 00000000..93c51576 Binary files /dev/null and b/kalzium/src/icons/cr32-action-plot.png differ diff --git a/kalzium/src/icons/cr32-action-sidebar.png b/kalzium/src/icons/cr32-action-sidebar.png new file mode 100644 index 00000000..7bf1b71f Binary files /dev/null and b/kalzium/src/icons/cr32-action-sidebar.png differ diff --git a/kalzium/src/icons/cr32-action-spectrum.png b/kalzium/src/icons/cr32-action-spectrum.png new file mode 100644 index 00000000..e33fc6cb Binary files /dev/null and b/kalzium/src/icons/cr32-action-spectrum.png differ diff --git a/kalzium/src/icons/cr32-action-statematter.png b/kalzium/src/icons/cr32-action-statematter.png new file mode 100644 index 00000000..2157b793 Binary files /dev/null and b/kalzium/src/icons/cr32-action-statematter.png differ diff --git a/kalzium/src/icons/cr32-action-timeline.png b/kalzium/src/icons/cr32-action-timeline.png new file mode 100644 index 00000000..0d9e528e Binary files /dev/null and b/kalzium/src/icons/cr32-action-timeline.png differ diff --git a/kalzium/src/icons/cr32-action-tooltip.png b/kalzium/src/icons/cr32-action-tooltip.png new file mode 100644 index 00000000..0f6142ef Binary files /dev/null and b/kalzium/src/icons/cr32-action-tooltip.png differ diff --git a/kalzium/src/icons/cr48-action-calculate.png b/kalzium/src/icons/cr48-action-calculate.png new file mode 100644 index 00000000..2bb64f0e Binary files /dev/null and b/kalzium/src/icons/cr48-action-calculate.png differ diff --git a/kalzium/src/icons/cr48-action-chemical.png b/kalzium/src/icons/cr48-action-chemical.png new file mode 100644 index 00000000..76c07896 Binary files /dev/null and b/kalzium/src/icons/cr48-action-chemical.png differ diff --git a/kalzium/src/icons/cr48-action-elempic.png b/kalzium/src/icons/cr48-action-elempic.png new file mode 100644 index 00000000..21225366 Binary files /dev/null and b/kalzium/src/icons/cr48-action-elempic.png differ diff --git a/kalzium/src/icons/cr48-action-energies.png b/kalzium/src/icons/cr48-action-energies.png new file mode 100644 index 00000000..34beef0a Binary files /dev/null and b/kalzium/src/icons/cr48-action-energies.png differ diff --git a/kalzium/src/icons/cr48-action-eqchem.png b/kalzium/src/icons/cr48-action-eqchem.png new file mode 100644 index 00000000..4df4b5bb Binary files /dev/null and b/kalzium/src/icons/cr48-action-eqchem.png differ diff --git a/kalzium/src/icons/cr48-action-glossary.png b/kalzium/src/icons/cr48-action-glossary.png new file mode 100644 index 00000000..122f6423 Binary files /dev/null and b/kalzium/src/icons/cr48-action-glossary.png differ diff --git a/kalzium/src/icons/cr48-action-isotopemap.png b/kalzium/src/icons/cr48-action-isotopemap.png new file mode 100644 index 00000000..9c888324 Binary files /dev/null and b/kalzium/src/icons/cr48-action-isotopemap.png differ diff --git a/kalzium/src/icons/cr48-action-legend.png b/kalzium/src/icons/cr48-action-legend.png new file mode 100644 index 00000000..e9b51c89 Binary files /dev/null and b/kalzium/src/icons/cr48-action-legend.png differ diff --git a/kalzium/src/icons/cr48-action-misc.png b/kalzium/src/icons/cr48-action-misc.png new file mode 100644 index 00000000..9386f46e Binary files /dev/null and b/kalzium/src/icons/cr48-action-misc.png differ diff --git a/kalzium/src/icons/cr48-action-orbits.png b/kalzium/src/icons/cr48-action-orbits.png new file mode 100644 index 00000000..697838b1 Binary files /dev/null and b/kalzium/src/icons/cr48-action-orbits.png differ diff --git a/kalzium/src/icons/cr48-action-overview.png b/kalzium/src/icons/cr48-action-overview.png new file mode 100644 index 00000000..da94ddd8 Binary files /dev/null and b/kalzium/src/icons/cr48-action-overview.png differ diff --git a/kalzium/src/icons/cr48-action-plot.png b/kalzium/src/icons/cr48-action-plot.png new file mode 100644 index 00000000..5e8fd76f Binary files /dev/null and b/kalzium/src/icons/cr48-action-plot.png differ diff --git a/kalzium/src/icons/cr48-action-sidebar.png b/kalzium/src/icons/cr48-action-sidebar.png new file mode 100644 index 00000000..b23a8770 Binary files /dev/null and b/kalzium/src/icons/cr48-action-sidebar.png differ diff --git a/kalzium/src/icons/cr48-action-spectrum.png b/kalzium/src/icons/cr48-action-spectrum.png new file mode 100644 index 00000000..8e7a93ee Binary files /dev/null and b/kalzium/src/icons/cr48-action-spectrum.png differ diff --git a/kalzium/src/icons/cr48-action-statematter.png b/kalzium/src/icons/cr48-action-statematter.png new file mode 100644 index 00000000..3daca346 Binary files /dev/null and b/kalzium/src/icons/cr48-action-statematter.png differ diff --git a/kalzium/src/icons/cr48-action-timeline.png b/kalzium/src/icons/cr48-action-timeline.png new file mode 100644 index 00000000..80ca53aa Binary files /dev/null and b/kalzium/src/icons/cr48-action-timeline.png differ diff --git a/kalzium/src/icons/cr48-action-tooltip.png b/kalzium/src/icons/cr48-action-tooltip.png new file mode 100644 index 00000000..fae1db9c Binary files /dev/null and b/kalzium/src/icons/cr48-action-tooltip.png differ diff --git a/kalzium/src/icons/crsc-action-calculate.svgz b/kalzium/src/icons/crsc-action-calculate.svgz new file mode 100644 index 00000000..6e194e93 Binary files /dev/null and b/kalzium/src/icons/crsc-action-calculate.svgz differ diff --git a/kalzium/src/icons/crsc-action-chemical.svgz b/kalzium/src/icons/crsc-action-chemical.svgz new file mode 100644 index 00000000..7358e162 Binary files /dev/null and b/kalzium/src/icons/crsc-action-chemical.svgz differ diff --git a/kalzium/src/icons/crsc-action-elempic.svgz b/kalzium/src/icons/crsc-action-elempic.svgz new file mode 100644 index 00000000..ba8949a6 Binary files /dev/null and b/kalzium/src/icons/crsc-action-elempic.svgz differ diff --git a/kalzium/src/icons/crsc-action-energies.svgz b/kalzium/src/icons/crsc-action-energies.svgz new file mode 100644 index 00000000..16b9f6e7 Binary files /dev/null and b/kalzium/src/icons/crsc-action-energies.svgz differ diff --git a/kalzium/src/icons/crsc-action-eqchem.svgz b/kalzium/src/icons/crsc-action-eqchem.svgz new file mode 100644 index 00000000..b1b31155 Binary files /dev/null and b/kalzium/src/icons/crsc-action-eqchem.svgz differ diff --git a/kalzium/src/icons/crsc-action-glossary.svgz b/kalzium/src/icons/crsc-action-glossary.svgz new file mode 100644 index 00000000..5b0c8f1e Binary files /dev/null and b/kalzium/src/icons/crsc-action-glossary.svgz differ diff --git a/kalzium/src/icons/crsc-action-isotopemap.svgz b/kalzium/src/icons/crsc-action-isotopemap.svgz new file mode 100644 index 00000000..96fb3121 Binary files /dev/null and b/kalzium/src/icons/crsc-action-isotopemap.svgz differ diff --git a/kalzium/src/icons/crsc-action-misc.svgz b/kalzium/src/icons/crsc-action-misc.svgz new file mode 100644 index 00000000..21d14d28 Binary files /dev/null and b/kalzium/src/icons/crsc-action-misc.svgz differ diff --git a/kalzium/src/icons/crsc-action-orbits.svgz b/kalzium/src/icons/crsc-action-orbits.svgz new file mode 100644 index 00000000..38ed6eb4 --- /dev/null +++ b/kalzium/src/icons/crsc-action-orbits.svgz @@ -0,0 +1,1119 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/kalzium/src/icons/crsc-action-overview.svgz b/kalzium/src/icons/crsc-action-overview.svgz new file mode 100644 index 00000000..8261cc4e Binary files /dev/null and b/kalzium/src/icons/crsc-action-overview.svgz differ diff --git a/kalzium/src/icons/crsc-action-plot.svgz b/kalzium/src/icons/crsc-action-plot.svgz new file mode 100644 index 00000000..15116f5f Binary files /dev/null and b/kalzium/src/icons/crsc-action-plot.svgz differ diff --git a/kalzium/src/icons/crsc-action-sidebar.svgz b/kalzium/src/icons/crsc-action-sidebar.svgz new file mode 100644 index 00000000..e5552c47 Binary files /dev/null and b/kalzium/src/icons/crsc-action-sidebar.svgz differ diff --git a/kalzium/src/icons/crsc-action-spectrum.svgz b/kalzium/src/icons/crsc-action-spectrum.svgz new file mode 100644 index 00000000..7967f757 Binary files /dev/null and b/kalzium/src/icons/crsc-action-spectrum.svgz differ diff --git a/kalzium/src/icons/crsc-action-statematter.svgz b/kalzium/src/icons/crsc-action-statematter.svgz new file mode 100644 index 00000000..2a80a8e1 Binary files /dev/null and b/kalzium/src/icons/crsc-action-statematter.svgz differ diff --git a/kalzium/src/icons/crsc-action-timeline.svgz b/kalzium/src/icons/crsc-action-timeline.svgz new file mode 100644 index 00000000..5b1b52fa Binary files /dev/null and b/kalzium/src/icons/crsc-action-timeline.svgz differ diff --git a/kalzium/src/icons/crsc-action-tooltip.svgz b/kalzium/src/icons/crsc-action-tooltip.svgz new file mode 100644 index 00000000..aa3f747a Binary files /dev/null and b/kalzium/src/icons/crsc-action-tooltip.svgz differ diff --git a/kalzium/src/icons/htmlview/Makefile.am b/kalzium/src/icons/htmlview/Makefile.am new file mode 100644 index 00000000..57763b1e --- /dev/null +++ b/kalzium/src/icons/htmlview/Makefile.am @@ -0,0 +1,3 @@ +appdatadir = $(kde_datadir)/kalzium/data/htmlview +appdata_DATA = characteristics.png density.png header.png icons.svg radius.png structure.png style.css mass.png book.png boilingpoint.png meltingpoint.png ionisation.png electronaffinity.png discovery.png abundance.png + diff --git a/kalzium/src/icons/htmlview/abundance.png b/kalzium/src/icons/htmlview/abundance.png new file mode 100644 index 00000000..20258695 Binary files /dev/null and b/kalzium/src/icons/htmlview/abundance.png differ diff --git a/kalzium/src/icons/htmlview/boilingpoint.png b/kalzium/src/icons/htmlview/boilingpoint.png new file mode 100644 index 00000000..3f0c7fcb Binary files /dev/null and b/kalzium/src/icons/htmlview/boilingpoint.png differ diff --git a/kalzium/src/icons/htmlview/book.png b/kalzium/src/icons/htmlview/book.png new file mode 100644 index 00000000..895d4545 Binary files /dev/null and b/kalzium/src/icons/htmlview/book.png differ diff --git a/kalzium/src/icons/htmlview/characteristics.png b/kalzium/src/icons/htmlview/characteristics.png new file mode 100644 index 00000000..a6ff407a Binary files /dev/null and b/kalzium/src/icons/htmlview/characteristics.png differ diff --git a/kalzium/src/icons/htmlview/density.png b/kalzium/src/icons/htmlview/density.png new file mode 100644 index 00000000..1475b70a Binary files /dev/null and b/kalzium/src/icons/htmlview/density.png differ diff --git a/kalzium/src/icons/htmlview/discovery.png b/kalzium/src/icons/htmlview/discovery.png new file mode 100644 index 00000000..c3b21c45 Binary files /dev/null and b/kalzium/src/icons/htmlview/discovery.png differ diff --git a/kalzium/src/icons/htmlview/electronaffinity.png b/kalzium/src/icons/htmlview/electronaffinity.png new file mode 100644 index 00000000..3082d02a Binary files /dev/null and b/kalzium/src/icons/htmlview/electronaffinity.png differ diff --git a/kalzium/src/icons/htmlview/header.png b/kalzium/src/icons/htmlview/header.png new file mode 100644 index 00000000..d9a23098 Binary files /dev/null and b/kalzium/src/icons/htmlview/header.png differ diff --git a/kalzium/src/icons/htmlview/icons.svg b/kalzium/src/icons/htmlview/icons.svg new file mode 100644 index 00000000..47645a26 --- /dev/null +++ b/kalzium/src/icons/htmlview/icons.svg @@ -0,0 +1,698 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/kalzium/src/icons/htmlview/ionisation.png b/kalzium/src/icons/htmlview/ionisation.png new file mode 100644 index 00000000..ab1c1fb3 Binary files /dev/null and b/kalzium/src/icons/htmlview/ionisation.png differ diff --git a/kalzium/src/icons/htmlview/mass.png b/kalzium/src/icons/htmlview/mass.png new file mode 100644 index 00000000..50277dde Binary files /dev/null and b/kalzium/src/icons/htmlview/mass.png differ diff --git a/kalzium/src/icons/htmlview/meltingpoint.png b/kalzium/src/icons/htmlview/meltingpoint.png new file mode 100644 index 00000000..0f1823e5 Binary files /dev/null and b/kalzium/src/icons/htmlview/meltingpoint.png differ diff --git a/kalzium/src/icons/htmlview/radius.png b/kalzium/src/icons/htmlview/radius.png new file mode 100644 index 00000000..20258695 Binary files /dev/null and b/kalzium/src/icons/htmlview/radius.png differ diff --git a/kalzium/src/icons/htmlview/structure.png b/kalzium/src/icons/htmlview/structure.png new file mode 100644 index 00000000..75d77db0 Binary files /dev/null and b/kalzium/src/icons/htmlview/structure.png differ diff --git a/kalzium/src/icons/htmlview/style.css b/kalzium/src/icons/htmlview/style.css new file mode 100644 index 00000000..4ef1cd77 --- /dev/null +++ b/kalzium/src/icons/htmlview/style.css @@ -0,0 +1,83 @@ +body +{ + font-family:'arial'; +} + +/* The outer div */ +div.chemdata +{ + border: 1px solid rgb(50,80,150); + /*border: 1px solid rgb(0,0,0); */ +/* width:400px;*/ + overflow:visible;; +} + +/* The header div */ +div.chemdata div +{ + background-image:url('header.png'); +} + +/* The table inside the header div */ +div.chemdata div table +{ + margin:0px; + width:100%; + color:rgb(240,240,240); + font-weight:bold; +} + +/* The td inside the header table */ +div.chemdata div table td +{ + padding-left:4px; +} + +/* The second td inside the header table */ +div.chemdata div table td+td +{ + text-align:right; + font-size:80%; +} + + +/* The table containing the characterstics */ +table.characterstics +{ + background-image:url('characteristics.png'); + background-repeat:repeat-y; + width:100%; +} + +/* The td's inside the characterstics-table */ +table.characterstics td +{ + padding:3px; + padding-left:5px; + vertical-align:middle; + text-align:center; +} + +table.isotopes td +{ + border-left:1px #000000 solid; + border-bottom:1px #000000 solid; +} + +table.isotopes +{ + border-right:1px #000000 solid; + border-top:1px #000000 solid; +} + +/* The second td inside the characterstics-table (text) */ +table.characterstics td+td +{ + text-align:left; +} + +/* Bold text inside the td's of the characterstics-table */ +table.characterstics td b +{ + color:rgb(80,80,80); +} diff --git a/kalzium/src/isotope.cpp b/kalzium/src/isotope.cpp new file mode 100644 index 00000000..b15e38cc --- /dev/null +++ b/kalzium/src/isotope.cpp @@ -0,0 +1,76 @@ +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ +#include "isotope.h" +#include "kalziumutils.h" + +#include +#include + +Isotope::Isotope( int neutrons, int protones, double percentage, double weight, double halflife, QString format, double alphadecay, double betaplusdecay, double betaminusdecay, double ecdecay, double alphapercentage, double betapluspercentage, double betaminuspercentage, double ecpercentage, QString spin, QString magmoment) +{ + m_neutrons = neutrons; + m_protones = protones; + m_percentage = percentage; + m_halflife = halflife; + m_format = format; + m_weight = weight; + m_alphadecay = alphadecay; + m_betaplusdecay = betaplusdecay; + m_betaminusdecay = betaminusdecay; + m_ecdecay = ecdecay; + + m_spin = spin; + m_magmoment = magmoment; + + m_alphapercentage = alphapercentage; + m_betapluspercentage = betapluspercentage; + m_betaminuspercentage = betaminuspercentage; + m_ecpercentage = ecpercentage; +} + +QString Isotope::halflifeAsString() +{ + QString halflife; + + if ( !seconds() )//years + { + if ( m_halflife > 1000000 ) + halflife = i18n("%1 million years").arg( KalziumUtils::localizedValue( m_halflife/1000000.0, 2 ) ); + if ( m_halflife > 1000000000 ) + halflife = i18n("%1 billion years").arg( KalziumUtils::localizedValue( m_halflife/1000000000.0, 2 ) ); + else + halflife = i18n("%1 years").arg( KalziumUtils::localizedValue( m_halflife, 2 ) ); + } + else + { + if ( m_halflife < 120 ) + halflife = i18n("%1 seconds").arg( KalziumUtils::localizedValue( m_halflife, 2 ) ); + else if ( m_halflife > 1000 ) + halflife = i18n("%1 minutes").arg( KalziumUtils::localizedValue( m_halflife/60.0, 2 ) ); + else if ( m_halflife > 3600 ) + halflife = i18n("%1 hours").arg( KalziumUtils::localizedValue( m_halflife/( 60*60 ), 2 ) ); + if ( m_halflife > 86400 ) //one day + halflife = i18n("%1 days").arg( KalziumUtils::localizedValue( m_halflife/( 60*60*24 ), 2 ) ); + if ( m_halflife > ( 31536000 * 2 ) ) //two year + halflife = i18n("%1 years").arg( KalziumUtils::localizedValue( m_halflife/( 3600.0*365 ), 2 ) ); + } + + return halflife; +} diff --git a/kalzium/src/isotope.h b/kalzium/src/isotope.h new file mode 100644 index 00000000..feed345f --- /dev/null +++ b/kalzium/src/isotope.h @@ -0,0 +1,244 @@ +#ifndef ISOTOPE_H +#define ISOTOPE_H +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include + +/** + * @author Carsten Niehaus + * @author Jörg Buchwald + * + * This class represents an Isotope with all its properties + */ +class Isotope +{ + public: + Isotope( int neutrons, + int protones, + double percentage, + double weight, + double halflife, + QString format, + double alphadecay, + double betaplusdecay, + double betaminusdecay, + double ecdecay, + double alphapercentage, + double betapluspercentage, + double betaminuspercentage, + double ecpercentage, + QString spin, + QString magmoment); + + bool seconds() const{ + if ( m_format == "seconds" ) + return true; + else + return false; + } + + /** + * @return the halflife period of the isotope it if has one. The format + * is defined by seconds() + */ + double halflife() const{ + return m_halflife; + } + + double percentage() const{ + return m_percentage; + } + + /** + * @return the number of neutrons the isotope has + */ + int neutrons() const{ + return m_neutrons; + } + + /** + * @return the number of protones the isotope has + */ + int protones() const{ + return m_protones; + } + + /** + * @return the number of nucleons of ths isotope + */ + int nucleons() const{ + return m_protones+m_neutrons; + } + + /** + * the weight of the isotope + */ + double weight() const{ + return m_weight; + } + + /** + * @return the energy of isotope's alpha decay + */ + double alphadecay() const{ + return m_alphadecay; + } + + /** + * @return the energy of isotope's beta plus decay + */ + double betaplusdecay() const{ + return m_betaplusdecay; + } + + /** + * @return the energy of isotope's beta-minus decay + */ + double betaminusdecay() const{ + return m_betaminusdecay; + } + + /** + * @return the energy of isotope's EC- decay + */ + double ecdecay() const{ + return m_ecdecay; + } + + QString spin() const{ + return m_spin; + } + + QString magmoment() const{ + return m_magmoment; + } + + /** + * @return the halflife as a QString. The format will be + * appended, for example "seconds" or "years" depending + * on the timeframe + */ + QString halflifeAsString(); + + /** + * @return the percentage of the betaminus decay + */ + double betaminuspercentage() const{ + return m_betaminuspercentage; + } + + /** + * @return the percentage of the betaplus decay + */ + double betapluspercentage() const{ + return m_betapluspercentage; + } + + /** + * @return the percentage of the alpha decay + */ + double alphapercentage() const{ + return m_alphapercentage; + } + + /** + * @return the percentage of the EC decay + */ + double ecpercentage() const{ + return m_ecpercentage; + } + + private: + /** + * it is either "years" or "seconds". Usually we use seconds. But some + * isotopes have half-lifes of billion of years. This simply + * doesn't fit into a unsigned int or double + */ + QString m_format; + + /** + * the weight of the isotope + */ + double m_weight; + + /** + * the half-life of an isotope, usually in seconds + * @see m_format + */ + double m_halflife; + + /** + * If 95.2% of the isotopes are of this type, this + * variable will have the value 95.2 + */ + double m_percentage; + + /** + * the number of neutrons + */ + int m_neutrons; + + /** + * the number of protones + */ + int m_protones; + + ///Specify if the decay is the energy + double m_alphadecay; + ///Specify if the decay is the energy + double m_betaplusdecay; + ///Specify if the decay is the energy + double m_betaminusdecay; + ///Specify if the decay is the energy + double m_ecdecay; + + + /** + *spin and parity + */ + QString m_spin; + + /** + * magnetic moment + */ + QString m_magmoment; + + /** + * the percentage with which the istope decays as alpha-rays + */ + double m_alphapercentage; + + /** + * the percentage with which the istope decays as beta-plus + */ + double m_betapluspercentage; + + /** + * the percentage with which the istope decays as beta-minus + */ + double m_betaminuspercentage; + /** + * the percentage with which the istope decays as EC + */ + double m_ecpercentage; +}; + +#endif // ISOTOPE_H diff --git a/kalzium/src/kalzium.cpp b/kalzium/src/kalzium.cpp new file mode 100644 index 00000000..613377cd --- /dev/null +++ b/kalzium/src/kalzium.cpp @@ -0,0 +1,578 @@ +/*************************************************************************** + copyright : (C) 2003, 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ +#include "kalzium.h" + +#ifdef HAVE_FACILE +#include "eqchemview.h" +#endif + +#include "element.h" +#include "prefs.h" +#include "settings_colors.h" +#include "settings_misc.h" +#include "settings_units.h" +#include "elementdataviewer.h" +#include "detailinfodlg.h" +#include "periodictableview.h" +#include "molcalcwidget.h" +#include "detailedgraphicaloverview.h" +#include "timewidget_impl.h" +#include "somwidget_impl.h" +#include "kalziumdataobject.h" +#include "kalziumutils.h" +#include "config.h" + +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include + +#define PerodicTableView_MARGIN 5 +#define IDS_ELEMENTINFO 7 + +Kalzium::Kalzium() + : KMainWindow( 0, "Kalzium" ) +{ + // reading the elements from file + KalziumDataObject::instance(); + + QWidget *centralWidget = new QWidget( this, "centralWidget" ); + m_pCentralLayout = new QVBoxLayout( centralWidget, PerodicTableView_MARGIN, -1, "CentralLayout" ); + + QScrollView *helperSV = new QScrollView(centralWidget); + m_pCentralLayout->addWidget(helperSV); + helperSV->viewport()->setPaletteBackgroundColor(paletteBackgroundColor()); + helperSV->setFrameShape(QFrame::NoFrame); + + m_PerodicTableView = new PerodicTableView( helperSV->viewport(), "PerodicTableView"); + helperSV->addChild( m_PerodicTableView ); + m_infoDialog = 0; + m_toolboxCurrent = 0; + + connect( m_PerodicTableView, SIGNAL( ElementClicked( int ) ), this, SLOT( openInformationDialog( int ) )); + connect( m_PerodicTableView, SIGNAL( MouseOver( int ) ), this, SLOT( slotStatusbar( int ) )); + + // layouting + setCentralWidget( centralWidget ); + centralWidget->show(); + + setupSidebars(); + setupActions(); + + // adding the libkdeedu catalog + KGlobal::locale()->insertCatalogue( "libkdeedu" ); + + // creating the glossary dialog and loading the glossaries we have + m_glossarydlg = new GlossaryDialog( true, this, "glossary" ); + QString dir = KGlobal::dirs()->findResourceDir( "data", "kalzium/data/" ); + QString picturepath = dir + "kalzium/data/bg.jpg"; + KURL u = dir + "kalzium/data/knowledge.xml"; + Glossary *g = Glossary::readFromXML( u ); + g->setName( i18n( "Knowledge" ) ); + g->setBackgroundPicture( picturepath ); + m_glossarydlg->addGlossary( g ); + u = dir + "kalzium/data/tools.xml"; + g = Glossary::readFromXML( u, dir+"kalzium/data/toolpics/" ); + g->setName( i18n( "Tools" ) ); + g->setBackgroundPicture( picturepath ); + m_glossarydlg->addGlossary( g ); + + setupStatusBar(); +} + +void Kalzium::setupActions() +{ + m_actionNoScheme = new KToggleAction(i18n("&No Color Scheme"), 0, this, SLOT(slotNoLook()), actionCollection(), "view_look_noscheme"); + + // the actions for the color schemes + m_actionGroups = new KToggleAction(i18n("Show &Groups"), 0, this, SLOT(slotLookGroups()), actionCollection(), "view_look_groups"); + m_actionBlocks = new KToggleAction(i18n("Show &Blocks"), 0, this, SLOT(slotLookBlocks()), actionCollection(), "view_look_blocks"); + m_actionAcid = new KToggleAction(i18n("Show &Acid Behavior"), 0, this, SLOT(slotLookAcidBehavior()), actionCollection(), "view_look_acid"); + m_actionFamily = new KToggleAction(i18n("Show &Family"), 0, this, SLOT(slotLookFamily()), actionCollection(), "view_look_family"); + m_actionCrystal = new KToggleAction(i18n("Show &Crystal Structures"), 0, this, SLOT(slotLookCrystal()), actionCollection(), "view_look_crystal"); + + //the actions for switching PerodicTableView + QStringList gradientlist; + gradientlist.append(i18n("Atomic Radius")); + gradientlist.append(i18n("Covalent Radius")); + gradientlist.append(i18n("van der Waals Radius")); + gradientlist.append(i18n("Atomic Mass")); + gradientlist.append(i18n("Density")); + gradientlist.append(i18n("Boiling Point")); + gradientlist.append(i18n("Melting Point")); + gradientlist.append(i18n("Electronegativity")); + gradientlist.append(i18n("Electron Affinity")); + gradient_action = new KSelectAction(i18n("&Gradient"), 0, this, 0, actionCollection(), "view_look_gradmenu"); + gradient_action->setItems(gradientlist); + connect (gradient_action, SIGNAL(activated(int)), this, SLOT(slotSwitchtoGradient(int))); + + // the actions for switching PerodicTableView + QStringList numlist; + numlist.append(i18n("No N&umeration")); + numlist.append(i18n("Show &IUPAC")); + numlist.append(i18n("Show &CAS")); + numlist.append(i18n("Show &Old IUPAC")); + numeration_action = new KSelectAction (i18n("&Numeration"), 0, this, 0, actionCollection(), "view_numerationtype"); + numeration_action->setItems(numlist); + numeration_action->setCurrentItem(Prefs::numeration()); + connect (numeration_action, SIGNAL(activated(int)), this, SLOT(slotSwitchtoNumeration(int))); + + m_SidebarAction = new KAction(i18n("Show &Sidebar"), "sidebar", 0, this, SLOT(slotShowHideSidebar()), actionCollection(), "view_sidebar"); + +#ifdef HAVE_FACILE + m_EQSolverAction = new KAction(i18n("&Equation Solver..."), "eqchem", 0, this, SLOT(slotShowEQSolver()), actionCollection(), "tools_eqsolver"); +#endif + + // tools actions + m_pPlotAction = new KAction(i18n("&Plot Data..."), "plot", 0, this, SLOT(slotPlotData()), actionCollection(), "tools_plotdata"); + m_pGlossaryAction = new KAction(i18n("&Glossary..."), "glossary", 0, this, SLOT(slotGlossary()), actionCollection(), "tools_glossary"); + + // other period view options + m_pLegendAction = new KAction(i18n("Show &Legend"), "legend", 0, this, SLOT(slotShowLegend()), actionCollection(), "view_legend"); + m_pTooltipAction = new KAction(i18n("Show &Tooltip"), "tooltip", 0, this, SLOT(slotEnableTooltips()), actionCollection(), "view_tooltip"); + + // the standard actions + KStdAction::preferences(this, SLOT(showSettingsDialog()), actionCollection()); + KStdAction::quit( kapp, SLOT (closeAllWindows()),actionCollection() ); + + slotShowScheme( Prefs::colorschemebox() ); + slotSwitchtoNumeration( Prefs::numeration() ); + + if ( Prefs::showsidebar() ) { + m_dockWin->show(); + m_SidebarAction->setText( i18n( "Hide &Sidebar" ) ); + } + else { + m_dockWin->hide(); + m_SidebarAction->setText( i18n( "Show &Sidebar" ) ); + } + + if ( Prefs::showlegend() ) { + m_PerodicTableView->showLegend(true); + m_pLegendAction->setText( i18n( "Hide &Legend" ) ); + } else + { + m_PerodicTableView->showLegend(false); + m_pLegendAction->setText( i18n( "Show &Legend" ) ); + } + + if ( Prefs::tooltip() ) { + m_PerodicTableView->setTooltipsEnabled( true ); + m_pTooltipAction->setText( i18n( "Hide &Tooltips" ) ); + } else + { + m_PerodicTableView->setTooltipsEnabled( false ); + m_pTooltipAction->setText( i18n( "Show &Tooltips" ) ); + } + + // set the shell's ui resource file + setXMLFile("kalziumui.rc"); + setupGUI(); +} + +void Kalzium::setupSidebars() +{ + m_dockWin = new QDockWindow( this ); + m_dockWin->setNewLine( true ); + m_dockWin->setFixedExtentWidth( 220 ); + m_dockWin->setResizeEnabled( true ); + m_dockWin->setFrameShape( QFrame::ToolBarPanel ); + m_dockWin->setCaption( i18n( "Sidebar" ) ); + m_dockWin->setCloseMode( QDockWindow::Always ); + + QToolBox *m_toolbox = new QToolBox( m_dockWin ); + m_dockWin->setWidget( m_toolbox ); + + QWidget *fake = new QWidget( m_dockWin ); + QVBoxLayout *lay = new QVBoxLayout( fake, 5 ); + lay->activate(); + m_detailWidget = new DetailedGraphicalOverview( fake, "DetailedGraphicalOverview" ); + m_detailWidget->setMinimumSize( 200, m_detailWidget->minimumSize().height() ); + connect( m_PerodicTableView, SIGNAL( MouseOver( int ) ), this, SLOT( slotSelectedNumber( int ) )); + lay->addWidget( m_detailWidget ); + lay->addItem( new QSpacerItem( 10, 10, QSizePolicy::Fixed, QSizePolicy::MinimumExpanding ) ); + m_toolbox->addItem( fake, SmallIcon( "overview" ), i18n( "Overview" ) ); + + m_calcWidget = new MolcalcWidget( m_dockWin, "molcalcwidget" ); + m_toolbox->addItem( m_calcWidget, SmallIcon( "calculate" ), i18n( "Calculate" ) ); + + m_timeWidget = new TimeWidgetIMPL( this, "TimeWidget" ); + connect( m_timeWidget->time_slider, SIGNAL( valueChanged( int ) ), + m_PerodicTableView, SLOT( setDate( int ) ) ); + connect( m_timeWidget->time_slider, SIGNAL( valueChanged( int ) ), + m_timeWidget, SLOT( slotChanged( int ) ) ); + connect( m_timeWidget->Number1, SIGNAL( valueChanged( int ) ), + m_timeWidget, SLOT( slotChanged( int ) ) ); + m_toolbox->addItem( m_timeWidget, SmallIcon( "timeline" ), i18n( "Timeline" ) ); + + m_somWidget = new SOMWidgetIMPL( this, "somWidget" ); + connect( m_somWidget->temp_slider, SIGNAL( valueChanged( int ) ), + m_PerodicTableView, SLOT( setTemperature( int ) ) ); + m_toolbox->addItem( m_somWidget, SmallIcon( "statematter" ), i18n( "State of Matter" ) ); + + connect( m_toolbox, SIGNAL( currentChanged( int ) ), this, SLOT( slotToolboxCurrentChanged( int ) ) ); + + moveDockWindow( m_dockWin, DockLeft ); + setDockEnabled( /*m_dockWin, */DockTop, false ); + setDockEnabled( /*m_dockWin, */DockBottom, false ); + m_dockWin->hide(); + connect( m_dockWin, SIGNAL(visibilityChanged(bool)), this, SLOT(slotSidebarVisibilityChanged(bool))); + +} + +void Kalzium::slotGlossary() +{ + m_glossarydlg->show(); +} + +void Kalzium::slotShowEQSolver() +{ +#ifdef HAVE_FACILE + EQChemDialog *dlg = new EQChemDialog( this ); + + QWidget *page = new QWidget( dlg ); + dlg->setMainWidget( page ); + QVBoxLayout *vbox = new QVBoxLayout( page , 0, KDialogBase:: spacingHint() ); + + eqchemView *eqsolver = new eqchemView( page ); + eqsolver->setMinimumSize( 600,400 ); + + vbox->addWidget( eqsolver ); + connect(dlg, SIGNAL(applyClicked()), eqsolver, SLOT(compute())); + dlg->show(); +#endif +} + +void Kalzium::slotPlotData() +{ + ElementDataViewer *edw = new ElementDataViewer( this, "edw" ); + edw->show(); +} + +void Kalzium::slotEnableTooltips() +{ + bool enabled = m_PerodicTableView->tooltipsEnabled(); + enabled = !enabled; + + if ( enabled ) + m_pTooltipAction->setText( i18n( "Hide &Tooltips" ) ); + else + m_pTooltipAction->setText( i18n( "Show &Tooltips" ) ); + + m_PerodicTableView->setTooltipsEnabled( enabled ); + + Prefs::setTooltip( enabled ); + Prefs::writeConfig(); +} + +void Kalzium::slotShowLegend() +{ + if(m_PerodicTableView->showLegend()) + { + m_PerodicTableView->showLegend(false); + m_pLegendAction->setText( i18n( "Show &Legend" ) ); + } + else + { + m_PerodicTableView->showLegend(true); + m_pLegendAction->setText( i18n( "Hide &Legend" ) ); + } + m_PerodicTableView->update(); + + //save the settings + Prefs::setShowlegend( m_PerodicTableView->showLegend() ); + Prefs::writeConfig(); + + //JH: redraw the full table next time + setFullDraw(); +} + +void Kalzium::slotShowHideSidebar() +{ + if( m_dockWin->isShown() ) + { + m_dockWin->hide(); + Prefs::setShowsidebar( false ); + m_SidebarAction->setText( i18n( "Show &Sidebar" ) ); + } + else + { + m_dockWin->show(); + Prefs::setShowsidebar( true ); + m_SidebarAction->setText( i18n( "Hide &Sidebar" ) ); + } + + //save the settings + Prefs::writeConfig(); +} + +void Kalzium::slotShowScheme(int i) +{ + switch ( i ) + { + case PerodicTableView::GROUPS: + m_actionGroups->setChecked( true ); + m_PerodicTableView->setLook( PerodicTableView::GROUPS ); + break; + case PerodicTableView::BLOCK: + m_actionBlocks->setChecked( true ); + m_PerodicTableView->setLook( PerodicTableView::BLOCK ); + break; + case PerodicTableView::ACIDIC: + m_actionAcid->setChecked( true ); + m_PerodicTableView->setLook( PerodicTableView::ACIDIC ); + break; + case PerodicTableView::FAMILY: + m_actionFamily->setChecked( true ); + m_PerodicTableView->setLook( PerodicTableView::FAMILY ); + break; + case PerodicTableView::CRYSTAL: + m_actionCrystal->setChecked( true ); + m_PerodicTableView->setLook( PerodicTableView::CRYSTAL ); + break; + case PerodicTableView::GRADIENT: + gradient_action->setCurrentItem( Prefs::gradient()-1 ); + m_PerodicTableView->setLook( PerodicTableView::GRADIENT, Prefs::gradient() ); + break; + case PerodicTableView::NOCOLOUR: + default: + m_actionNoScheme->setChecked( true ); + m_PerodicTableView->setLook( PerodicTableView::NOCOLOUR ); + } +} + +void Kalzium::slotSwitchtoGradient( int index ) +{ + m_PerodicTableView->setLook( PerodicTableView::GRADIENT, index + 1 ); + m_actionNoScheme->setChecked( false ); + m_actionGroups->setChecked( false ); + m_actionBlocks->setChecked( false ); + m_actionAcid->setChecked( false ); + m_actionFamily->setChecked( false ); + m_actionCrystal->setChecked( false ); + m_pLegendAction->setEnabled( false ); + + Prefs::setGradient(index + 1); + Prefs::writeConfig(); +} + +void Kalzium::slotSwitchtoNumeration( int index ) +{ + m_PerodicTableView->setNumerationType( ( PerodicTableView::NUMERATIONTYPE )index ); + Prefs::setNumeration(index); + Prefs::writeConfig(); + + //JH: redraw the full table next time + setFullDraw(); +} + +void Kalzium::showSettingsDialog() +{ + if (KConfigDialog::showDialog("settings")) + return; + + //KConfigDialog didn't find an instance of this dialog, so lets create it : + KConfigDialog *dialog = new KConfigDialog(this,"settings", Prefs::self()); + connect( dialog, SIGNAL( settingsChanged() ), this , SLOT( slotUpdateSettings() ) ); + connect( dialog, SIGNAL( settingsChanged() ), m_somWidget, SLOT( reloadUnits() ) ); + dialog->addPage( new setColors( 0, "colors_page"), i18n("Colors"), "colorize"); + dialog->addPage( new setupUnits( 0, "units_page"), i18n("Units"), "gear"); + dialog->addPage( new setupMisc( 0, "miscpage" ), i18n( "Miscellaneous" ), "misc" ); + dialog->show(); +} + +void Kalzium::slotUpdateSettings() +{ + m_PerodicTableView->reloadColours(); + m_PerodicTableView->setFullDraw(); +} + +void Kalzium::setupStatusBar() +{ + statusBar()->insertItem( "" , IDS_ELEMENTINFO, 1, false ); + statusBar()->setItemAlignment( IDS_ELEMENTINFO, AlignRight ); + statusBar()->show(); +} + +void Kalzium::slotStatusbar( int num ) +{ + Element *e = KalziumDataObject::instance()->element( num ); + statusBar()->changeItem( i18n( "For example: \"Carbon (6), Mass: 12.0107 u\"", "%1 (%2), Mass: %3 u" ).arg( e->elname() ).arg(e->number() ).arg( KalziumUtils::localizedValue( e->mass(), 6 ) ) , IDS_ELEMENTINFO ); +} + +void Kalzium::openInformationDialog( int number ) +{ + if ( m_PerodicTableView->showTooltip() ) + { + kdDebug() << "Handling Information Dialog" << endl; + + if (m_infoDialog) + m_infoDialog->setElement(KalziumDataObject::instance()->element(number)); + else + { + m_infoDialog = new DetailedInfoDlg( + KalziumDataObject::instance()->element(number), + this, "detailedDlg" ); + + // Remove the selection when this dialog finishes or hides. + connect(m_infoDialog, SIGNAL(hidden()), + m_PerodicTableView, SLOT(unSelect())); + connect(m_infoDialog, SIGNAL(elementChanged(int)), + m_PerodicTableView, SLOT(selectElement(int))); + } + m_infoDialog->show(); + } +} + +void Kalzium::slotNoLook() +{ + m_PerodicTableView->setLook( PerodicTableView::NOCOLOUR ); + gradient_action->setCurrentItem( -1 ); + m_actionGroups->setChecked( false ); + m_actionBlocks->setChecked( false ); + m_actionAcid->setChecked( false ); + m_actionFamily->setChecked( false ); + m_actionCrystal->setChecked( false ); + m_pLegendAction->setEnabled( true ); +} + +void Kalzium::slotLookGroups() +{ + m_PerodicTableView->setLook( PerodicTableView::GROUPS ); + gradient_action->setCurrentItem( -1 ); + m_actionNoScheme->setChecked( false ); + m_actionBlocks->setChecked( false ); + m_actionAcid->setChecked( false ); + m_actionFamily->setChecked( false ); + m_actionCrystal->setChecked( false ); + m_pLegendAction->setEnabled( true ); +} + +void Kalzium::slotLookBlocks() +{ + m_PerodicTableView->setLook( PerodicTableView::BLOCK ); + gradient_action->setCurrentItem( -1 ); + m_actionNoScheme->setChecked( false ); + m_actionGroups->setChecked( false ); + m_actionAcid->setChecked( false ); + m_actionFamily->setChecked( false ); + m_actionCrystal->setChecked( false ); + m_pLegendAction->setEnabled( true ); +} + +void Kalzium::slotLookAcidBehavior() +{ + m_PerodicTableView->setLook( PerodicTableView::ACIDIC ); + gradient_action->setCurrentItem( -1 ); + m_actionNoScheme->setChecked( false ); + m_actionGroups->setChecked( false ); + m_actionBlocks->setChecked( false ); + m_actionFamily->setChecked( false ); + m_actionCrystal->setChecked( false ); + m_pLegendAction->setEnabled( true ); +} + +void Kalzium::slotLookFamily() +{ + m_PerodicTableView->setLook( PerodicTableView::FAMILY ); + gradient_action->setCurrentItem( -1 ); + m_actionNoScheme->setChecked( false ); + m_actionGroups->setChecked( false ); + m_actionBlocks->setChecked( false ); + m_actionAcid->setChecked( false ); + m_actionCrystal->setChecked( false ); + m_pLegendAction->setEnabled( true ); +} + +void Kalzium::slotLookCrystal() +{ + m_PerodicTableView->setLook( PerodicTableView::CRYSTAL ); + gradient_action->setCurrentItem( -1 ); + m_actionNoScheme->setChecked( false ); + m_actionGroups->setChecked( false ); + m_actionBlocks->setChecked( false ); + m_actionAcid->setChecked( false ); + m_actionFamily->setChecked( false ); + m_pLegendAction->setEnabled( true ); +} + +void Kalzium::setFullDraw() +{ + m_PerodicTableView->setFullDraw(); +} + +void Kalzium::slotToolboxCurrentChanged( int id ) +{ + m_PerodicTableView->unSelect(); + m_PerodicTableView->setTimeline( false ); + m_PerodicTableView->activateSOMMode( false ); + + switch ( id ) + { + case 0: // nothing + break; + case 1: // molcalc + break; + case 2: // timeline + m_PerodicTableView->setTimeline( true ); + m_PerodicTableView->setDate( m_timeWidget->time_slider->value() ); + break; + case 3: // state of matter + m_PerodicTableView->activateSOMMode( true ); + m_PerodicTableView->setTemperature( m_somWidget->temp_slider->value() ); + break; + } + if ( m_dockWin->isShown() ) + m_toolboxCurrent = id; +} + +void Kalzium::slotSelectedNumber( int num ) +{ + m_detailWidget->setElement( KalziumDataObject::instance()->element( num ) ); +} + +void Kalzium::slotSidebarVisibilityChanged( bool visible ) +{ + if( visible ) + slotToolboxCurrentChanged( m_toolboxCurrent ); + else + slotToolboxCurrentChanged( 0 ); + + //save the settings + Prefs::setShowsidebar( m_dockWin->isShown() ); + Prefs::writeConfig(); + + //JH: redraw the full table next time + setFullDraw(); +} + +Kalzium::~Kalzium() +{ +} + +#include "kalzium.moc" diff --git a/kalzium/src/kalzium.desktop b/kalzium/src/kalzium.desktop new file mode 100644 index 00000000..840cf11d --- /dev/null +++ b/kalzium/src/kalzium.desktop @@ -0,0 +1,128 @@ +# KDE Config File +[Desktop Entry] +Type=Application +Exec=kalzium -caption "%c" %i %m +Icon=kalzium +DocPath=kalzium/index.html +Comment=KDE Periodic Table of Elements +Comment[be]=Перыядычная табліца элементаў KDE +Comment[bg]=Таблица на химическите елементи +Comment[bn]=কে.ডি.ই. উপস্থাপিত পদার্থের পর্যায় সারণী +Comment[bs]=KDE periodna tablica elemenata +Comment[ca]=Taula periòdica dels elements per a KDE +Comment[cs]=Periodická tabulka prvků pro KDE +Comment[csb]=Cządowi ùstôw pierwińców +Comment[da]=Det periodiske system af grundstoffer for KDE +Comment[de]=Periodensystem der Elemente +Comment[el]=Περιοδικός πίνακας των στοιχείων του KDE +Comment[eo]=KDE perioda tabelo de la elementoj +Comment[es]=Tabla periódica de los elementos de KDE +Comment[et]=KDE keemiliste elementide tabel +Comment[eu]=Elemtuen taula periodikoa +Comment[fa]=جدول تناوبی عناصر KDE +Comment[fi]=Alkuaineiden jaksollinen järjestelmä +Comment[fr]=Classification périodique des éléments de KDE +Comment[ga]=Tábla Peiriadach KDE +Comment[gl]=Táboa periódica dos elementos para KDE +Comment[he]=הטבלה המחזורית של היסודות של KDE +Comment[hr]=KDE periodni sustav elemenata +Comment[hu]=KDE-alapú periódusos rendszer +Comment[is]=KDE Lotukerfi +Comment[it]=Tavola periodica degli elementi per KDE +Comment[ja]=元素周期表 +Comment[ka]=ელემენტების პერიოდული ცხრილი +Comment[km]=តារាង​ខួប​នៃ​ធាតុ​គីមី​របស់ KDE +Comment[lt]=KDE periodinė elementų lentelė +Comment[ms]=Jadual Berkala Elemen KDE +Comment[nb]=Grunnstoffenes periodiske system i KDE +Comment[nds]=Periodensysteem vun de Elementen för KDE +Comment[ne]=तत्वको KDE आवधिक तालिका +Comment[nl]=Periodieke Tabel der Elementen +Comment[nn]=Det periodiske system for KDE +Comment[pa]=ਤੱਤਾਂ ਲਈ KDE ਆਵਰਤੀ ਸਾਰਣੀ +Comment[pl]=Układ okresowy pierwiastków dla KDE +Comment[pt]=Tabela Periódica de Elementos do KDE +Comment[pt_BR]=Tabela periódica dos elementos do KDE +Comment[ru]=Периодическая система Менделеева +Comment[sk]=KDE Periodická tabuľka prvkov +Comment[sl]=Periodni sistem elementov +Comment[sr]=Периодни систем елемената за KDE +Comment[sr@Latn]=Periodni sistem elemenata za KDE +Comment[sv]=Periodiska systemet för KDE +Comment[tr]=Elementlerin Periyodik Cetveli +Comment[uk]=Періодична таблиця елементів +Comment[vi]=Bảng Tuần hoàn các Nguyên tố Hoá học KDE +Comment[zh_CN]=KDE 的元素周期表 +Comment[zh_TW]=KDE 元素週期表 +Terminal=false +Name=Kalzium +Name[bn]=ক্যালজিয়াম +Name[csb]=Kalzium (Programa do ùczbë pierwińców) +Name[eo]=Kalziumo +Name[fo]=Kalsium +Name[hi]=के-एल्जियम +Name[lv]=Kalcium +Name[mk]=Калциум +Name[mn]=Кальци +Name[ne]=काल्जिउम +Name[pa]=ਕੈਲਜ਼ੀਅਮ +Name[pl]=Kalzium (Program do nauki pierwiastków chemicznych) +Name[ta]=கால்சியம் +GenericName=Periodic Table of Elements +GenericName[af]=Periodieke Tabel van Elemente +GenericName[ar]=الجدول الدوري للعناصر +GenericName[be]=Перыядычная табліца элементаў +GenericName[bg]=Таблица на химическите елементи +GenericName[bn]=পদার্থের পর্যায় সারণী +GenericName[bs]=Periodna tablica elemenata +GenericName[ca]=Taula periòdica dels elements +GenericName[cs]=Periodická tabulka +GenericName[csb]=Cządowi ùstôw pierwińców +GenericName[cy]=Tabl yr Elfennau +GenericName[da]=Grundstoffernes periodiske system +GenericName[de]=Elektronisches Periodensystem +GenericName[el]=Περιοδικός πίνακας των στοιχείων +GenericName[eo]=Perioda tabelo de la elementoj +GenericName[es]=Tabla periódica de los elementos +GenericName[et]=Keemiliste elementide tabel +GenericName[eu]=Elemtuen taula periodikoa +GenericName[fa]=جدول تناوبی عناصر +GenericName[fi]=Alkuaineiden jaksollinen järjestelmä +GenericName[fr]=Classification périodique des éléments +GenericName[ga]=An Tábla Peiriadach +GenericName[gl]=Táboa Periódica dos Elementos +GenericName[he]=הטבלה המחזורית של היסודות +GenericName[hi]=तत्वों के पीरियाडिक टेबल +GenericName[hr]=Periodni sustav elemenata +GenericName[hu]=Periódusos rendszer +GenericName[is]=Lotukerfið +GenericName[it]=Tavola periodica degli elementi +GenericName[ja]=元素周期表 +GenericName[ka]=ელემენტების პერიოდული ცხრილი +GenericName[km]=តារាង​ខួម​នៃ​ធាតុ​គីមី +GenericName[lt]=Periodinė elementų lentelė +GenericName[mk]=Периодична табела на елементи +GenericName[ms]=Jadual Berkala bagi Elemen +GenericName[nb]=Grunnstoffenes periodiske system +GenericName[nds]=Periodensysteem vun de Elementen +GenericName[ne]=तत्वको आवधिक तालिका +GenericName[nl]=Periodieke Tabel der Elementen +GenericName[nn]=Det periodiske systemet +GenericName[pa]=ਇਕਾਈਆਂ ਦੀ ਆਵਰਤੀ ਸਾਰਣੀ +GenericName[pl]=Tablica okresowa pierwiastków +GenericName[pt]=Tabela Periódica de Elementos +GenericName[pt_BR]=Tabela periódica dos elementos +GenericName[ru]=Периодическая система Менделеева +GenericName[sk]=Periodická tabuľka prvkov +GenericName[sl]=Periodna tabela elementov +GenericName[sr]=Периодни систем елемената +GenericName[sr@Latn]=Periodni sistem elemenata +GenericName[sv]=Periodiska systemet +GenericName[ta]=பொருட்களின் கால அட்டவணை +GenericName[tg]=Системаи даври элементҳо +GenericName[tr]=Periyodik Cetvel +GenericName[uk]=Періодична таблиця елементів +GenericName[vi]=Bảng Tuần hoàn các Nguyên tố +GenericName[zh_CN]=元素周期表 +GenericName[zh_TW]=元素週期表 +Categories=Qt;KDE;Education;Science; diff --git a/kalzium/src/kalzium.h b/kalzium/src/kalzium.h new file mode 100644 index 00000000..5837607b --- /dev/null +++ b/kalzium/src/kalzium.h @@ -0,0 +1,189 @@ +/*************************************************************************** + copyright : (C) 2003, 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ +#ifndef _KALZIUM_H_ +#define _KALZIUM_H_ + +#ifdef HAVE_CONFIG_H +#include +#endif + +#include + +class KSelectAction; +class KToggleAction; +class QuizsettingsDlg; +class SliderWidget; +class QToolBox; +class QVBoxLayout; +class QDockWindow; +class TempSlider; +class DetailedInfoDlg; +class PerodicTableView; +class MolcalcWidget; +class DetailedGraphicalOverview; +class TimeWidgetIMPL; +class SOMWidgetIMPL; +class GlossaryDialog; + +/** + * @short Application Main Window + * @author Carsten Niehaus + * @version 1.2 + * + * This class connects the parts of kalzium. All actions will + * be set, the menu generated and so on. + */ +class Kalzium : public KMainWindow +{ + Q_OBJECT + public: + /** + * Default Constructor + */ + Kalzium(); + + /** + * Default Destructor + */ + virtual ~Kalzium(); + + private: + class privatedata; + friend class privatedata; + privatedata* pd; + + DetailedInfoDlg *m_infoDialog; + + /** + * this pointer points to the PerodicTableView. + */ + PerodicTableView *m_PerodicTableView; + + /** + *initialize actions + */ + void setupActions(); + + /** + *initialize the sidebars + */ + void setupSidebars(); + + /** + * Signal the PerodicTableView that it should do a full draw operation + */ + void setFullDraw(); + + /** + * all KActions Kalzium uses + */ + KSelectAction *gradient_action; + KSelectAction *numeration_action; + KAction *m_pPlotAction, + *m_pGlossaryAction; + + KAction *m_pTooltipAction; + KAction *m_pLegendAction; + KAction *m_SidebarAction; + KAction *m_EQSolverAction; + + KToggleAction *m_actionNoScheme; + KToggleAction *m_actionGroups; + KToggleAction *m_actionBlocks; + KToggleAction *m_actionAcid; + KToggleAction *m_actionFamily; + KToggleAction *m_actionCrystal; + + /** + * the layout of the central Widget ( CentralWidget ) + */ + QVBoxLayout *m_pCentralLayout; + + MolcalcWidget *m_calcWidget; + + TimeWidgetIMPL *m_timeWidget; + + SOMWidgetIMPL *m_somWidget; + + DetailedGraphicalOverview *m_detailWidget; + + QDockWindow *m_dockWin; + QToolBox *m_toolbox; + int m_toolboxCurrent; + + GlossaryDialog *m_glossarydlg; + + private slots: + /** + * opens the information dialog for the element @p number + */ + void openInformationDialog( int number ); + + void slotStatusbar( int num ); + void setupStatusBar(); + + + /** + * this slot switches Kalzium to the selected color scheme + */ + void slotShowScheme(int); + + void slotShowEQSolver(); + + void slotShowLegend(); + + /** + * Hide or show the tooltips + */ + void slotEnableTooltips(); + + /** + * start the glossary + */ + void slotGlossary(); + + void slotSwitchtoNumeration(int); + + /** + * this will make the periodic table display the gradient + * defined by @p int gradient + */ + void slotSwitchtoGradient(int gradient); + + void slotPlotData(); + + void slotUpdateSettings(); + + void slotNoLook(); + + void slotLookGroups(); + void slotLookBlocks(); + void slotLookAcidBehavior(); + void slotLookFamily(); + void slotLookCrystal(); + + /** + * These slots are for the standard actions + */ + void showSettingsDialog(); + + void slotToolboxCurrentChanged(int); + + void slotSelectedNumber(int); + + void slotShowHideSidebar(); + + void slotSidebarVisibilityChanged(bool); +}; + +#endif // _KALZIUM_H_ diff --git a/kalzium/src/kalzium.kcfg b/kalzium/src/kalzium.kcfg new file mode 100644 index 00000000..d8f1321e --- /dev/null +++ b/kalzium/src/kalzium.kcfg @@ -0,0 +1,220 @@ + + + + + + + Select the PSE you want + 0 + + + + Select the color scheme you prefer by clicking on the corresponding radio button + 1 + + + + Select the gradient you want by clicking on the menu entry + 1 + + + + Select the numeration you want + 1 + + + + Show or hide the legend + true + + + + Show or hide the tooltips + true + + + + Display the atomic mass in the PSE + 0 + + + + + + Selects the color of the elements if no scheme is selected + #b4adff + + + + Selects the color of liquid elements + #b4adff + + + + Selects the color of solid elements + #FF5255 + + + + Selects the color of vaporous elements + #5CFF46 + + + + Selects the color of radioactive elements + #FFFFFF + + + + Selects the color of artificial elements + #FFA94E + + + + Selects the color of the elements in block s + #be72ee + + + + Selects the color of the elements in block p + #62ee25 + + + + Selects the color of the elements in block d + #f4fd40 + + + + Selects the color of the elements in block f + #ee5ab8 + + + + Selects the color of the elements in group 1 + #dd00ee + + + + Selects the color of the elements in group 2 + #2284ee + + + + Selects the color of the elements in group 3 + #91ee7f + + + + Selects the color of the elements in group 4 + #c80000 + + + + Selects the color of the elements in group 5 + #eec809 + + + + Selects the color of the elements in group 6 + #486f8b + + + + Selects the color of the elements in group 7 + #ee0842 + + + + Selects the color of the elements in group 8 + #b4adff + + + + Selects the color of the elements with acidic behaviour + #b4adff + + + + Selects the color of the elements with basic behaviour + #d3ee22 + + + + Selects the color of the elements with amphoteric behaviour + #EE4346 + + + + Selects the color of the elements with neutral behaviour + #44EE2E + + + + Selects the color of the alkali metals + #FFFF2D + + + + Selects the color of the rare-earth elements + #5B2EFF + + + + Selects the color of the non-metal elements + #CCBE2C + + + + Selects the color of the alkaline earth metals + #3DD9DE + + + + Selects the color of the metals which do not fit into the other categories + #546F56 + + + + Selects the color of the halogen elements + #5BF4A0 + + + + Selects the color of the transition elements + #97F805 + + + + Selects the color of the noble gases + #C56188 + + + + Selects the color of the metalloid elements + #E8D888 + + + + + + Use eV or kJ/mol + 0 + + + + Select the scale for the temperature + 0 + + + + + + Show or hide the sidebar + true + + + diff --git a/kalzium/src/kalziumdataobject.cpp b/kalzium/src/kalziumdataobject.cpp new file mode 100644 index 00000000..3d1a33bf --- /dev/null +++ b/kalzium/src/kalziumdataobject.cpp @@ -0,0 +1,264 @@ +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "kalziumdataobject.h" + +#include "isotope.h" +#include "spectrum.h" + +#include +#include + +#include +#include +#include +#include +#include +#include + +KalziumDataObject* KalziumDataObject::instance() +{ + static KalziumDataObject kdo; + return &kdo; +} + +KalziumDataObject::KalziumDataObject() +{ + QDomDocument doc( "datadocument" ); + + KURL url; + url.setPath( locate("data", "kalzium/data/")); + url.setFileName( "data.xml" ); + QFile layoutFile( url.path() ); + + if (!layoutFile.exists()) + { + kdDebug() << "data.xml not found, exiting" << endl; + kapp->exit(0); + return; + } + + if (!layoutFile.open(IO_ReadOnly)) + { + kdDebug() << "data.xml IO-error" << endl; + return; + } + + // Check if the document is well-formed + if (!doc.setContent(&layoutFile)) + { + kdDebug() << "wrong xml" << endl; + layoutFile.close(); + return; + } + layoutFile.close(); + + ElementList = readData( doc ); + m_numOfElements = ElementList.count(); +} + +KalziumDataObject::~KalziumDataObject() +{ +} + +Element* KalziumDataObject::element( int number ) +{ + // checking that we are requesting a valid element + if ( ( number <= 0 ) || ( number > m_numOfElements ) ) + return 0; + return *( ElementList.at( number-1 ) ); +} + +EList KalziumDataObject::readData( QDomDocument &dataDocument ) +{ + EList list; + QDomNodeList elementNodes; //the list of all element + QDomElement domElement; //a single element + + //read in all elements + elementNodes = dataDocument.elementsByTagName( "element" ); + + const uint count = elementNodes.count(); + + for ( uint i = 0; i < count; ++i ) + {//iterate through all elements + domElement = ( const QDomElement& ) elementNodes.item( i ).toElement(); + + double mass = domElement.namedItem( "mass" ).toElement().text().toDouble(); + double en = domElement.namedItem( "electronegativity" ).toElement().text().toDouble(); + double ea = domElement.namedItem( "electronaffinity" ).toElement().text().toDouble(); + double mp = domElement.namedItem( "meltingpoint" ).toElement().text().toDouble(); + double bp = domElement.namedItem( "boilingpoint" ).toElement().text().toDouble(); + double density = domElement.namedItem( "density" ).toElement().text().toDouble(); + double covalent_radius = domElement.namedItem( "radius" ).namedItem( "covalent" ).toElement().text().toDouble(); + //van der Waals-Radius + double vdw_radius = domElement.namedItem( "radius" ).namedItem( "vdw" ).toElement().text().toDouble(); + double atomic_radius = domElement.namedItem( "radius" ).namedItem( "atomic" ).toElement().text().toDouble(); + double ionic_radius = domElement.namedItem( "radius" ).namedItem( "ionic" ).toElement().text().toDouble(); + QString ionic_charge = domElement.namedItem( "radius" ).namedItem( "ionic" ).toElement().attributeNode( "charge" ).value(); + + int bio = domElement.namedItem( "biologicalmeaning" ).toElement().text().toInt(); + int radioactive = domElement.namedItem( "radioactive" ).toElement().text().toInt(); + int period = domElement.namedItem( "period" ).toElement().text().toInt(); + int artificial = domElement.namedItem( "artificial" ).toElement().text().toInt(); + int date = domElement.namedItem( "date" ).toElement().text().toInt(); + int number = domElement.namedItem( "number" ).toElement().text().toInt(); + int abundance = domElement.namedItem( "abundance" ).toElement().text().toInt(); + + QString scientist = domElement.namedItem( "date" ).toElement().attributeNode( "scientist" ).value(); + QString crystal = domElement.namedItem( "crystalstructure" ).toElement().text(); + + QDomElement nameE = domElement.namedItem( "name" ).toElement(); + QString name = nameE.text(); + QString origin = i18n( nameE.attributeNode( "origin" ).value().utf8() ); + + QString block = domElement.namedItem( "block" ).toElement().text(); + QString group = domElement.namedItem( "group" ).toElement().text(); + QString family = domElement.namedItem( "family" ).toElement().text(); + QString orbits = domElement.namedItem( "orbits" ).toElement().text(); + QString symbol = domElement.namedItem( "symbol" ).toElement().text(); + QString oxydation = domElement.namedItem( "oxydation" ).toElement().text(); + QString acidicbehaviour = domElement.namedItem( "acidicbehaviour" ).toElement().text(); + + QDomNodeList elist = domElement.elementsByTagName( "energy" ); + QValueList ionlist; + for( uint i = 0; i < elist.length(); i++ ) + { + ionlist.append( elist.item( i ).toElement().text().toDouble() ); + } + + //now read in all the date for the isotopes + QDomNodeList isotopelist = domElement.elementsByTagName( "isotope" ); + QValueList isolist; + for( uint i = 0; i < isotopelist.length(); i++ ) + { + QDomElement iso = isotopelist.item( i ).toElement(); + double halflife = iso.attributeNode( "halflife" ).value().toDouble(); + double weight = iso.attributeNode( "weight" ).value().toDouble(); + QString format = iso.attributeNode( "halflifeformat" ).value(); + int neutrons = iso.attributeNode( "neutron" ).value().toInt(); + double percentage = iso.attributeNode( "percentage" ).value().toDouble(); + double alphapercentage = iso.attributeNode( "alphapercentage" ).value().toDouble(); + double betapluspercentage = iso.attributeNode( "betapluspercentage" ).value().toDouble(); + double betaminuspercentage = iso.attributeNode( "betaminuspercentage" ).value().toDouble(); + double ecpercentage = iso.attributeNode( "ecpercentage" ).value().toDouble(); + double alphadecay = iso.attributeNode( "alphadecay" ).value().toDouble(); + double betaplusdecay = iso.attributeNode( "betaplusdecay" ).value().toDouble(); + double betaminusdecay = iso.attributeNode( "betaminusdecay" ).value().toDouble(); + double ecdecay = iso.attributeNode( "ecdecay" ).value().toDouble(); + QString spin = iso.attributeNode( "spin" ).value(); + QString magmoment = iso.attributeNode( "magmoment" ).value(); + + + Isotope *isotope = new Isotope( neutrons, + number, + percentage, + weight, + halflife, + format, + alphadecay, + betaplusdecay, + betaminusdecay, + ecdecay, + alphapercentage, + betapluspercentage, + betaminuspercentage, + ecpercentage, + spin, + magmoment ); + isolist.append( isotope ); + } + + QDomNodeList spectrumList = domElement.namedItem( "spectra" ).toElement().elementsByTagName( "spectrum" ); + + Element *e = new Element(); + e->setDate(date); + e->setBiologicalMeaning(bio); + e->setNumber( number ); + e->setName(i18n(name.utf8())); + e->setRadius( Element::ATOMIC, atomic_radius ); + e->setRadius( Element::IONIC, ionic_radius, ionic_charge ); + e->setRadius( Element::COVALENT, covalent_radius ); + e->setRadius( Element::VDW, vdw_radius ); + e->setAbundance( abundance ); + + if ( artificial == 1 ) + e->setArtificial(); + if ( radioactive == 1 ) + e->setRadioactive(); + + e->setScientist(scientist); + e->setPeriod( period ); + e->setCrysatalstructure( crystal ); + e->setOrigin(origin); + e->setBlock(block); + e->setGroup(group); + e->setFamily(family); + e->setOrbits(orbits); + e->setSymbol(symbol); + e->setOxydation(oxydation); + e->setAcidicbehaviour(acidicbehaviour); + e->setIonisationList( ionlist ); + e->setIsotopeList( isolist ); + + e->setMass( mass ); + e->setEN( en ); + e->setEA( ea ); + e->setMeltingpoint( mp ); + e->setBoilingpoint( bp ); + e->setDensity( density ); + + e->setupXY(); + + Spectrum *spectrum = new Spectrum(); + bool spectrum_temp = false; + if ( spectrumList.length() > 0 ) + spectrum_temp = true; + for( uint i = 0; i < spectrumList.length(); i++ ) + { + Spectrum::band b; + QDomElement spec = spectrumList.item( i ).toElement(); + + b.intensity = spec.attributeNode( "intensity" ).value().toInt(); + b.wavelength = spec.attributeNode( "wavelength" ).value().toDouble()/10.0; + b.aki = spec.attributeNode( "aki" ).value().toDouble(); + b.energy1 = spec.attributeNode( "energy1" ).value().toDouble(); + b.energy2 = spec.attributeNode( "energy2" ).value().toDouble(); + b.electronconfig1 = spec.attributeNode( "electronconfig1" ).value(); + b.electronconfig2 = spec.attributeNode( "electronconfig1" ).value(); + b.term1 = spec.attributeNode( "term1" ).value(); + b.term2 = spec.attributeNode( "term2" ).value(); + b.J1 = spec.attributeNode( "J1" ).value(); + b.J2 = spec.attributeNode( "J2" ).value(); + + spectrum->addBand( b ); + } + if ( spectrum_temp ) //if no spectrumdata are found don't use this object + e->setSpectrum( spectrum ); + e->setHasSepctrum( spectrum_temp ); + + list.append( e ); + coordinate point; point.x = e->x; point.y = e->y; + CoordinateList.append( point ); + } + + return list; +} + diff --git a/kalzium/src/kalziumdataobject.h b/kalzium/src/kalziumdataobject.h new file mode 100644 index 00000000..6d358510 --- /dev/null +++ b/kalzium/src/kalziumdataobject.h @@ -0,0 +1,79 @@ +#ifndef KALZIUMDATAOBJECT_H +#define KALZIUMDATAOBJECT_H +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "element.h" + +/** + * @short This class contains all Element objects + * + * This singleton class collects all the information about the elements of the + * Periodic Table as list of Element (QValueList). + * Use: + * @code + * KalziumDataObject::instance()->ElementList; + * @endcode + * to get the whole list of Element, while a + * @code + * KalziumDataObject::instance()->element( num ); + * @endcode + * will return you the pointer to the num'th element of the Periodic Table. + * + * @author Carsten Niehaus + */ +class KalziumDataObject +{ + public: + /** + * @return the instance of this class + */ + static KalziumDataObject* instance(); + + /** + * The list of elements in a QValueList + */ + EList ElementList; + + CList CoordinateList; + + /** + * @return the Element with the number @p number + * @param number the number of the Element which will be returned + */ + Element* element( int number ); + + /** + * @return the number of elements we have + */ + int numberOfElements() const { return m_numOfElements; } + + private: + KalziumDataObject(); + ~KalziumDataObject(); + + EList readData( QDomDocument &dataDocument ); + + /** + * Caching the number of elements + */ + int m_numOfElements; +}; +#endif // KALZIUMDATAOBJECT_H diff --git a/kalzium/src/kalziumtip.cpp b/kalzium/src/kalziumtip.cpp new file mode 100644 index 00000000..0f053c77 --- /dev/null +++ b/kalzium/src/kalziumtip.cpp @@ -0,0 +1,306 @@ +/*************************************************************************** + * Copyright (C) 2005 by Zack Rusin * + * Sami Kyostil * + * Aaron J. Seigo * + * Martin Pfeiffer * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "kalziumtip.h" +#include "kalziumutils.h" +#include "element.h" + +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include + +KalziumTip::KalziumTip( QWidget * parent, const char * name, WFlags f ) : QWidget( parent, name, f ) +{ + setFocusPolicy(NoFocus); //the widget don't get the keyboard focus + setBackgroundMode(NoBackground); // widget has no background + resize(0,0); + hide(); //initailly hide it + m_richText = 0; + m_noElemIcon = KGlobal::iconLoader()->loadIcon( "orbits", KIcon::NoGroup, 64 ); + setMouseTracking(true); // receice mouse move events + + connect(&m_frameTimer, SIGNAL(timeout()), SLOT(internalUpdate())); +} + +void KalziumTip::showTip( QPoint mouse, Element* element, int visibleWidth, int visibleHeight ) +{ + QWidget *p = 0; + if ( dynamic_cast( parent() ) ) + p = static_cast( parent() ); + + if ( p ) + { + if ( mouse.y() + size().height() > visibleHeight ) + mouse.setY( mouse.y() - size().height() ); + if ( mouse.x() + size().width() > visibleWidth ) + mouse.setX( mouse.x() - size().width() ); + + if ( p->width() < visibleWidth ) + { + if ( mouse.x() + size().width() > p->width() ) + mouse.setX( mouse.x() - size().width() ); + } + + if ( p->height() < visibleHeight ) + { + if ( mouse.y() + size().height() > p->height() ) + mouse.setY( mouse.y() - size().height() ); + } + } + + m_mousePointer = mouse; + + if( element == m_tippedElement ) + { + // Avoid moving out of the current screen + if (m_mousePointer.x()+width() > qApp->desktop()->width()) + m_mousePointer.setX(qApp->desktop()->width() - width()); + + move(m_mousePointer); //do not paint again if already painted + } + else + { + if ( element == 0) + return; + + m_tippedElement = element; + + loadIcon(); //load icon + display(); + } +} + +void KalziumTip::paintEvent(QPaintEvent* e) +{ + if (m_dirty) + { + displayInternal(); + m_dirty = false; + } + + QPainter p(this); + p.drawPixmap(e->rect().topLeft(), m_pixmap, e->rect()); +} + +void KalziumTip::mouseMoveEvent(QMouseEvent * e) +{ + // delegate the mouse move event to the parent (actually the elements table) + // so that this tooltip doesn't stop to be updated + e->ignore(); +} + +void KalziumTip::display() +{ + if( !m_tippedElement ) + return; + + delete m_richText; + + QString elementname = m_tippedElement->elname(); + + QString number = i18n( "Number: %1" ) + .arg( QString::number(m_tippedElement->number()) ); + + QString mass = i18n( "Mass: %1" ) + .arg( KalziumUtils::localizedValue(m_tippedElement->mass(), 6) ); + + m_richText = new QSimpleRichText("

" + elementname + "

" + + number + "

" + + mass +"

", font()); + + m_richText->setWidth(400); + + m_maskEffect = isVisible() ? Plain : Dissolve; + m_dissolveSize = 24; + m_dissolveDelta = -1; + + displayInternal(); + m_frameTimer.start(500/30); + + move(m_mousePointer); + show(); +} + +void KalziumTip::displayInternal() +{ + if (!m_richText) + return; + + + // determine text rectangel sizes + QRect textRect(0,0,0,0); + textRect.setWidth(m_richText->widthUsed()); + textRect.setHeight(m_richText->height()); + + //moves the rect + textRect.moveBy(-textRect.left(), -textRect.top()); + // add the new coordinates + textRect.addCoords(0,0,2,2); + + int margin = KDialog::marginHint(); + int height = QMAX(m_icon.height(), textRect.height()) + 2 * margin; + int textX = 2 + m_icon.width() + 2 * margin; + int width = textX + textRect.width() + margin; + int textY = (height - textRect.height()) / 2; + + //resize pixmap, mask and widget + m_mask.resize(width, height); + m_pixmap.resize(width, height); + resize(width, height); + + // create and set transparency mask + switch(m_maskEffect) + { + case Plain: + plainMask(); + break; + + case Dissolve: + dissolveMask(); + break; + } + + // draw background + QPainter bufferPainter(&m_pixmap); + bufferPainter.setPen(Qt::black); + bufferPainter.setBrush(backgroundColor()); + bufferPainter.drawRoundRect(0, 0, width, height, + 1600 / width, 1600 / height); + + // draw icon if present + if (!m_icon.isNull()) + { + bufferPainter.drawPixmap(margin, + margin, + m_icon, 0, 0, + m_icon.width(), m_icon.height()); + } + + // draw text shadow + QColorGroup cg = colorGroup(); + cg.setColor(QColorGroup::Text, cg.background().dark(115)); + int shadowOffset = QApplication::reverseLayout() ? -1 : 1; + m_richText->draw(&bufferPainter, 5 + textX + shadowOffset, textY + 1, QRect(), cg); + + // draw text + cg = colorGroup(); + m_richText->draw(&bufferPainter, 5 + textX, textY, rect(), cg); +} + +void KalziumTip::dissolveMask() +{ + QPainter maskPainter(&m_mask); + + m_mask.fill(Qt::black); + + maskPainter.setBrush(Qt::white); + maskPainter.setPen(Qt::white); + maskPainter.drawRoundRect(m_mask.rect(), 1600 / m_mask.rect().width(), + 1600 / m_mask.rect().height()); + + m_dissolveSize += m_dissolveDelta; + + if (m_dissolveSize > 0) + { + maskPainter.setRasterOp(Qt::EraseROP); + + int x, y, s; + const int size = 16; + const int heightsize = size + height(); + + for (y = 0; y < heightsize; y += size) + { + x = width(); + s = m_dissolveSize * x / 128; + for (; x > -size; x -= size, s -= 2) + { + if (s < 0) + { + s = 0; + } + maskPainter.drawEllipse(x - s / 2, y - s / 2, s, s); + } + } + } + else if (m_dissolveSize < 0) + { + m_frameTimer.stop(); + m_dissolveDelta = 1; + } + + setMask(m_mask); +} + +void KalziumTip::hide() +{ + m_frameTimer.stop(); + m_tippedElement = 0; + QWidget::hide(); +} + +void KalziumTip::plainMask() +{ + QPainter maskPainter(&m_mask); + + m_mask.fill(Qt::black); + + maskPainter.setBrush(Qt::white); + maskPainter.setPen(Qt::white); + maskPainter.drawRoundRect(m_mask.rect(), 1600 / m_mask.rect().width(), + 1600 / m_mask.rect().height()); + setMask(m_mask); + m_frameTimer.stop(); +} + +void KalziumTip::internalUpdate() +{ + m_dirty = true; + update(); +} + +void KalziumTip::loadIcon() +{ + QString iconpath = locate( "data" , "kalzium/elempics/" + m_tippedElement->symbol() + ".jpg" ); + if ( !iconpath.isEmpty() ) + { + QImage img ( iconpath, "JPEG" ); + img = img.smoothScale ( 128, 128, QImage::ScaleMin ); + m_icon.convertFromImage( img ); + + } + else + { + m_icon = m_noElemIcon; + } +} + +#include "kalziumtip.moc" diff --git a/kalzium/src/kalziumtip.h b/kalzium/src/kalziumtip.h new file mode 100644 index 00000000..425e2a7e --- /dev/null +++ b/kalzium/src/kalziumtip.h @@ -0,0 +1,88 @@ +#ifndef KALZIUMTIP_H +#define KALZIUMTIP_H +/*************************************************************************** + + The header for the tooltip class of Kalzium + ------------------- + begin : June 2003 + copyright : (C) 2003, 2004, 2005 by Zack Rusin + Sami Kyostil +                    Aaron J. Seigo + Martin Pfeiffer + + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + + +#include +#include +#include + +class QPaintEvent; +class QSimpleRichText; +class QPixmap; +class Element; +class QTimer; + + +/** + * @short tooltip for kalzium + * @author Martin Pfeiffer + */ +class KalziumTip : public QWidget +{ + Q_OBJECT + + public: + enum MaskEffect { Plain, Dissolve }; + + KalziumTip( QWidget * parent = 0, const char * name = 0, WFlags f = 0 ); + + void showTip( QPoint, Element* element, int visibleWidth, int visibleHeight ); //show the tip + void hide(); // hide it + + protected: + void paintEvent(QPaintEvent * e); + + void plainMask(); + void dissolveMask(); + // if the mouse pointer hovers us, send the event to the parent + // so we are some-what 'mouse transparent' + void mouseMoveEvent(QMouseEvent * e); + void displayInternal(); + void display(); + + void loadIcon(); //loads the elements icon + + protected slots: + void internalUpdate(); + + private: + QBitmap m_mask; + QPoint m_mousePointer; + QPixmap m_pixmap; + QPixmap m_icon; //icon shown on the tip + QPixmap m_noElemIcon; //icon for element wich have no image + + MaskEffect m_maskEffect; //inidicates to show mask effect or plain + QSimpleRichText* m_richText; + + int m_dissolveSize; + int m_dissolveDelta; + + QTimer m_frameTimer; //timer for the dissolve effect + bool m_dirty; //indicates repainting the tooltip internal + + const Element* m_tippedElement; //the element the tip is about +}; + +#endif + diff --git a/kalzium/src/kalziumui.rc b/kalzium/src/kalziumui.rc new file mode 100644 index 00000000..80c9be54 --- /dev/null +++ b/kalzium/src/kalziumui.rc @@ -0,0 +1,45 @@ + + + + &File + + + &View + + &Look + + + + + + + + + + + + + + + &Tools + + + + + &Settings + + + + + Main Toolbar + + + + + + + + + + + diff --git a/kalzium/src/kalziumutils.cpp b/kalzium/src/kalziumutils.cpp new file mode 100644 index 00000000..2e4dd127 --- /dev/null +++ b/kalzium/src/kalziumutils.cpp @@ -0,0 +1,88 @@ +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ +#include "kalziumutils.h" + +#include +#include +#include +#include +#include +#include +#include + +#include +#if defined(Q_OS_SOLARIS) +#include +#endif + +int KalziumUtils::maxSize( const QString& string, const QRect& rect, QFont font, QPainter* p, int minFontSize, int maxFontSize ) +{ + bool goodSizeFound = false; + int size = maxFontSize; + QRect r; + + do + { + font.setPointSize( size ); + p->setFont( font ); + r = p->boundingRect( QRect(), Qt::AlignAuto, string ); + r.moveBy( rect.left(), rect.top() ); + + if ( rect.contains( r ) ) + goodSizeFound = true; + else + size--; + } + while ( !goodSizeFound && ( size > minFontSize ) ); + + return size; +} + +int KalziumUtils::StringHeight( const QString& string, const QFont& font, QPainter* p ) +{ + return p->boundingRect( QRect(), Qt::AlignAuto, string ).height(); +} + +int KalziumUtils::StringWidth( const QString& string, const QFont& font, QPainter* p ) +{ + return p->boundingRect( QRect(), Qt::AlignAuto, string ).width(); +} + +double KalziumUtils::strippedValue( double num ) +{ + if ( !finite( num ) ) + return num; + + double power; + power = 1e-6; + while ( power < num ) + power *= 10; + + num = num / power * 10000; + num = qRound( num ); + + return num * power / 10000; +} + +QString KalziumUtils::localizedValue( double val, int precision, unsigned long options ) +{ + QString str = KGlobal::locale()->formatNumber( val, precision ); + while( str.endsWith("0") ) + str.truncate( str.length()-1); + if ( str.endsWith( KGlobal::locale()->decimalSymbol() ) ) + { + // we do not want trailing ',' values so readd trailing 0 + str.append( '0' ); // + } + return str; +} diff --git a/kalzium/src/kalziumutils.h b/kalzium/src/kalziumutils.h new file mode 100644 index 00000000..36f66080 --- /dev/null +++ b/kalzium/src/kalziumutils.h @@ -0,0 +1,73 @@ +#ifndef KALZIUMUTILS_H +#define KALZIUMUTILS_H + +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +class QString; +class QRect; +class QFont; +class QPainter; + +class KalziumUtils +{ + public: + + enum FormatOptions { NoOptions, + Round = 1 + }; + /** + * @param string the string which is measured + * @param rect the rect needed for measurement + * @param font the used font + * @param painter the used painter + * @param maxFontSize the maximum fontsize + * @param minFontSize the maximum fontsize + */ + static int maxSize( const QString& string, const QRect& rect, QFont font, QPainter* painter, int minFontSize = 4, int maxFontSize = 20 ); + + /** + * calculate the 4-digit value of the value @p w. For + * example, 12.3456 will be returned as 12.35 + * @param value the value which will be stripped + * @return the 4-digit value + */ + static double strippedValue( double value ); + + /** + * format the given double with localized separators + * @param val the number value as double + * @param precision number of decimals + * @param options the options used for formatting of @p val + * @return + */ + static QString localizedValue( double val, int precision, unsigned long options = 0 ); + + /** + * @param string the string which is measured + * @param font the used font + * @param painter the used painter + * @return the width of the string @p string + */ + static int StringWidth( const QString& string, const QFont& font, QPainter* painter ); + /** + * @param string the string which is measured + * @param font the used font + * @param painter the used painter + * @return the height of the string @p string + */ + static int StringHeight( const QString& string, const QFont& font, QPainter* painter ); +}; + +#endif // KALZIUMUTILS_H + diff --git a/kalzium/src/main.cpp b/kalzium/src/main.cpp new file mode 100644 index 00000000..3ea452df --- /dev/null +++ b/kalzium/src/main.cpp @@ -0,0 +1,94 @@ +/* + * Copyright (C) 2003-2005 Carsten Niehaus + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include +#include +#include + +#include "config.h" +#include "kalzium.h" + +#define APP_VERSION "1.4.6" + +static const char description[] = + I18N_NOOP("A periodic table of the elements"); + +static const char version[] = APP_VERSION; + +static KCmdLineOptions options[] = +{ +// { "+[URL]", I18N_NOOP( "Document to open" ), 0 }, + KCmdLineLastOption +}; + +#ifdef HAVE_FACILE +extern "C" { + void caml_startup(char**); +}; +#endif + +int main(int argc, char **argv) +{ +#ifdef HAVE_FACILE + caml_startup(argv); +#endif + + KAboutData about("kalzium", I18N_NOOP("Kalzium"), version, description, + KAboutData::License_GPL, "(C) 2002-2005 Carsten Niehaus", 0, "http://edu.kde.org/kalzium"); + about.addAuthor( "Carsten Niehaus", 0, "cniehaus@kde.org" ); + about.addCredit( "Pino Toscano", I18N_NOOP("Code contributions" )); + about.addCredit( "Martin Pfeiffer", I18N_NOOP("Tooltip, some other small things" )); + about.addCredit( "Thomas Nagy", I18N_NOOP("Contributed EqChem, the equation solver" )); + about.addCredit( "Jörg Buchwald", I18N_NOOP("Contributed most isotope information" )); + about.addCredit( "Marco Martin", I18N_NOOP("Thank you for some icons and inspiration for others" )); + about.addCredit( "Chris Luetchford", I18N_NOOP("SVG icon"), "chris@os11.com"); + about.addCredit( "Anne-Marie Mahfouf", I18N_NOOP( "A lot of small things and the documentation" )); + about.addCredit( "Paweł Budzyński", I18N_NOOP( "The pictures of the elements iodine and bromine" )); + about.addCredit( "M. Stegemann", I18N_NOOP( "Almost all pictures of the elements" )); + about.addCredit( "Daniel Haas", I18N_NOOP( "The design of the information dialog" )); + about.addCredit( "Brian Beck", I18N_NOOP( "The orbits-icon" )); + about.addCredit( "Lee Olson", I18N_NOOP( "Several icons in the information dialog" )); + about.addCredit( "Inge Wallin", I18N_NOOP( "Code cleaning, the molecule parser and a lot of smaller improvements" )); + KCmdLineArgs::init(argc, argv, &about); + KCmdLineArgs::addCmdLineOptions( options ); + KApplication app; + Kalzium *mainWin = 0; + + if (app.isRestored()) + { + RESTORE(Kalzium); + } + else + { + // no session.. just start up normally + KCmdLineArgs *args = KCmdLineArgs::parsedArgs(); + + /// @todo do something with the command line args here + + mainWin = new Kalzium(); + app.setMainWidget( mainWin ); + mainWin->show(); + + args->clear(); + } + + // mainWin has WDestructiveClose flag by default, so it will delete itself. + return app.exec(); +} + diff --git a/kalzium/src/molcalcwidget.cpp b/kalzium/src/molcalcwidget.cpp new file mode 100644 index 00000000..c9947eda --- /dev/null +++ b/kalzium/src/molcalcwidget.cpp @@ -0,0 +1,153 @@ +/*************************************************************************** + * Copyright (C) 2003-2005 by Carsten Niehaus, cniehaus@kde.org * + * Copyright (C) 2005 by Inge Wallin, inge@lysator.liu.se * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + * * + ***************************************************************************/ + + +#include "molcalcwidget.h" + +#include "kalziumdataobject.h" +#include "molcalcwidgetbase.h" +#include "element.h" +#include "kalziumutils.h" +#include "parser.h" +#include "moleculeparser.h" + +#include +#include +#include +#include +#include +#include + +#include +#include +#include + + +MolcalcWidget::MolcalcWidget( QWidget *parent, const char *name ) + : MolcalcWidgetBase( parent, name ) +{ + clear(); +} + + +void MolcalcWidget::clear() +{ + // Clear the data. + m_mass = 0; + m_elementMap.clear(); + + // Clear the widgets. + resultLabel->setText( "" ); + resultMass->setText( "" ); + + resultComposition->setText( i18n("To start, enter\na formula in the\nwidget above and\nclick on 'Calc'.") ); + + QToolTip::remove( resultMass ); + QToolTip::remove( resultComposition ); + QToolTip::remove( resultLabel ); +} + + +void MolcalcWidget::updateUI() +{ + if ( m_validInput ){ + + QString str; + + // The complexString stores the whole molecule like this: + // 1 Seaborgium. Cumulative Mass: 263.119 u (39.2564 %) + QString complexString; + + // Create the list of elements making up the molecule + ElementCountMap::Iterator it = m_elementMap.begin(); + ElementCountMap::Iterator itEnd = m_elementMap.end(); + for ( ; it != itEnd; ++it ) { + // Update the resultLabel + str += i18n( "For example: \"1 Carbon\" or \"3 Oxygen\"", "%1 %2\n" ) + .arg( (*it)->count() ) + .arg( (*it)->element()->elname() ); + + complexString + += i18n( "For example: 1 Seaborgium. Cumulative Mass: 263.119 u (39.25%)", + "%1 %2. Cumulative Mass: %3 u (%4%)\n" ) + .arg( (*it)->count() ) + .arg( (*it)->element()->elname() ) + .arg( (*it)->count() * (*it)->element()->mass() ) + .arg( KalziumUtils::strippedValue( (( (*it)->count() * (*it)->element()->mass() ) + / m_mass ) * 100 ) ); + } + resultLabel->setText( str ); + + // The composition + resultComposition->setText( compositionString(m_elementMap) ); + + // The mass + resultMass->setText( i18n( "Molecular mass: %1 u" ).arg( m_mass ) ); + + QToolTip::add( resultMass, complexString ); + QToolTip::add( resultComposition, complexString ); + QToolTip::add( resultLabel, complexString ); + } + else{//the input was invalid, so tell this the user + resultComposition->setText( i18n( "Invalid input" ) ); + resultLabel->setText( QString() ); + resultMass->setText( QString() ); + + QToolTip::add( resultMass, i18n( "Invalid input" ) ); + QToolTip::add( resultComposition, i18n( "Invalid input" ) ); + QToolTip::add( resultLabel, i18n( "Invalid input" ) ); + } +} + + +QString MolcalcWidget::compositionString( ElementCountMap &_map ) +{ + QString str; + + ElementCountMap::Iterator it = _map.begin(); + ElementCountMap::Iterator itEnd = _map.end(); + for (; it != itEnd; ++it) { + str += i18n( "%1%2 " ) + .arg( (*it)->element()->symbol() ) + .arg( (*it)->count() ); + } + + return str; +} + + +// ---------------------------------------------------------------- +// slots + + +void MolcalcWidget::slotCalcButtonClicked() +{ + QString molecule = formulaEdit->text(); + + // Parse the molecule, and at the same time calculate the total + // mass, and the composition of it. + m_validInput = m_parser.weight(molecule, &m_mass, &m_elementMap); + + updateUI(); +} + + +#include "molcalcwidget.moc" diff --git a/kalzium/src/molcalcwidget.h b/kalzium/src/molcalcwidget.h new file mode 100644 index 00000000..f09157e6 --- /dev/null +++ b/kalzium/src/molcalcwidget.h @@ -0,0 +1,80 @@ +#ifndef MOLCALCWIDGET_H +#define MOLCALCWIDGET_H +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "molcalcwidgetbase.h" + +#include "moleculeparser.h" + +class KToggleAction; +class KLineEdit; + +class Element; +class MolcalcDialog; +class MoleculeParser; + +/** + * This widget is a small calculator for molecules. + * + * @author Carsten Niehaus + * @author Pino Toscano + * @author Inge Wallin + */ +class MolcalcWidget : public MolcalcWidgetBase +{ + Q_OBJECT + public: + /** + * Constructor + * @param parent parent widget + * @param name name of this widget + */ + MolcalcWidget( QWidget *parent = 0, const char *name = 0 ); + + protected slots: + void slotCalcButtonClicked(); + + private slots: + void clear(); + + private: + /** + * @return the HTML code of an element symbol and its + * subscripted amount. Eg: Mg2 + */ + QString compositionString( ElementCountMap &_map ); + + /** + * This methods gathers all the data and updates the + * contents of the widget. + */ + void updateUI(); + + private: + MoleculeParser m_parser; + + double m_mass; + bool m_validInput; + ElementCountMap m_elementMap; +}; + + +#endif // MOLCALC_IMPL_H diff --git a/kalzium/src/molcalcwidgetbase.ui b/kalzium/src/molcalcwidgetbase.ui new file mode 100644 index 00000000..a330b773 --- /dev/null +++ b/kalzium/src/molcalcwidgetbase.ui @@ -0,0 +1,135 @@ + +MolcalcWidgetBase + + + MolcalcWidgetBase + + + + 0 + 0 + 2180 + 400 + + + + + unnamed + + + 11 + + + 6 + + + + + + formulaEdit + + + + + + + + buttonCalc + + + Calc + + + + + + + line1 + + + HLine + + + Sunken + + + Horizontal + + + + + resultComposition + + + + 14 + 1 + + + + + + + AlignCenter + + + + + spacer5_2 + + + Vertical + + + MinimumExpanding + + + + 20 + 10 + + + + + + resultLabel + + + + + + + + resultMass + + + + + + + + + + + + buttonCalc + pressed() + this + slotCalcButtonClicked() + + + formulaEdit + returnPressed(const QString&) + this + slotCalcButtonClicked() + + + + slotCalcButtonClicked() + + + + klineedit.h + kpushbutton.h + + diff --git a/kalzium/src/moleculeparser.cpp b/kalzium/src/moleculeparser.cpp new file mode 100644 index 00000000..183f9769 --- /dev/null +++ b/kalzium/src/moleculeparser.cpp @@ -0,0 +1,304 @@ +/*************************************************************************** + copyright : (C) 2005 by Inge Wallin + email : inge@lysator.liu.se + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + + +#include + +#include + +#include "kalziumdataobject.h" +#include "moleculeparser.h" + + +// ================================================================ +// class ElementCountMap + + + +ElementCountMap::ElementCountMap() +{ + m_map.clear(); +} + + +ElementCountMap::~ElementCountMap() +{ +} + + +ElementCount * +ElementCountMap::search(Element *_element) +{ + QValueList::ConstIterator it = m_map.constBegin(); + const QValueList::ConstIterator itEnd = m_map.constEnd(); + + for (; it != itEnd; ++it) { + if ((*it)->element() == _element) + return *it; + } + + return 0; +} + + +void +ElementCountMap::add(ElementCountMap &_map) +{ + QValueList::ConstIterator it = _map.m_map.constBegin(); + const QValueList::ConstIterator itEnd = _map.m_map.constEnd(); + + // Step throught _map and for each element, add it to the current one. + for (; it != itEnd; ++it) { + add((*it)->m_element, (*it)->m_count); + } + +} + + +void +ElementCountMap::add(Element *_element, int _count) +{ + ElementCount *elemCount; + + elemCount = search(_element); + if (elemCount) + elemCount->m_count += _count; + else + m_map.append(new ElementCount(_element, _count)); +} + + +void +ElementCountMap::multiply(int _factor) +{ + Iterator it = begin(); + Iterator itEnd = end(); + + for (; it != itEnd; ++it) + (*it)->multiply(_factor); +} + + +// ================================================================ +// class MoleculeParser + + +MoleculeParser::MoleculeParser() + : Parser() +{ +} + + +MoleculeParser::MoleculeParser(const QString& _str) + : Parser(_str) +{ +} + + +MoleculeParser::~MoleculeParser() +{ + //Parser::~Parser(); +} + + +// ---------------------------------------------------------------- +// public methods + + +// Try to parse the molecule and get the weight of it. +// +// This method also acts as the main loop. + +bool +MoleculeParser::weight(QString _moleculeString, + double *_resultMass, + ElementCountMap *_resultMap) +{ + // Clear the result variables and set m_error to false + _resultMap->clear(); + m_error = false; + *_resultMass = 0.0; + + // Initialize the parsing process, and parse te molecule. + start(_moleculeString); + parseSubmolecule(_resultMass, _resultMap); + + if (nextToken() != -1) + return false; + + if ( m_error )//there was an error in the input... + return false; + + return true; +} + + +// ---------------------------------------------------------------- +// helper methods for the public methods + + +// Parse a submolecule. This is a list of terms. +// + +bool +MoleculeParser::parseSubmolecule(double *_resultMass, + ElementCountMap *_resultMap) +{ + double subMass = 0.0; + ElementCountMap subMap; + + *_resultMass = 0.0; + _resultMap->clear(); + while (parseTerm(&subMass, &subMap)) { + //kdDebug() << "Parsed a term, weight = " << subresult << endl; + + // Add the mass and composition of the submolecule to the total. + *_resultMass += subMass; + _resultMap->add(subMap); + } + + return true; +} + + +// Parse a term within the molecule, i.e. a single atom or a +// submolecule within parenthesis followed by an optional number. +// Examples: Bk, Mn2, (COOH)2 +// +// Return true if correct, otherwise return false. + +// If correct, the mass of the term is returned in *_resultMass, and +// the flattened composition of the molecule in *_resultMap. +// + +bool +MoleculeParser::parseTerm(double *_resultMass, + ElementCountMap *_resultMap) +{ + *_resultMass = 0.0; + _resultMap->clear(); + +#if 0 + kdDebug() << "parseTerm(): Next token = " + << nextToken() << endl; +#endif + if (nextToken() == ELEMENT_TOKEN) { + //kdDebug() << "Parsed an element: " << m_elementVal->symbol() << endl; + *_resultMass = m_elementVal->mass(); + _resultMap->add(m_elementVal, 1); + + getNextToken(); + } + + else if (nextToken() == '(') { + // A submolecule. + + getNextToken(); + parseSubmolecule(_resultMass, _resultMap); + + // Must end in a ")". + if (nextToken() == ')') { + //kdDebug() << "Parsed a submolecule. weight = " << *_result << endl; + getNextToken(); + } + else + return false; + } + else + // Neither an element nor a list within (). + return false; + + // Optional number. + if (nextToken() == INT_TOKEN) { + //kdDebug() << "Parsed a number: " << intVal() << endl; + + *_resultMass *= intVal(); + _resultMap->multiply(intVal()); + + getNextToken(); + } + + kdDebug() << "Weight of term = " << *_resultMass << endl; + return true; +} + + +// ---------------------------------------------------------------- +// protected methods + + +// Extend Parser::getNextToken with elements. + +int +MoleculeParser::getNextToken() +{ + QString elementName; + +#if 0 + kdDebug() << "getNextToken(): Next character = " + << nextChar() << endl; +#endif + + // Check if the token is an element name. + if ('A' <= nextChar() && nextChar() <= 'Z') { + elementName = char(nextChar()); + getNextChar(); + + if ('a' <= nextChar() && nextChar() <= 'z') { + elementName.append(char(nextChar())); + getNextChar(); + } + + // Look up the element from the name.. + m_elementVal = lookupElement(elementName); + if (m_elementVal) + { + m_nextToken = ELEMENT_TOKEN; + } + else + m_nextToken = -1; + } + else + return Parser::getNextToken(); + + return m_nextToken; +} + + +// ---------------------------------------------------------------- +// private methods + + +Element * +MoleculeParser::lookupElement( const QString& _name ) +{ + EList elementList = KalziumDataObject::instance()->ElementList; + + //kdDebug() << "looking up " << _name << endl; + + EList::ConstIterator it = elementList.constBegin(); + const EList::ConstIterator end = elementList.constEnd(); + + for (; it != end; ++it) { + if ( (*it)->symbol() == _name ) { + kdDebug() << "Found element " << _name << endl; + return *it; + } + } + + //if there is an error make m_error true. + m_error = true; + + kdDebug() << k_funcinfo << "no such element, parsing error!: " << _name << endl; + return NULL; +} diff --git a/kalzium/src/moleculeparser.h b/kalzium/src/moleculeparser.h new file mode 100644 index 00000000..c35c71be --- /dev/null +++ b/kalzium/src/moleculeparser.h @@ -0,0 +1,138 @@ +/*************************************************************************** + copyright : (C) 2005 by Inge Wallin + email : inge@lysator.liu.se + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#ifndef MOLECULEPARSER_H +#define MOLECULEPARSER_H + +#include "element.h" +#include "parser.h" + +#include +#include + + +/** + * @class Element + */ +class ElementCount { + public: + ElementCount(Element *_element, int _count) + { + m_element = _element; + m_count = _count; + } + ElementCount(Element *_element) + { + m_element = _element; + m_count = 0; + } + + ~ElementCount(); + + Element *element() const { return m_element; } + int count() const { return m_count; } + void add(int _count) { m_count += _count; } + void multiply(int _factor) { m_count *= _factor; } + + Element *m_element; + int m_count; +}; + + +/** + * @class ElementCountMap + */ +class ElementCountMap { + public: + ElementCountMap(); + ~ElementCountMap(); + + void clear() { m_map.clear(); } + + ElementCount *search(Element *_element); + void add(ElementCountMap &_map); + void add(Element *_element, int _count); + void multiply(int _factor); + + typedef QValueList::Iterator Iterator; + Iterator begin() { return m_map.begin(); } + Iterator end() { return m_map.end(); } + + private: + QValueList m_map; +}; + + + +/** + * Parse molecule formulas. + * + * Usage: + * @code + * MoleculeParser parser; + * QString chemical_formula = "C2H5OH"; + * double weight; + * + * if (parser.weight(chemical_formula, &weight)) + * cout << "Weight of " << chemical_formula << " = " << weight << ".\n"; + * else + * cout << "Parse error\n"; + * @endcode + * + * @author Inge Wallin + */ +class MoleculeParser : public Parser { + +public: + static const int ELEMENT_TOKEN = 300; + + MoleculeParser(); + MoleculeParser( const QString& _str); + ~MoleculeParser(); + + /** + * Try to parse the molecule @p molecule and get the weight of it. + * The calculated weight is stored in @p _result. + * + * @return whether the parsing was successful or not + */ + bool weight(QString _moleculeString, + double *_resultMass, + ElementCountMap *_resultMap); + + private: + // Helper functions + bool parseSubmolecule(double *_resultMass, + ElementCountMap *_resultMap); + bool parseTerm(double *_resultMass, + ElementCountMap *_resultMap); + + Element *lookupElement( const QString& _name ); + + QMap m_elementMap; + + //if this booloean is "true" the parser found an error + bool m_error; + +protected: + + /** + * Extends the standard tokenizer in Parser::getNextToken(). + */ + virtual int getNextToken(); + +private: + Element *m_elementVal; // Valid if m_nextToken == ELEMENT_TOKEN +}; + +#endif diff --git a/kalzium/src/orbitswidget.cpp b/kalzium/src/orbitswidget.cpp new file mode 100644 index 00000000..f79381f0 --- /dev/null +++ b/kalzium/src/orbitswidget.cpp @@ -0,0 +1,257 @@ +/*************************************************************************** + begin : Jun 23 2003 + copyright : (C) 2003, 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "orbitswidget.h" + +#include + +//QT-Includes +#include +#include +#include + +static QStringList hulllist; + +OrbitsWidget::OrbitsWidget( QWidget *parent, const char *name) : QWidget( parent, name ) +{ + if ( hulllist.count() == 0 ) + { + hulllist.append( "1" ); + hulllist.append( "2" ); //Helium + hulllist.append( "2 1" ); + hulllist.append( "2 2" ); + hulllist.append( "2 3" ); + hulllist.append( "2 4" ); + hulllist.append( "2 5" ); + hulllist.append( "2 6" ); + hulllist.append( "2 7" ); + hulllist.append( "2 8" ); //Neon + hulllist.append( "2 8 1" ); + hulllist.append( "2 8 2" ); + hulllist.append( "2 8 3" ); + hulllist.append( "2 8 4" ); + hulllist.append( "2 8 5" ); + hulllist.append( "2 8 6" ); + hulllist.append( "2 8 7" ); + hulllist.append( "2 8 8" ); //Argon + hulllist.append( "2 8 8 1" ); + hulllist.append( "2 8 8 2" );//Calcium + hulllist.append( "2 8 9 2" ); + hulllist.append( "2 8 10 2" ); + hulllist.append( "2 8 11 2" ); + hulllist.append( "2 8 13 1" ); + hulllist.append( "2 8 13 2" );//Manganese + hulllist.append( "2 8 14 2" ); + hulllist.append( "2 8 15 2" ); + hulllist.append( "2 8 16 2" ); + hulllist.append( "2 8 18 1" );//Copper + hulllist.append( "2 8 18 2" ); + hulllist.append( "2 8 18 3" ); + hulllist.append( "2 8 18 4" ); + hulllist.append( "2 8 18 5" ); + hulllist.append( "2 8 18 6" ); + hulllist.append( "2 8 18 7" ); + hulllist.append( "2 8 18 8" );//Krypton + hulllist.append( "2 8 18 8 1" ); + hulllist.append( "2 8 18 8 2" );//Rubidium + hulllist.append( "2 8 18 9 2" ); + hulllist.append( "2 8 18 10 2" );//Zirconium + hulllist.append( "2 8 18 12 1" ); + hulllist.append( "2 8 18 13 1" ); + hulllist.append( "2 8 18 14 1" );//Techneticum + hulllist.append( "2 8 18 15 1" ); + hulllist.append( "2 8 18 16 1" ); + hulllist.append( "2 8 18 18" ); //Palladium + hulllist.append( "2 8 18 18 1" ); + hulllist.append( "2 8 18 18 2" ); + hulllist.append( "2 8 18 18 3" );//Indium + hulllist.append( "2 8 18 18 4" ); + hulllist.append( "2 8 18 18 5" ); + hulllist.append( "2 8 18 18 6" ); + hulllist.append( "2 8 18 18 7" ); + hulllist.append( "2 8 18 18 8" );//Xenon + hulllist.append( "2 8 18 18 8 1" );//Caesium + hulllist.append( "2 8 18 18 8 2" );//Barium + hulllist.append( "2 8 18 18 9 2" ); + hulllist.append( "2 8 18 20 8 2" );//Cerium + hulllist.append( "2 8 18 21 8 2" ); + hulllist.append( "2 8 18 22 8 2" ); + hulllist.append( "2 8 18 23 8 2" ); + hulllist.append( "2 8 18 24 8 2" ); + hulllist.append( "2 8 18 25 8 2" ); + hulllist.append( "2 8 18 25 9 2" );//Gadolinium + hulllist.append( "2 8 18 27 8 2" );//Terbium + hulllist.append( "2 8 18 28 8 2" ); + hulllist.append( "2 8 18 29 8 2" ); + hulllist.append( "2 8 18 30 8 2" ); + hulllist.append( "2 8 18 31 8 2" ); + hulllist.append( "2 8 18 32 8 2" );//Ytterbium + hulllist.append( "2 8 18 32 9 2" );//Lutetium + hulllist.append( "2 8 18 32 10 2" );//Hafnium + hulllist.append( "2 8 18 32 11 2" ); + hulllist.append( "2 8 18 32 12 2" ); + hulllist.append( "2 8 18 32 13 2" ); + hulllist.append( "2 8 18 32 14 2" ); + hulllist.append( "2 8 18 32 15 2" );//Irdium + hulllist.append( "2 8 18 32 17 1" ); + hulllist.append( "2 8 18 32 18 1" ); + hulllist.append( "2 8 18 32 18 2" );//Mercury + hulllist.append( "2 8 18 32 18 3" ); + hulllist.append( "2 8 18 32 18 4" ); + hulllist.append( "2 8 18 32 18 5" ); + hulllist.append( "2 8 18 32 18 6" ); + hulllist.append( "2 8 18 32 18 7" ); + hulllist.append( "2 8 18 32 18 8" );//Radon + hulllist.append( "2 8 18 32 18 8 1" );//Francium + hulllist.append( "2 8 18 32 18 8 2" );//Radium + hulllist.append( "2 8 18 32 18 9 2" );//Actinium + hulllist.append( "2 8 18 32 20 8 2" );//Thorium + hulllist.append( "2 8 18 32 21 8 2" ); + hulllist.append( "2 8 18 32 22 8 2" );//Uran + hulllist.append( "2 8 18 32 23 8 2" ); + hulllist.append( "2 8 18 32 24 8 2" );//Plutonium + hulllist.append( "2 8 18 32 25 8 2" ); + hulllist.append( "2 8 18 32 26 8 2" );//Cm + hulllist.append( "2 8 18 32 27 8 2" ); + hulllist.append( "2 8 18 32 28 8 2" );//Cf + hulllist.append( "2 8 18 32 29 8 2" ); + hulllist.append( "2 8 18 32 30 8 2" );//Fm + hulllist.append( "2 8 18 32 31 8 2" ); + hulllist.append( "2 8 18 32 32 8 2" );//Nobelium + hulllist.append( "2 8 18 32 32 9 2" );//Lawrencium + hulllist.append( "2 8 18 32 32 10 2" ); + hulllist.append( "2 8 18 32 32 11 2" );//Dubnium (105) + hulllist.append( "2 8 18 32 32 12 2" ); + hulllist.append( "2 8 18 32 32 13 2" );//Bohrium + hulllist.append( "2 8 18 32 32 14 2" ); + hulllist.append( "2 8 18 32 32 15 2" );//Mt + hulllist.append( "2 8 18 32 32 16 2" );//Darmstadtium + hulllist.append( "2 8 18 32 32 17 2" );//Roentgenium + } +} + +void OrbitsWidget::setElementNumber( const int num ) +{ + Elemno = num; + + getNumberOfOrbits(); + + update(); +} + +void OrbitsWidget::getNumberOfOrbits() +{ + numOfElectrons.clear(); + QRegExp rxb( "\\s" ); //space + QString o = getNumber(); + + num = 1; + int pos = 0; + int cut = 0; + bool cont = true; + + if ( !o.contains( rxb ) ) //only true for H and He + numOfElectrons.append( o.toInt() ); + else //every other element + { + while ( cont ) + { + + pos = o.find( rxb ); + cut = o.length()-pos-1; + numOfElectrons.append(o.left( pos ).toInt()); + o = o.right( cut ); + num++; + + if ( !o.contains( rxb ) ) + { + numOfElectrons.append( o.toInt() ); + cont = false; + } + } + } +} + +const QString& OrbitsWidget::getNumber() const +{ + return *hulllist.at( Elemno-1 ); +} + +void OrbitsWidget::paintEvent( QPaintEvent* ) +{ + + QPainter DC; + DC.begin( this ); + + int h=height(); + int w=width(); + int w_c=h/10; + int h_c=h/10; + + //the radius of the current orbit + int r; + + //the radius of an 'electron' + int r_electron; + + //make sure the biggest orbit fits in the widget + if ( h < w ) + r = ( h-2*h_c )/2; + else r = ( w-2*w_c )/2; + + r_electron = r/20; //diameter of an electron-circle + + QBrush brush( yellow ); + + int d = 2*r; //Diameter + int ddx = d/(2*num);//difference to the previous circle + + numOfElectrons.prepend( 999 ); + intList::Iterator it = numOfElectrons.end(); + it--; + + for ( int i = 0 ; i < num ; ++i ) + { + int mx = w_c+ddx*i; //the x-coordinate for the current circle + int my = h_c+ddx*i; //the y-coordinate for the current circle + + DC.setBrush( NoBrush ); + DC.setPen( black ); + + //draw the big ellipses in concentric circles + DC.drawEllipse( mx , my , d , d); + + DC.setBrush( brush ); + + for ( int e = 0 ; e < *it ; ++e ) + { + int x = (int)translateToDX( ( double )d/2 , ( double )e , *it); + int y = (int)translateToDY( ( double )d/2 , ( double )e , *it); + + DC.drawEllipse( x + mx + d/2 - r_electron, + y + mx + d/2 - r_electron, + 2*r_electron , + 2*r_electron ); + + } + --it; + d = d-2*ddx; + } +} + + + + +#include "orbitswidget.moc" diff --git a/kalzium/src/orbitswidget.h b/kalzium/src/orbitswidget.h new file mode 100644 index 00000000..831684d0 --- /dev/null +++ b/kalzium/src/orbitswidget.h @@ -0,0 +1,86 @@ +#ifndef ORBITSWIDGET_H +#define ORBITSWIDGET_H +/*************************************************************************** + + orbitswidget.h - description + ------------------- + begin : June 2003 + copyright : (C) 2003, 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + + +#include +#include + +/** + * @short the widget which displays the Bohr-orbit of the element + * @author Carsten Niehaus + */ +class OrbitsWidget : public QWidget +{ + Q_OBJECT + + public: + OrbitsWidget( QWidget *parent=0 , const char *name =0 ); + + void setElementNumber( const int num ); + + private: + /** + * the elementnumber we are looking at + */ + int Elemno; + + /** + * the number off hulls the atom has + */ + int num; + + typedef QValueList intList; + intList numOfElectrons; + + const QString& getNumber() const; + + /** + * @return the delta of the x-coordinate + * @param r is the radius of the circle + * @param angle is the n'st circle out of num + * @param num is the number of circles + */ + inline double translateToDX( const double r , const double angle , const int num ) + { + return( r * sin( M_PI * angle / num * 2 ) ); + } + + /** + * @return the delta of the y-coordinate + * @param r is the radius of the circle + * @param angle is the n'st circle out of num + * @param num is the number of circles + */ + inline double translateToDY( const double r , const double angle , const int num ) + { + return( r * cos( M_PI * angle / num * 2 ) ); + } + + /** + * sets everything up + */ + void getNumberOfOrbits(); + + protected slots: + virtual void paintEvent( QPaintEvent* ); +}; + +#endif // ORBITSWIDGET_H + diff --git a/kalzium/src/parser.cpp b/kalzium/src/parser.cpp new file mode 100644 index 00000000..19364c73 --- /dev/null +++ b/kalzium/src/parser.cpp @@ -0,0 +1,217 @@ +/*************************************************************************** + copyright : (C) 2005 by Inge Wallin + email : inge@lysator.liu.se + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + + +#include + +#include + +#include "parser.h" + + +Parser::Parser() +{ + start(QString::null); +} + + +Parser::Parser(const QString& _str) +{ + start(_str); +} + + +Parser::~Parser() +{ +} + + +void +Parser::start(const QString& _str) +{ + m_str = _str; + + if (_str.isNull()) { + m_index = -1; + m_nextChar = -1; + m_nextToken = -1; + } + else { + m_index = 0; + m_nextChar = m_str.at(0).latin1(); + getNextToken(); + } +} + + +// ---------------------------------------------------------------- + + +// Skip whitespace, and try to parse the following characters as an int. +// +// Return true if successful. + +bool +Parser::parseInt(int *_result) +{ + int sign = 1; + + skipWhitespace(); + + if (m_nextChar == '-') { + sign = -1; + getNextChar(); + } + + if (!isdigit(m_nextChar)) + return false; + + int result = 0; + while (isdigit(m_nextChar)) { + result = result * 10 + (m_nextChar - '0'); + getNextChar(); + } + + *_result = sign * result; + return true; +} + + +// Skip whitespace, and try to parse the following characters as a +// simple float of the type -?[0-9]+'.'?[0-9]* +// +// Return true if successful. + +bool +Parser::parseSimpleFloat(double *_result) +{ + double sign = 1.0; + + skipWhitespace(); + if (m_nextChar == '-') { + sign = -1.0; + getNextChar(); + } + + if (!isdigit(m_nextChar)) + return false; + + double result = 0.0; + + // The integer. + while (isdigit(m_nextChar)) { + result = result * 10.0 + (double) (m_nextChar - '0'); + getNextChar(); + } + *_result = result; + + if (m_nextChar != '.' || !isdigit(getNextChar())) { + *_result = sign * result; + return true; + } + + double decimal = 0.1; + while (isdigit(m_nextChar)) { + result += decimal * (double) (m_nextChar - '0'); + decimal /= 10.0; + getNextChar(); + } + + *_result = sign * result; + return true; +} + + +// ---------------------------------------------------------------- +// protected methods + + +int +Parser::getNextChar() +{ + if (m_index == -1) + return -1; + + // If end of string, then reset the parser. + if (m_index == (int) m_str.length()) { + m_index = -1; + m_nextChar = -1; + } + else + m_nextChar = m_str.at(++m_index).latin1(); + + // Take care of null-terminated strings. + if (m_nextChar == 0) { + m_index = -1; + m_nextChar = -1; + } + + //kdDebug() << "Parser::getNextChar(): char = " << m_nextChar << endl; + + return m_nextChar; +} + + +int +Parser::skipWhitespace() +{ + while (QChar(m_nextChar).isSpace()) + getNextChar(); + + return m_nextChar; +} + + +// Get the next token. This corresponds to the lexical analyzer of a +// standard parser, e.g as generated by lex. +// +// This basic parser supports integers and simple +// floats. Reimplement this method to extend it. + +int +Parser::getNextToken() +{ + int saveIndex = m_index; + + skipWhitespace(); + if (isdigit(nextChar())) { + // At this point we know that there is a valid number in the + // string. The only question now, is whether it is an int or a + // float. + + parseInt(&m_intVal); + + skipWhitespace(); + if (nextChar() == '.') { + m_index = saveIndex; + + // No need to check since we already know it is correct. + (void) parseSimpleFloat(&m_floatVal); + m_nextToken = FLOAT_TOKEN; + } + else + m_nextToken = INT_TOKEN; + } + + else if (nextChar() != -1) { + // Any character. + m_nextToken = nextChar(); + getNextChar(); + } + + else + // End of string. + m_nextToken = -1; + + return m_nextToken; +} diff --git a/kalzium/src/parser.h b/kalzium/src/parser.h new file mode 100644 index 00000000..f4ec68e7 --- /dev/null +++ b/kalzium/src/parser.h @@ -0,0 +1,105 @@ +/*************************************************************************** + copyright : (C) 2005 by Inge Wallin + email : inge@lysator.liu.se + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#ifndef PARSER_H +#define PARSER_H + +#include + +/** + * This is a general purpose parser originally written by Inge Wallin. + * + * It is intended to be subclassed; see MoleculeParser. + * + * @author Inge Wallin + */ +class Parser { +public: + // All characters are their own token value per default. + static const int INT_TOKEN = 257; + static const int FLOAT_TOKEN = 258; + // Extend this list in your subclass to make a more advanced parser. + + Parser(); + Parser(const QString& _str); + ~Parser(); + + /** + * Start a new parse. + */ + void start(const QString& _str); + + /** + * Peek at the next character; + */ + int nextChar() const { return m_nextChar; } + + /** + * Peek at the next token. + */ + int nextToken() const { return m_nextToken; } + + /** + * Get the value stored for different types of tokens. + */ + int intVal() const { return m_intVal; } + float floatVal() const { return m_floatVal; } + +private: + + // Try to parse some special datatypes. + bool parseInt(int *_result); + bool parseSimpleFloat(double *_result); + +protected: + + /** + * Make the next character the current one. + */ + int getNextChar(); + + /** + * Make the next non-space character the current one. + */ + int skipWhitespace(); + + /** + * Fetches the next token. + */ + virtual int getNextToken(); + +private: + QString m_str; + int m_index; + int m_nextChar; + + protected: + + // Lexical analysis and token handling. These members need to be + // protected instead of private since we want to be able to + // reimplement getNextToken(). + + /** + * The next token to be used in the parser. + */ + int m_nextToken; + + // Values for the respective token. These could be made into a + // union, but I don't think it is necessary to bother, since they + // are so few and we don't instantiate a lot of copies of the + // parser. + int m_intVal; // Valid if m_nextToken == INT_TOKEN + double m_floatVal; // Valid if m_nextToken == FLOAT_TOKEN +}; + +#endif diff --git a/kalzium/src/periodictableview.cpp b/kalzium/src/periodictableview.cpp new file mode 100644 index 00000000..b466cffa --- /dev/null +++ b/kalzium/src/periodictableview.cpp @@ -0,0 +1,1382 @@ +/*************************************************************************** + * Copyright (C) 2003-2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ +#include "periodictableview.h" +#include "prefs.h" +#include "element.h" +#include "kalziumtip.h" +#include "kalziumutils.h" +#include "kalziumdataobject.h" + +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +PerodicTableView::PerodicTableView(QWidget *parent, const char *name) + : QWidget(parent, name), m_kalziumTip(0), table(0), table2(0) +{ + d = KalziumDataObject::instance(); + + + // No selection + unSelect(); + +#if 0 + connect( this, SIGNAL( tableClicked( QPoint ) ), + this, SLOT( selectPoint( QPoint ) ) ); +#endif + connect( this, SIGNAL( ToolTip( int ) ), + this, SLOT( slotToolTip( int ) ) ); + + connect( &HoverTimer, SIGNAL( timeout() ), + this, SLOT( slotTransientLabel() ) ); + + connect( &MouseoverTimer, SIGNAL( timeout() ), + this, SLOT( slotMouseover() ) ); + + setMouseTracking( true ); + + //JH: eliminates flicker on redraw + setBackgroundMode( QWidget::NoBackground ); + + m_molcalcIsActive = false; + m_showTooltip = true; + m_showLegend = Prefs::showlegend(); + m_showLegendTooltip = Prefs::tooltip(); + m_timeline = false; + m_showSOM = false; + m_showGradient = false; + m_tooltipsEnabled = Prefs::tooltip(); + + reloadColours(); + + //IUPAC + m_IUPAClist.append( "IA"); + m_IUPAClist.append( "IIA"); + m_IUPAClist.append( "IIIB"); + m_IUPAClist.append( "IVB"); + m_IUPAClist.append( "VB"); + m_IUPAClist.append( "VIB"); + m_IUPAClist.append( "VIIB"); + m_IUPAClist.append( "VIII"); + m_IUPAClist.append( "VIII"); + m_IUPAClist.append( "VIII"); + m_IUPAClist.append( "IB"); + m_IUPAClist.append( "IIB"); + m_IUPAClist.append( "IIIA"); + m_IUPAClist.append( "IVA"); + m_IUPAClist.append( "VA"); + m_IUPAClist.append( "VIA"); + m_IUPAClist.append( "VIIA"); + m_IUPAClist.append( "VIIIA"); + + //oldIUPAC + m_IUPACOLDlist.append( "1A"); + m_IUPACOLDlist.append( "2A"); + m_IUPACOLDlist.append( "3A"); + m_IUPACOLDlist.append( "4A"); + m_IUPACOLDlist.append( "5A"); + m_IUPACOLDlist.append( "6A"); + m_IUPACOLDlist.append( "7A"); + m_IUPACOLDlist.append( "8"); + m_IUPACOLDlist.append( "8"); + m_IUPACOLDlist.append( "8"); + m_IUPACOLDlist.append( "1B"); + m_IUPACOLDlist.append( "2B"); + m_IUPACOLDlist.append( "3B"); + m_IUPACOLDlist.append( "4B"); + m_IUPACOLDlist.append( "5B"); + m_IUPACOLDlist.append( "6B"); + m_IUPACOLDlist.append( "7B"); + m_IUPACOLDlist.append( "0"); + + table = new QPixmap(); + table2 = new QPixmap(); + + m_kalziumTip = new KalziumTip( this ); + + //JH: Start with a full draw + doFullDraw = true; + + // according to carsten :) + setMinimumSize(ELEMENTSIZE*18+1, ELEMENTSIZE*10+30); +} + +void PerodicTableView::reloadColours() +{ + color_s = Prefs::block_s(); + color_p = Prefs::block_p(); + color_d = Prefs::block_d(); + color_f = Prefs::block_f(); + color_1 = Prefs::group_1(); + color_2 = Prefs::group_2(); + color_3 = Prefs::group_3(); + color_4 = Prefs::group_4(); + color_5 = Prefs::group_5(); + color_6 = Prefs::group_6(); + color_7 = Prefs::group_7(); + color_8 = Prefs::group_8(); + color_ba = Prefs::beh_basic(); + color_ac = Prefs::beh_acidic(); + color_neu = Prefs::beh_neutral(); + color_amp = Prefs::beh_amphoteric(); + c_alkalie = Prefs::alkalie(); + c_rare = Prefs::rare(); + c_nonmetal = Prefs::nonmetal(); + c_alkaline = Prefs::alkaline(); + c_other_metal = Prefs::other_metal(); + c_halogene = Prefs::halogene(); + c_transition = Prefs::transition(); + c_noble_gas = Prefs::noble_gas(); + c_metalloid = Prefs::metalloid(); + c_solid = Prefs::color_solid(); + c_vapor = Prefs::color_vapor(); + c_liquid = Prefs::color_liquid(); +} + +void PerodicTableView::slotToolTip( int number ) +{ + if ( !m_showTooltip || !m_tooltipsEnabled ) + return; //don't update if the table is locked + + m_tooltipElementNumber = number; + + QWidget *p = 0; + if ( dynamic_cast( parent() ) ) + p = static_cast( parent() ); + + if( p ) + m_kalziumTip->showTip( mapFromGlobal(QCursor::pos()), + d->element(number), + p->width(), + p->height() ); +} + +PerodicTableView::~PerodicTableView(){} + +void PerodicTableView::activateColorScheme( const int nr ) +{ + m_currentScheme = nr; + + EList::ConstIterator it = d->ElementList.begin(); + const EList::ConstIterator itEnd = d->ElementList.end(); + + if ( m_currentScheme == PerodicTableView::NOCOLOUR ) //normal view, no colors + { + const QColor color = Prefs::noscheme(); + while ( it != itEnd ) + { + ( *it )->setElementColor( color ); + ++it; + } + } + else if ( m_currentScheme == PerodicTableView::GROUPS ) //groups view + { + + static QString group; + + while ( it != itEnd ) + { + group = ( *it )->group(); + + if (group == QString("1")) { + ( *it )->setElementColor( color_1 ); + } + if (group == QString("2")){ + ( *it )->setElementColor( color_2 ); + } + if (group == QString("3")){ + ( *it )->setElementColor( color_3 ); + } + if (group == QString("4")){ + ( *it )->setElementColor( color_4 ); + } + if (group == QString("5")){ + ( *it )->setElementColor( color_5 ); + } + if (group == QString("6")){ + ( *it )->setElementColor( color_6 ); + } + if (group == QString("7")){ + ( *it )->setElementColor( color_7 ); + } + if (group == QString("8")){ + ( *it )->setElementColor( color_8 ); + } + + ++it; + } + } + else if ( m_currentScheme == PerodicTableView::BLOCK ) //block view + { + static QString block; + while ( it != itEnd ) + { + block = (*it)->block(); + + if (block == QString("s")) { + (*it)->setElementColor( color_s ); + } + if (block == QString("p")) { + (*it)->setElementColor( color_p ); + } + if (block == QString("d")) { + (*it)->setElementColor( color_d ); + } + if (block == QString("f")) { + (*it)->setElementColor( color_f ); + } + ++it; + } + } + else if ( m_currentScheme == PerodicTableView::ACIDIC ) //acidic beh + { + static QString acidicbeh; + + while ( it != itEnd ) + { + acidicbeh = ( *it )->acidicbeh(); + + if (acidicbeh == QString("0")) { + (*it)->setElementColor( color_ac ); + } + if (acidicbeh == QString("1")){ + (*it)->setElementColor( color_ba ); + } + if (acidicbeh == QString("2")){ + (*it)->setElementColor( color_neu ); + } + if (acidicbeh == QString("3")){ + (*it)->setElementColor( color_amp ); + } + ++it; + } + } + else if ( m_currentScheme == PerodicTableView::FAMILY ) //familiy of the element + { + static QString family; + + while ( it != itEnd ) + { + family = ( *it )->family(); + + if ( family == "Noblegas" ){ + (*it)->setElementColor( c_noble_gas ); + } + if ( family == "Non-Metal" ){ + (*it)->setElementColor( c_nonmetal ); + } + if ( family == "Rare_Earth" ){ + (*it)->setElementColor( c_rare ); + } + if ( family == "Alkaline_Earth" ){ + (*it)->setElementColor( c_alkaline ); + } + if ( family == "Alkali_Earth" ){ + (*it)->setElementColor( c_alkalie ); + } + if ( family == "Transition" ){ + (*it)->setElementColor( c_transition ); + } + if ( family == "Other_Metal" ){ + (*it)->setElementColor( c_other_metal ); + } + if ( family == "Metalloids" ){ + (*it)->setElementColor( c_metalloid ); + } + if ( family == "Halogene" ){ + (*it)->setElementColor( c_halogene ); + } + + ++it; + } + } + +} + +void PerodicTableView::resizeEvent( QResizeEvent * /*e*/ ) +{ + table->resize( width(), height() ); + table2->resize( width(), height() ); + // XXX: I know it isn't the best way, but otherwise the table won't be redrawn + // on repaint... Feel *free* to remove these two lines if you foind a better + // solution... + doFullDraw = true; + update(); +} + +void PerodicTableView::paintEvent( QPaintEvent * /*e*/ ) +{ + QPainter p; + + //JH: I have split the drawing into two pixmaps: table and table2. + //table contains the "static" PerodicTableView table, and does not change very often. + //table2 contains the tooltips and any other dynamic overlays. + //Usually, we can skip the code which renders the table, and just use the + //image stored in table...when doFullDraw==false, the rendering code is skipped. + if ( doFullDraw ) + { + //DEBUG + kdDebug() << "Drawing full table" << endl; + + p.begin( table ); + p.fillRect( 0, 0, width(), height(), paletteBackgroundColor() ); + + // Draw the numbers above the table. + drawNumeration( &p ); + + drawLegend( &p ); + + if ( m_timeline ) + { //use timeline + drawTimeLine(& p ); + p.end(); + + *table2 = *table; + bitBlt( this, 0, 0, table2 ); + return; + } + if ( som() ) + {//use state of matter + drawSOMPerodicTableView(& p ); + p.end(); + + *table2 = *table; + bitBlt( this, 0, 0, table2 ); + return; + } + if ( gradient() ) + {//show a gradient + calculateGradient(& p ); + p.end(); + + *table2 = *table; + bitBlt( this, 0, 0, table2 ); + return; + } + + drawPerodicTableView( &p, m_currentScheme == CRYSTAL ); + + paintCurrentSelection(); + + p.end(); + + doFullDraw = false; + } + + //JH: Ok, now table contains the static PerodicTableView table, and we may need to draw + //a tooltip on it. However, we don't want to ruin the stored table pixmap, + //so let's copy it to table2 and add the tooltip there. + *table2 = *table; + + //JH: Finally, bitBlt the table2 pixmap to the widget + bitBlt( this, 0, 0, table2 ); +} + +void PerodicTableView::paintCurrentSelection() +{ + if (m_currentPoint.x() == -1) + return; + + int x = (m_currentPoint.x()-1)*ELEMENTSIZE; + int y = m_currentPoint.y()*ELEMENTSIZE; + + // make a small gap (ELEMENTSIZE/3) over the rare earths + if (m_currentPoint.y() > 7) y += ELEMENTSIZE/3; + + QPainter p; + p.begin(table); + + QPen pen; + pen.setStyle( DotLine ); + pen.setWidth( 4 ); + pen.setColor( Qt::blue ); + p.setPen( pen ); + + p.drawEllipse( x-10,y-10,ELEMENTSIZE+20,ELEMENTSIZE+20 ); + pen.setWidth( 3 ); + pen.setColor( Qt::red ); + p.setPen( pen ); + p.drawEllipse( x-5,y-5,ELEMENTSIZE+10,ELEMENTSIZE+10 ); + + p.end(); +} + +void PerodicTableView::drawLegendToolTip( QPainter* p ) +{ + kdDebug() << "PerodicTableView::drawLegendToolTip()" << endl; + if(!m_showLegendTooltip || !m_showLegend) return; + + QString text; + + switch ( m_currentScheme ) { + //No Legend drawn as only one colour is used + case PerodicTableView::NOCOLOUR: + break; + case PerodicTableView::BLOCK: + text = i18n( "The periodic table can be split up into four areas:\n the s-, p-, d- and f-Block. The name indicates which orbit\n is being filled last. For example, all elements in the s-block\n fill up the s-orbits." ); + break; + case PerodicTableView::GROUPS: + text = i18n( "The periodic table can be split up into groups:\n All elements in a group show similar behaviour"); + break; + case PerodicTableView::ACIDIC: + text = i18n( "The periodic table can be split up in groups of \nelements with different acidic behaviour."); + break; + case PerodicTableView::FAMILY: + text = i18n( "The periodic table can be split up into several families."); + break; + } + + const int x1 = mapFromGlobal( QCursor::pos() ).x(); + const int y1 = mapFromGlobal( QCursor::pos() ).y(); + + static const int padding = 3; + + QFont fB = KGlobalSettings::generalFont(); + fB.setPointSize( fB.pointSize() + 4 ); + p->setFont( fB ); + + QRect bRect( 0, 0, 1000, 1000 ); + bRect = p->boundingRect( bRect, AlignLeft|AlignTop, text ); + bRect.moveBy( x1, y1 ); + QRect bRectExt = bRect; + bRect.moveBy( padding, padding ); + bRectExt.setWidth( bRectExt.width() + 2 * padding ); + bRectExt.setHeight( bRectExt.height() + 2 * padding ); + + bool vertflipped = false; + if ( bRectExt.bottom() > height() ) + { + bRectExt.moveBy( 0, - bRectExt.height() ); + bRect.moveBy( 0, - bRect.height() - 2 * padding ); + vertflipped = true; + } + if ( bRectExt.right() > width() ) + { + bRectExt.moveBy( - bRectExt.width(), 0 ); + bRect.moveBy( - bRect.width() - 2 * padding, 0 ); + } + else if ( !vertflipped ) + { + bRectExt.moveBy( 15, 0 ); + bRect.moveBy( 15, 0 ); + } + + p->setBrush(Qt::SolidPattern); + p->setBrush( QColor( 255, 255, 220 ) ); + p->drawRect( bRectExt ); + + p->setBrush( Qt::black ); + p->setBrush(Qt::NoBrush); + + p->drawText( bRect, AlignLeft|AlignTop, text ); +} + +void PerodicTableView::drawTimeLine( QPainter* p ) +{ + if ( !p ) return; + kdDebug() << "PerodicTableView::drawTimeLine: " << m_date << endl; + + if ( gradient() ) + activateColorScheme( PerodicTableView::NOCOLOUR ); + + EList::ConstIterator it = d->ElementList.begin(); + const EList::ConstIterator itEnd = d->ElementList.end(); + + bool simple = Prefs::pselook(); + + /** + * this loop iterates through all elements. The Elements + * draw themselfs, the PerodicTableView only tells them to do so + */ + while ( it != itEnd ) + { + if ( ( *it )->date() <= m_date ) + ( *it )->drawSelf( p, simple ); + else + ( *it )->drawGrayedOut( p ); + ++it; + } +} + +void PerodicTableView::drawLegend( QPainter* p ) +{ + if ( !p ) return; + + if ( !m_showLegend ) return; + + /* + * The legend is drawn in the big gap of the table. The gap has + * this size: + * + * width: ELEMENTSIZE * 10 + * height: ELEMENTSIZE * 3 + * + * We need to spare a few pixels on every side so that the legend + * does not collide with the elements + */ + + QFont legendFont = KGlobalSettings::generalFont(); + legendFont.setPointSize( legendFont.pointSize() + 1 ); + p->setFont( legendFont ); + + int legendLeft = ELEMENTSIZE * 5 / 2; + int legendTop = ELEMENTSIZE * 3 / 4; + int legendWidth = ELEMENTSIZE * 9; + int legendHeight = ELEMENTSIZE * 3; + + int x1 = legendLeft + ELEMENTSIZE / 2; + int x2 = legendLeft + ELEMENTSIZE * 5; + + /* + * one field is allowed to be half the gap minus 10 pixel + */ + int fieldsize = ELEMENTSIZE*5-10; + + /* + * one field is a maximum of half the size of an element + */ + int fieldheight = ELEMENTSIZE/2; + + + const int square_w = 18; + const int square_h = 18; + const int textOffset = square_w + 10; + + if ( !m_currentScheme == PerodicTableView::NOCOLOUR ) + p->fillRect(legendLeft, legendTop, legendWidth, legendHeight, + QColor(200, 200, 200)); + + if ( som() ) + { + p->fillRect(x1, fieldheight*2, square_w, square_h, c_solid ); + p->fillRect(x1, fieldheight*3, square_w, square_h, c_liquid ); + p->fillRect(x1, fieldheight*4, square_w, square_h, c_vapor ); + + p->drawText(x1 + textOffset, fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("Solid") ); + p->drawText(x1 + textOffset, fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("Liquid") ); + p->drawText(x1 + textOffset, fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("Vaporous") ); + return; + } + switch ( m_currentScheme ){ + //No Legend to be drawn as only one colour is used + case PerodicTableView::NOCOLOUR: + break; + case PerodicTableView::GROUPS: + p->fillRect( x1, fieldheight*2, square_w, square_h, color_1); + p->fillRect( x1, fieldheight*3, square_w, square_h, color_2); + p->fillRect( x1, fieldheight*4, square_w, square_h, color_3); + p->fillRect( x1, fieldheight*5, square_w, square_h, color_4); + p->fillRect( x2, fieldheight*2, square_w, square_h, color_5); + p->fillRect( x2, fieldheight*3, square_w, square_h, color_6); + p->fillRect( x2, fieldheight*4, square_w, square_h, color_7); + p->fillRect( x2, fieldheight*5, square_w, square_h, color_8 ); + + p->drawText( x1 + textOffset , fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 1") ); + p->drawText( x1 + textOffset , fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 2")); + p->drawText( x1 + textOffset , fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 3")); + p->drawText( x1 + textOffset , fieldheight*5, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 4")); + p->drawText( x2 + textOffset , fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 5")); + p->drawText( x2 + textOffset , fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 6")); + p->drawText( x2 + textOffset , fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 7")); + p->drawText( x2 + textOffset , fieldheight*5, fieldsize, fieldheight, Qt::AlignLeft, i18n("Group 8")); + break; + case PerodicTableView::BLOCK: + p->fillRect(x1, fieldheight*2, square_w, square_h, color_s ); + p->fillRect(x1, fieldheight*3, square_w, square_h, color_p ); + p->fillRect(x1, fieldheight*4, square_w, square_h, color_d ); + p->fillRect(x1, fieldheight*5, square_w, square_h, color_f ); + + p->drawText(x1 + textOffset, fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("s-Block") ); + p->drawText(x1 + textOffset, fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("p-Block") ); + p->drawText(x1 + textOffset, fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("d-Block") ); + p->drawText(x1 + textOffset, fieldheight*5, fieldsize, fieldheight, Qt::AlignLeft, i18n("f-Block") ); + break; + case PerodicTableView::ACIDIC: + p->fillRect(x1, fieldheight*2, square_w, square_h, color_ba ); + p->fillRect(x1, fieldheight*3, square_w, square_h, color_neu ); + p->fillRect(x1, fieldheight*4, square_w, square_h, color_ac ); + p->fillRect(x1, fieldheight*5, square_w, square_h, color_amp ); + + p->drawText(x1 + textOffset, fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("Basic") ); + p->drawText(x1 + textOffset, fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("Neutral") ); + p->drawText(x1 + textOffset, fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("Acidic") ); + p->drawText(x1 + textOffset, fieldheight*5, fieldsize, fieldheight, Qt::AlignLeft, i18n("both acidic and basic behaviour","Amphoteric") ); + break; + case PerodicTableView::FAMILY: + p->fillRect( x1, fieldheight*2, square_w, square_h, c_alkaline ); + p->fillRect( x2, fieldheight*2, square_w, square_h, c_rare ); + p->fillRect( x1, fieldheight*3, square_w, square_h, c_nonmetal ); + p->fillRect( x2, fieldheight*3, square_w, square_h, c_alkalie ); + p->fillRect( x1, fieldheight*4, square_w, square_h, c_other_metal ); + p->fillRect( x2, fieldheight*4, square_w, square_h, c_halogene ); + p->fillRect( x1, fieldheight*5, square_w, square_h, c_transition ); + p->fillRect( x2, fieldheight*5, square_w, square_h, c_noble_gas ); + p->fillRect( x1, fieldheight*6, square_w, square_h, c_metalloid ); + + p->drawText( x1 + textOffset , fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("Alkaline") ); + p->drawText( x2 + textOffset , fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("Rare Earth")); + p->drawText( x1 + textOffset , fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("Non-Metals")); + p->drawText( x2 + textOffset , fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("Alkalie-Metals")); + p->drawText( x1 + textOffset , fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("Other Metal")); + p->drawText( x2 + textOffset , fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("Halogene")); + p->drawText( x1 + textOffset , fieldheight*5, fieldsize, fieldheight, Qt::AlignLeft, i18n("Transition Metal")); + p->drawText( x2 + textOffset , fieldheight*5, fieldsize, fieldheight, Qt::AlignLeft, i18n("Noble Gas")); + p->drawText( x1 + textOffset , fieldheight*6, fieldsize, fieldheight, Qt::AlignLeft, i18n("Metalloid")); + break; + case PerodicTableView::CRYSTAL: + p->fillRect(x1, fieldheight*2, square_w, square_h, Qt::cyan ); + p->fillRect(x1, fieldheight*3, square_w, square_h, Qt::red ); + p->fillRect(x1, fieldheight*4, square_w, square_h, Qt::yellow ); + p->fillRect(x1, fieldheight*5, square_w, square_h, Qt::green ); + p->fillRect(x1, fieldheight*6, square_w, square_h, Qt::white ); + + p->drawText(x1 + textOffset, fieldheight*2, fieldsize, fieldheight, Qt::AlignLeft, i18n("Own") ); + p->drawText(x1 + textOffset, fieldheight*3, fieldsize, fieldheight, Qt::AlignLeft, i18n("bcc, body centered cubic") ); + p->drawText(x1 + textOffset, fieldheight*4, fieldsize, fieldheight, Qt::AlignLeft, i18n("hdp, hexagonal") ); + p->drawText(x1 + textOffset, fieldheight*5, fieldsize, fieldheight, Qt::AlignLeft, i18n("ccp, cubic close packed") ); + p->drawText(x1 + textOffset, fieldheight*6, fieldsize, fieldheight, Qt::AlignLeft, i18n("Unknown") ); + break; + } +} + +void PerodicTableView::drawNumeration( QPainter* p ) +{ + if ( !p ) return; + + switch(m_num){ + case PerodicTableView::NO: + return; + case PerodicTableView::CAS: + for(int i = 0; i < 18 ; ++i ) + { + p->drawText( i*ELEMENTSIZE,0 ,ELEMENTSIZE,ELEMENTSIZE, Qt::AlignCenter, QString::number(i+1)); + } + break; + case PerodicTableView::IUPAC: + for(int i = 0; i < 18 ; ++i ) + { + p->drawText( i*ELEMENTSIZE,0 ,ELEMENTSIZE,ELEMENTSIZE, Qt::AlignCenter, m_IUPAClist[i]); + } + break; + case PerodicTableView::IUPACOLD: + for(int i = 0; i < 18 ; ++i ) + { + p->drawText( i*ELEMENTSIZE,0 ,ELEMENTSIZE,ELEMENTSIZE, Qt::AlignCenter, m_IUPACOLDlist[i]); + } + break; + } +} + + +void PerodicTableView::drawSOMPerodicTableView( QPainter* p ) +{ + EList::ConstIterator it = d->ElementList.begin(); + const EList::ConstIterator itEnd = d->ElementList.end(); + + while ( it != itEnd ) + { + ( *it )->drawStateOfMatter( p, m_temperature ); + ++it; + } + +} + +void PerodicTableView::slotTransientLabel() +{ + QPoint point = ElementUnderMouse(); + + int X = point.x(); + int Y = point.y(); + + const int num = ElementNumber( X, Y ); + if ( num ) + emit ToolTip( num ); + else if ( pointerOnLegend( X, Y ) ) //show the tooltip for the lengend + { + m_showLegendTooltip = true; + update(); + } + else + m_showLegendTooltip = false; +} + +void PerodicTableView::mousePressEvent( QMouseEvent *) +{ + if( m_kalziumTip->isVisible() ) + m_kalziumTip->hide(); +} + +void PerodicTableView::mouseMoveEvent( QMouseEvent * /*mouse*/ ) +{ + //JH: only update() if we were showing a tooltip + if ( m_tooltipElementNumber || m_showLegendTooltip ) + { + //this invalidates the number. If the mouse + //is moved, the number is invalid. + m_tooltipElementNumber = 0; + m_showLegendTooltip = false; + update(); + } + + if( m_kalziumTip->isVisible() ) + { +// kdDebug()<< "visible" << endl; + QPoint point = ElementUnderMouse(); + + int X = point.x(); + int Y = point.y(); + + const int num = ElementNumber( X, Y ); + + if ( num != 0 ) + emit ToolTip( num ); + else + m_kalziumTip->hide(); + } + + HoverTimer.start( 500, true ); //JH: true = run timer once, not continuously + MouseoverTimer.start( 200, true ); //JH: true = run timer once, not continuously +} + +bool PerodicTableView::pointerOnLegend(int X, int Y) +{ + if ( X > 2 && X < 13 ) + { + if ( Y < 4 && Y > 0 ) + { + return true; + } + } + + return false; +} + +void PerodicTableView::mouseReleaseEvent( QMouseEvent *mouse ) +{ + ///first: find out the position + int X = mouse->x()/ELEMENTSIZE; + + //for the y-position I need to substract ELEMENTSIZE pixel because + //the whole table doesn't start at (0,0) but at (0,ELEMENTSIZE) + int Y = mouse->y()-ELEMENTSIZE; + + // ignore clicks on the small gap over rare earth + if (Y >= (ELEMENTSIZE*7) && Y < (ELEMENTSIZE*7+ELEMENTSIZE/3+1)) return; + + // mind the gap! + if (Y > (ELEMENTSIZE*7)) Y -= ELEMENTSIZE/3; + Y /= ELEMENTSIZE; + + X += 1; + Y += 1; + + QPoint point( X,Y ); + emit tableClicked( point ); + + const int num = ElementNumber( X, Y ); + + //kdDebug() << "Element clicked: " << num << endl; + + //If no element was clicked ElementNumber() will return 0 + if ( num ) { + emit ElementClicked( num ); + selectPoint( point ); + } +} + +int PerodicTableView::ElementNumber( int X, int Y ) +{ + //from this on I can use X and Y. Both contain the position of an element in the + //complete PerodicTableView. Eg, He is 1,18 and Na is 2,1 + + CList::ConstIterator it = d->CoordinateList.begin(); + const CList::ConstIterator itEnd = d->CoordinateList.end(); + + int counter = 1; + while ( it != itEnd ) + {//iterate through the list of coordinates and compare the x/y values. + //finally, if the 20'es iterator has the same coordinates Element 20 + //has been clicked. + + coordinate c = *it; + if ( c.x == X ) + { + if ( c.y == Y ) + {//coordinates match. Return the number of the element. + return counter; + } + } + ++it; + ++counter; + } + + return 0; +} + + +void PerodicTableView::unSelect() +{ + m_currentPoint = QPoint(-1, -1); + + // Full draw needed to redraw the select mark. + setFullDraw(); + update(); +} + +void PerodicTableView::selectPoint( const QPoint& point ) +{ + kdDebug() << "PerodicTableView::selectPoint " << point << endl; + + m_currentPoint = point; + + // Full draw needed to redraw the select mark. + setFullDraw(); + update(); +} + +void PerodicTableView::selectElement( int num ) +{ + kdDebug() << "PerodicTableView::selectElement " << num << endl; + + selectPoint( d->element( num )->coords() ); +} + +void PerodicTableView::drawPerodicTableView( QPainter* p, bool isCrystal ) +{ + EList::ConstIterator it = d->ElementList.begin(); + const EList::ConstIterator itEnd = d->ElementList.end(); + + bool simple = Prefs::pselook(); + /** + * this loop iterates through all elements. The Elements + * draw themselfs, the PerodicTableView only tells them to do so + */ + while ( it != itEnd ) + { + ( *it )->drawSelf( p, simple, isCrystal ); + ++it; + } +} + +//CN This is called for *every* drawing of the table. This means +//a lot overload... I would be better to chache the values in +//member variables an only check if they need an update. +void PerodicTableView::calculateGradient( QPainter *p ) +{ + EList::ConstIterator it = d->ElementList.begin(); + const EList::ConstIterator itEnd = d->ElementList.end(); + + QValueList tmpList; + switch ( m_gradientType ) + { + case Element::ATOMICRADIUS: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->radius(Element::ATOMIC) ); + } + break; + case Element::COVALENTRADIUS: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->radius(Element::COVALENT) ); + } + break; + case Element::VDWRADIUS: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->radius(Element::VDW) ); + } + break; + case Element::MASS: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->mass() ); + } + break; + case Element::DENSITY: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->density() ); + } + break; + case Element::BOILINGPOINT: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->boiling() ); + } + break; + case Element::MELTINGPOINT: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->melting() ); + } + break; + case Element::EN: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->electroneg() ); + } + break; + case Element::EA: + for (; it != itEnd; ++it ) + { + tmpList.append( ( *it )->electroaf() ); + } + break; + } + + QValueList::iterator dit = tmpList.begin(); + const QValueList::iterator ditEnd = tmpList.end(); + + double tmpMin = *dit; + double tmpMax = *dit; + for ( ; dit != ditEnd; ++dit ) + { + if (( *dit ) == 0 ) continue; + if ( ( *dit ) < tmpMin ) + tmpMin = *dit; + if ( ( *dit ) > tmpMax ) + tmpMax = *dit; + } + + //now draw the gradient-table + drawGradientPerodicTableView( p, tmpMin, tmpMax ); +} + + + +void PerodicTableView::drawGradientPerodicTableView( QPainter *p, const double min, const double max ) +{ + QString title = QString::null; + + const double var = max-min; + EList::ConstIterator it = d->ElementList.begin(); + const EList::ConstIterator itEnd = d->ElementList.end(); + + + /** + * this loop iterates through all elements. The Elements + * draw themselves, the PerodicTableView only tells them to do so + */ + it = d->ElementList.begin(); + switch ( m_gradientType ) + { + case Element::ATOMICRADIUS: + title = i18n( "Gradient: Atomic Radius" ); + while ( it != d->ElementList.end() ) + { + double value = ( *it )->radius( Element::ATOMIC ); + double coeff = ( value - min )/var; + + drawGradientButton( p, *it, coeff, value, min ); + + ++it; + } + break; + case Element::VDWRADIUS: + title = i18n( "Gradient: van der Waals Radius" ); + while ( it != d->ElementList.end() ) + { + double value = ( *it )->radius( Element::VDW ); + double coeff = ( value - min )/var; + + drawGradientButton( p, *it, coeff, value, min ); + + ++it; + } + break; + case Element::COVALENTRADIUS: + title = i18n( "Gradient: Covalent Radius" ); + while ( it != d->ElementList.end() ) + { + double value = ( *it )->radius( Element::COVALENT ); + double coeff = ( (*it)->radius(Element::COVALENT) - min )/var; + + drawGradientButton( p, *it, coeff, value, min ); + + ++it; + } + break; + case Element::MASS: + title = i18n( "Gradient: Atomic Mass" ); + while ( it != d->ElementList.end() ) + { + double coeff = ( (*it)->mass() - min )/var; + drawGradientButton( p, *it, coeff, ( *it )->mass(), min ); + + ++it; + } + break; + case Element::DENSITY: + title = i18n( "Gradient: Atomic Density" ); + while ( it != d->ElementList.end() ) + { + double coeff = ( (*it)->density() - min )/var; + + drawGradientButton( p, *it, coeff, ( *it )->density(), min ); + ++it; + } + break; + case Element::BOILINGPOINT: + title = i18n( "Gradient: Boiling point" ); + while ( it != d->ElementList.end() ) + { + double coeff = ( (*it)->boiling() - min )/var; + drawGradientButton( p, *it, coeff, ( *it )->boiling(), min ); + + ++it; + } + break; + case Element::MELTINGPOINT: + title = i18n( "Gradient: Melting point" ); + while ( it != d->ElementList.end() ) + { + double coeff = ( (*it)->melting() - min )/var; + drawGradientButton( p, *it, coeff, ( *it )->melting(), min ); + + ++it; + } + break; + case Element::EN: + title = i18n( "Gradient: Electronegativity" ); + while ( it != d->ElementList.end() ) + { + double coeff = ( (*it)->electroneg() - min )/var; + drawGradientButton( p, *it, coeff, ( *it )->electroneg(), min ); + + ++it; + } + break; + case Element::EA: + title = i18n( "Gradient: Electron affinity" ); + double tmpVar = -1*(min - max); + while ( it != d->ElementList.end() ) + { + if( (*it)->electroaf() == 0.0) + drawGradientButton( p, *it,-1.0, (*it )->electroaf(), min ); + else + { + double coeff = ( max - (*it)->electroaf() )/tmpVar; + drawGradientButton( p, *it, coeff, (*it )->electroaf(), min ); + } + + ++it; + } + break; + } + + // Now draw the legend. + int x = ELEMENTSIZE*2+5; + int y = 5; + //int w = ELEMENTSIZE*10-5; + //int h = ELEMENTSIZE*4-5; + + // Create the gradient image. + QSize s( ELEMENTSIZE*7+20, 20 ); + QImage img = KImageEffect::gradient ( s, Qt::white, Qt::red, + KImageEffect::HorizontalGradient ); + QPixmap pm( img ); + + /** + * now find the optimum stringsize for the caption + * i18n( "Gradient: van der Waals Radius" ); is at least + * for english the longest possible string. As "van der Waals" + * is a name it should be the same in all languages and be + * probably always the longest string + */ + QString tmp = i18n( "Gradient: van der Waals Radius" ); + QRect rect(x+5, y+50, ELEMENTSIZE*10,20); + QFont font = p->font(); + int maxSize = KalziumUtils::maxSize( tmp, rect, p->font(), p, 8, 24 ); + kdDebug() << "maxSize: " << maxSize << endl; + font.setPointSize(maxSize); + p->setFont(font); + + p->drawText( x+5, y+50, ELEMENTSIZE*10,20, Qt::AlignCenter, title ); + p->drawPixmap( x+50, y+80, pm ); + + if ( m_gradientType == Element::EA ) + { + // FIXME: In the lines below, "30" is the max allowed text + // height. This should be calculated from the font + // metrics, not hard coded. + p->drawText( x+50,y+100,ELEMENTSIZE*7+20,30, Qt::AlignRight, QString::number( min ) ); + p->drawText( x+50,y+100,ELEMENTSIZE*7+20,30, Qt::AlignLeft, QString::number( max ) ); + } + else + { + p->drawText( x+50,y+100,ELEMENTSIZE*7+20,30, Qt::AlignRight, QString::number( max ) ); + p->drawText( x+50,y+100,ELEMENTSIZE*7+20,30, Qt::AlignLeft, QString::number( min ) ); + + } +} + +QPoint PerodicTableView::ElementUnderMouse() +{ + int X = mapFromGlobal( QCursor::pos() ).x()/ELEMENTSIZE; + int Y = mapFromGlobal( QCursor::pos() ).y( )-ELEMENTSIZE; + + // mind the gap over rare earth! + if (Y >= (ELEMENTSIZE*7) && Y < (ELEMENTSIZE*7+ELEMENTSIZE/3+1)) return QPoint( 0, 0 ); + + if (Y > (ELEMENTSIZE*7)) Y -= ELEMENTSIZE/3; + + Y /= ELEMENTSIZE; + + X += 1; + Y += 1; + + return QPoint( X,Y ); +} + + +void PerodicTableView::slotMouseover() +{ + QPoint point = ElementUnderMouse(); + + int num = ElementNumber( point.x(), point.y() ); + if ( num ) + emit MouseOver( num ); +} + +void PerodicTableView::drawGradientButton( QPainter *p, Element* e, double coeff, double value, double minValue ) +{ + if ( value >= minValue && coeff != -1.0) + { + QColor c = calculateColor( coeff ); + QString v = KalziumUtils::localizedValue( KalziumUtils::strippedValue( value ), 6 ); + e->drawGradient( p, v, c ); + } + else + e->drawGradient( p, i18n("It means: Not Available. Translators: keep it as short as you can!", "N/A"), Qt::lightGray ); +} + +QColor PerodicTableView::calculateColor( const double coeff ) +{ + const QColor color2 = Qt::white; + const QColor color1 = Qt::red; + + int red = (int)( (color1.red() - color2.red()) * coeff + color2.red() ); + int green = (int)( (color1.green() - color2.green()) * coeff + color2.green() ); + int blue = (int)( (color1.blue() - color2.blue()) * coeff + color2.blue() ); + + return QColor( red, green, blue ); +} + +void PerodicTableView::setLook( PerodicTableView::SCHEMETYPE type, int which ) +{ + m_currentScheme = type; + + EList::ConstIterator it = d->ElementList.begin(); + const EList::ConstIterator itEnd = d->ElementList.end(); + + switch ( type ) + { + case NOCOLOUR: + { + const QColor color = Prefs::noscheme(); + while ( it != itEnd ) + { + ( *it )->setElementColor( color ); + ++it; + } + setGradient( false ); + break; + } + case PerodicTableView::GROUPS: // group view + { + QString group; + + while ( it != itEnd ) + { + group = ( *it )->group(); + + if (group == QString("1")) { + ( *it )->setElementColor( color_1 ); + } + if (group == QString("2")){ + ( *it )->setElementColor( color_2 ); + } + if (group == QString("3")){ + ( *it )->setElementColor( color_3 ); + } + if (group == QString("4")){ + ( *it )->setElementColor( color_4 ); + } + if (group == QString("5")){ + ( *it )->setElementColor( color_5 ); + } + if (group == QString("6")){ + ( *it )->setElementColor( color_6 ); + } + if (group == QString("7")){ + ( *it )->setElementColor( color_7 ); + } + if (group == QString("8")){ + ( *it )->setElementColor( color_8 ); + } + + ++it; + } + setGradient( false ); + break; + } + case PerodicTableView::BLOCK: //block view + { + static QString block; + while ( it != itEnd ) + { + block = (*it)->block(); + + if (block == QString("s")) { + (*it)->setElementColor( color_s ); + } + if (block == QString("p")) { + (*it)->setElementColor( color_p ); + } + if (block == QString("d")) { + (*it)->setElementColor( color_d ); + } + if (block == QString("f")) { + (*it)->setElementColor( color_f ); + } + ++it; + } + setGradient( false ); + break; + } + case PerodicTableView::ACIDIC: //acidic beh + { + static QString acidicbeh; + while ( it != itEnd ) + { + acidicbeh = ( *it )->acidicbeh(); + + if (acidicbeh == QString("0")) { + (*it)->setElementColor( color_ac ); + } + if (acidicbeh == QString("1")){ + (*it)->setElementColor( color_ba ); + } + if (acidicbeh == QString("2")){ + (*it)->setElementColor( color_neu ); + } + if (acidicbeh == QString("3")){ + (*it)->setElementColor( color_amp ); + } + ++it; + } + setGradient( false ); + break; + } + case PerodicTableView::FAMILY: //familiy of the element + { + static QString family; + + while ( it != itEnd ) + { + family = ( *it )->family(); + + if ( family == "Noblegas" ){ + (*it)->setElementColor( c_noble_gas ); + } + if ( family == "Non-Metal" ){ + (*it)->setElementColor( c_nonmetal ); + } + if ( family == "Rare_Earth" ){ + (*it)->setElementColor( c_rare ); + } + if ( family == "Alkaline_Earth" ){ + (*it)->setElementColor( c_alkaline ); + } + if ( family == "Alkali_Earth" ){ + (*it)->setElementColor( c_alkalie ); + } + if ( family == "Transition" ){ + (*it)->setElementColor( c_transition ); + } + if ( family == "Other_Metal" ){ + (*it)->setElementColor( c_other_metal ); + } + if ( family == "Metalloids" ){ + (*it)->setElementColor( c_metalloid ); + } + if ( family == "Halogene" ){ + (*it)->setElementColor( c_halogene ); + } + + ++it; + } + setGradient( false ); + break; + } + case CRYSTAL: + { + QString structure; + while ( it != itEnd ) + { + structure = ( *it )->crystalstructure(); + if ( structure == "own") + (*it)->setElementColor( Qt::cyan ); + else if ( structure == "bcc" ) + (*it)->setElementColor( Qt::red ); + else if ( structure == "hdp" ) + (*it)->setElementColor( Qt::yellow ); + else if ( structure == "ccp" ) + (*it)->setElementColor( Qt::green ); + else + (*it)->setElementColor( Qt::white ); + ++it; + } + setGradient( false ); + break; + } + case GRADIENT: + { + setGradient( true ); + setGradientType( which ); + break; + } + default: + ; + } + + Prefs::setColorschemebox( type ); + Prefs::writeConfig(); + + //JH: redraw the full table next time + setFullDraw(); + update(); +} + +#include "periodictableview.moc" diff --git a/kalzium/src/periodictableview.h b/kalzium/src/periodictableview.h new file mode 100644 index 00000000..632f5d57 --- /dev/null +++ b/kalzium/src/periodictableview.h @@ -0,0 +1,523 @@ +/*************************************************************************** + * Copyright (C) 2003-2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#ifndef PerodicTableView_H +#define PerodicTableView_H + +class QLabel; +class QPixmap; +class QPoint; +class QVBoxLayout; +class Element; +class KalziumDataObject; +class KalziumTip; + +#include +#include +#include + +// A PerodicTableView is ... +/** + * @short basic class for the specific PerodicTableViews + * @author Carsten Niehaus + */ +class PerodicTableView : public QWidget +{ + Q_OBJECT + + public: + /** + * Constructor + * @param parent parent widget + * @param name name of this widget + */ + PerodicTableView( QWidget *parent = 0, const char *name = 0); + ~PerodicTableView(); + + enum SCHEMETYPE + { + NOCOLOUR = 0, + GROUPS, + BLOCK, + ACIDIC, + FAMILY, + GRADIENT, + CRYSTAL + }; + + enum NUMERATIONTYPE + { + NO=0, /// no numeration + CAS = 1, /// Chemical Abstract Service + IUPAC = 2, /// International Union of Pure and Applied Chemistry + IUPACOLD = 3 /// old IUPAC numeration + }; + + /** + * if this mode is activated a click on a button will not open + * a information dialog + */ + virtual void activateMolcalcmode( bool mode ){ + m_molcalcIsActive = mode; + } + + /** + * @return if the molcalc mode is active or not + */ + virtual bool molcalcMode() const{ + return m_molcalcIsActive; + } + + /** + * sets the NUMERATIONTYPE @p num of the periodic table + * @see NUMERATIONTYPE + */ + void setNumerationType( NUMERATIONTYPE num ){ + m_num = num; + update(); + } + /** + * @return whether the tooltips are enabled + */ + bool tooltipsEnabled() const{ + return m_tooltipsEnabled; + } + + /** + * if @p enabled is true the tooltips + * will be enabled + */ + void setTooltipsEnabled( bool enabled ){ + m_tooltipsEnabled = enabled; + } + + /** + * This method sets the colors of the PerodicTableView. + * @param nr takes 5 different values: + * @li normal view + * @li groups + * @li blocks + * @li state of matter + * @li acidic behavior + * @li family view + */ + void activateColorScheme( const int nr); + + /** + * @return the short and descriptive name of this PerodicTableView + */ + QString shortName() const{ + return m_ShortName; + } + + /** + * if @p show is true the tooltip will be displayed + */ + void setShowTooltip( bool show ){ + m_showTooltip = show; + } + + /** + * @return whether tooltips will be displayed + */ + bool showTooltip() const { + return m_showTooltip; + } + + /** + * @return whether if the SOM is active or not + */ + bool som() const{ + return m_showSOM; + } + + void activateSOMMode( bool som ){ + m_showSOM = som; + setFullDraw(); + update(); + } + + /** + * @return if the gradient mode is active + */ + bool gradient() const{ + return m_showGradient; + } + + /** + * Defines if the gradient mode will be activated or + * deactivated + * @param gradient defines if the gradient mode should be activated or not + */ + void setGradient( bool gradient ){ + m_showGradient = gradient; + setFullDraw(); + update(); + } + + //XXX can't use Element::TYPE here... why? + void setGradientType( int type ){ + m_gradientType = type; + } + + /** + * if false, the user disabled tooltips + */ + bool m_tooltipsEnabled; + + bool m_showLegendTooltip; + + /** + * activates or deactivates the legend + */ + void showLegend( bool show ){ + m_showLegend = show; + } + + bool showLegend() const{ + return m_showLegend; + } + + bool timeline() const{ + return m_timeline; + } + + void setTimeline( bool timeline ){ + if ( m_timeline != timeline ) + m_timeline = timeline; + } + + int date() const{ + return m_date; + } + + /** + * load the colours from the config file. This is done + * on startup and everytime the user changed the configuration + */ + void reloadColours(); + + /** + * JH: Draw the full table next time + */ + void setFullDraw(){ + doFullDraw = true; + } + + /** + * @param type set the scheme + * @param which set the type of gradient + * @see Element::TYPE + */ + void setLook( PerodicTableView::SCHEMETYPE type, int which = 0 ); + + /** + * This method paints the marker around the currently selected + * element + */ + virtual void paintCurrentSelection(); + + private: + /** + * if true the tooltips will be displayed + */ + bool m_showTooltip; + + /** + * the type of the gradient. + * @see Element::TYPE + */ + int m_gradientType; + + /** + * calculates the min and max values to prepare the painting + */ + void calculateGradient( QPainter* ); + + /** + * @return true if the mouse is over the legend area + */ + bool pointerOnLegend(int,int); + + /** + * @param p The painter for drawing + * @param e the element which is to be drawn + * @param coeff ? + * @param value the value + * @param minValue the smallest of all the values + */ + void drawGradientButton( QPainter* p, Element* e, double coeff, double value, double minValue ); + + /** + * calculates the color of an element which has a value which + * is @p percentage of the maximum value. This will be the + * color used in the gradient view for an element. + */ + QColor calculateColor( const double percentage ); + + /** + * the date used in the timeline + */ + int m_date; + + /** + * the current colour scheme + */ + int m_currentScheme; + + KalziumTip* m_kalziumTip; + bool m_timeline; + + /** + * the temperature of the table (for the SOM-feature) + */ + double m_temperature; + + /** + * if true the State Of Matter will be shown + */ + bool m_showSOM; + + /** + * if true the gradients will be shown + */ + bool m_showGradient; + + /** + * timer used for the tooltop + */ + QTimer HoverTimer, + MouseoverTimer; + + KalziumDataObject *d; + + /** + * the number of the element the mouse-cursor is over + */ + int m_tooltipElementNumber; + + /** + * @return the number of the element at position x/y. If there + * is no element it will return 0 + */ + int ElementNumber( int x, int y ); + + /** + * @return the coordinates of the element under the mouseCursor. + * For example, H will be 1/1 and Li will be 1/2 + */ + QPoint ElementUnderMouse(); + + /** + * the currently selected element (the x/y-coordinates) + */ + QPoint m_currentPoint; + + void mouseReleaseEvent( QMouseEvent* ); + void mousePressEvent( QMouseEvent* ); + void mouseMoveEvent( QMouseEvent* ); + + QStringList m_IUPAClist; + QStringList m_IUPACOLDlist; + + /** + * if the the legend will be displayed + */ + bool m_showLegend; + + /** + * this is a short, descriptive name of the PerodicTableView + */ + QString m_ShortName; + + /** + * true if the molcalc-mode is active + */ + bool m_molcalcIsActive; + + /** + * the type of the nummeration ( NO, CAS, IUPACOLD, IUPAC ) + */ + NUMERATIONTYPE m_num; + + /** + * implements double buffering of the widget. + */ + QPixmap *table; // The basic PerodicTableView + QPixmap *table2; // Basic PerodicTableView + extra data such as tooltip, etc + + /** + * used for bitBlit. If true the complete table will be drawn + */ + bool doFullDraw; + + + //I am holding all colours as member so that they don't need to + //be reloaded on every reload + QColor color_s;//Blocks + QColor color_p; + QColor color_d; + QColor color_f; + QColor color_1;//Groups + QColor color_2; + QColor color_3; + QColor color_4; + QColor color_5; + QColor color_6; + QColor color_7; + QColor color_8; + QColor color_ba;//Acidic + QColor color_ac; + QColor color_neu; + QColor color_amp; + QColor c_alkalie;//Family + QColor c_rare; + QColor c_nonmetal; + QColor c_alkaline; + QColor c_other_metal; + QColor c_halogene; + QColor c_transition; + QColor c_noble_gas; + QColor c_metalloid; + QColor c_liquid; + QColor c_solid; + QColor c_vapor; + + protected: + virtual void paintEvent( QPaintEvent *e ); + + /** + * draw the tooltip for the legend + */ + virtual void drawLegendToolTip( QPainter *p ); + + virtual void drawTimeLine( QPainter *p ); + + /** + * called if the user resized the table + */ + virtual void resizeEvent( QResizeEvent *e ); + + /** + * the central place for the drawing of the table + */ + virtual void drawPerodicTableView( QPainter* p, bool isCrystal ); + + /** + * draw a gradient of the type @p type + */ + virtual void drawGradientPerodicTableView( QPainter* p, const double min, const double max ); + + /** + * draw the state of matter + */ + virtual void drawSOMPerodicTableView( QPainter* p ); + + /** + * draw the legend + */ + virtual void drawLegend( QPainter* p ); + + /** + * draw the numeration + */ + virtual void drawNumeration( QPainter* p ); + + public slots: + /** + * This method sets the color for the buttons corresponding to + * the given temperature @p temp + * @param temp is the temperature to which all buttons will be set + */ + void setTemperature( int temp ){ + m_temperature = (double)temp; + update(); + } + + void setDate( int date ){ + //These elements have always been known: + //6 16 26 29 33 47 50 51 79 80 82 83 + m_date = date; + update(); + } + + /** + * this slot removes the selection of any point + */ + void unSelect(); + + private slots: + /** + * If called this slot will emit the signal MouseOver( num ) + * where num is the number of the element the mouse if over. + * If the mouse is not over an element nothing will be emited + * @see MouseOver() + */ + void slotMouseover(); + + /** + * start the calculation of the element over which the mouse-cursor + * is over. Finally the signal ToolTip( int ) is emitted + */ + void slotTransientLabel(); + + /** + * this slot updates the currently selected point + */ + void selectPoint( const QPoint& point ); + + /** + * this slot updates the element given in the @p num + * @param num The number of the selected element + */ + void selectElement( int num ); + + /** + * sets the current element to @p number + * and updates the table + */ + void slotToolTip( int number ); + + signals: + /** + * this signal is emitted when the table is clicked + */ + void tableClicked(QPoint); + + /** + * this signal is emitted when an element is clicked + */ + void ElementClicked(int); + + /** + * this signal is emitted when the tooltip of an element + * has to be displayed + */ + void ToolTip(int); + + /** + * This signal is emited when the mouse pointer is + * over an element + */ + void MouseOver( int ); +}; + + +#endif diff --git a/kalzium/src/plotsetupwidget.ui b/kalzium/src/plotsetupwidget.ui new file mode 100644 index 00000000..a395541d --- /dev/null +++ b/kalzium/src/plotsetupwidget.ui @@ -0,0 +1,256 @@ + +PlotSetupWidget + + + PlotSetupWidget + + + + 0 + 0 + 279 + 565 + + + + + unnamed + + + + textLabel3 + + + First element: + + + + + layout4 + + + + unnamed + + + + textLabel1_2 + + + Average value: + + + + + aValue + + + + + + + + + + to + + + 115 + + + 2 + + + 200 + + + Define the last element whose value should be plotted + + + + + layout2 + + + + unnamed + + + + textLabel3_2 + + + Minimum value: + + + + + minValue + + + + + + + + + + showNames + + + &Show element names + + + Define whether the names of the plotted element should be displayed + + + + + textLabel4 + + + Last element: + + + + + layout3 + + + + unnamed + + + + textLabel2 + + + Maximum value: + + + + + maxValue + + + + + + + + + + connectPoints + + + &Connect points + + + Define whether the plotted points should be connected or not + + + + + from + + + 1 + + + 1 + + + 200 + + + Define the first element whose value should be plotted + + + + + spacer1 + + + Vertical + + + Expanding + + + + 20 + 60 + + + + + + groupBox1 + + + Y-axis + + + + unnamed + + + + + Mass + + + + + Mean Mass + + + + + Density + + + + + Electronegativity + + + + + Melting Point + + + + + Boiling Point + + + + + Atomic Radius + + + + + Covalent Radius + + + + KCB_y + + + Here you can define what you want to plot + + + + + + + + + + + knuminput.h + kcombobox.h + + diff --git a/kalzium/src/plotwidget.cpp b/kalzium/src/plotwidget.cpp new file mode 100644 index 00000000..3a6f8530 --- /dev/null +++ b/kalzium/src/plotwidget.cpp @@ -0,0 +1,69 @@ +/*************************************************************************** + copyright : (C) 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "plotwidget.h" +#include "plotwidget.moc" + +//KDE-Includes +#include + +//QT-Includes +#include + +PlotWidget::PlotWidget( double x1, + double x2, + double y1, + double y2, + QWidget *parent, + const char* name) + : KPlotWidget( x1, x2, y1, y2, parent, name ) +{ + m_connectPoints = false; +} + +void PlotWidget::drawObjects( QPainter *p ) +{ + // let the KPlotWidget draw the default stuff first + KPlotWidget::drawObjects(p); + // then draw the connecting lines + if (!m_connectPoints) return; // bail out if connect points is not enabled + + QPoint old; // used to remember last coordinates + bool first = true; + for ( KPlotObject *po = ObjectList.first(); po; po = ObjectList.next() ) + { + // skip empty plot objects + if ( po->points()->count() == 0 ) continue; + // skip non-point plot objects + if (po->type() != KPlotObject::POINTS) continue; + + // draw the connecting lines + p->setPen( QColor( po->color() ) ); + p->setBrush( QColor( po->color() ) ); + for ( DPoint *dp = po->points()->first(); dp; dp = po->points()->next() ) + { + QPoint q = dp->qpoint( PixRect, DataRect ); + + if ( first ) + first = false; + else + p->drawLine(old.x(), old.y(), q.x(), q.y()); + + old.setX( q.x() ); + old.setY( q.y() ); + } + p->setBrush( Qt::NoBrush ); + } +} + diff --git a/kalzium/src/plotwidget.h b/kalzium/src/plotwidget.h new file mode 100644 index 00000000..5a0ccd61 --- /dev/null +++ b/kalzium/src/plotwidget.h @@ -0,0 +1,55 @@ +#ifndef PLOTWIDGET_H +#define PLOTWIDGET_H +/*************************************************************************** + copyright : (C) 2004, 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include + +/** + * @short This class add the abilitiy to connect the plotted + * data using a line. + * @author Carsten Niehaus + */ +class PlotWidget : public KPlotWidget +{ + Q_OBJECT + + public: + PlotWidget( double x1 = 0.0, double x2 = 0.0, double y1 = 0.0, double y2 = 0.0, QWidget *parent=0 , const char *name =0 ); + + /** + * toggles if the points will be connected with + * a line or not + * @param b if true the points will be connected + */ + void setConnection( bool b ){ + m_connectPoints = b; + } + + private: + /** + * if true, the points will be connected + */ + bool m_connectPoints; + + protected: + /** + * draws the objects + */ + virtual void drawObjects( QPainter *p); + +}; + +#endif // PLOTWIDGET_H + diff --git a/kalzium/src/prefs.kcfgc b/kalzium/src/prefs.kcfgc new file mode 100644 index 00000000..e6df4e2e --- /dev/null +++ b/kalzium/src/prefs.kcfgc @@ -0,0 +1,6 @@ +# Code generation options for kconfig_compiler +File=kalzium.kcfg +#IncludeFiles=defines.h +ClassName=Prefs +Singleton=true +Mutators=true diff --git a/kalzium/src/settings_colors.ui b/kalzium/src/settings_colors.ui new file mode 100644 index 00000000..f32360d0 --- /dev/null +++ b/kalzium/src/settings_colors.ui @@ -0,0 +1,936 @@ + +setColors + + + setColors + + + + 0 + 0 + 560 + 359 + + + + Set Colors + + + + unnamed + + + + dfgdfg + + + + tab + + + &Blocks + + + + unnamed + + + + layout32 + + + + unnamed + + + + layout28 + + + + unnamed + + + + textLabel13 + + + s-Block: + + + + + kcfg_block_s + + + + + + + + + + layout29 + + + + unnamed + + + + textLabel14 + + + p-Block: + + + + + kcfg_block_p + + + + + + + + + + layout30 + + + + unnamed + + + + textLabel15 + + + d-Block: + + + + + kcfg_block_d + + + + + + + + + + layout31 + + + + unnamed + + + + textLabel16 + + + f-Block: + + + + + kcfg_block_f + + + + + + + + + + + + + + tab + + + Ac&id Behavior + + + + unnamed + + + + layout26 + + + + unnamed + + + + layout23 + + + + unnamed + + + + textLabel9 + + + Acidic: + + + + + kcfg_beh_acidic + + + + + + + + + + layout24 + + + + unnamed + + + + textLabel10 + + + Amphoteric: + + + + + kcfg_beh_amphoteric + + + + + + + + + + layout25 + + + + unnamed + + + + textLabel11 + + + Neutral: + + + + + kcfg_beh_neutral + + + + + + + + + + layout26 + + + + unnamed + + + + textLabel12 + + + Basic: + + + + + kcfg_beh_basic + + + + + + + + + + + + + + TabPage + + + &Groups + + + + unnamed + + + + layout22 + + + + unnamed + + + + layout12 + + + + unnamed + + + + textLabel2_2_2 + + + Group 1: + + + + + kcfg_group_1 + + + + + + + + + + layout19 + + + + unnamed + + + + textLabel8 + + + Group 2: + + + + + kcfg_group_2 + + + + + + + + + + layout18 + + + + unnamed + + + + textLabel7 + + + Group 3: + + + + + kcfg_group_3 + + + + + + + + + + layout17 + + + + unnamed + + + + textLabel6 + + + Group 4: + + + + + kcfg_group_4 + + + + + + + + + + layout16 + + + + unnamed + + + + textLabel5_2 + + + Group 5: + + + + + kcfg_group_5 + + + + + + + + + + layout15 + + + + unnamed + + + + textLabel4_2 + + + Group 6: + + + + + kcfg_group_6 + + + + + + + + + + layout14 + + + + unnamed + + + + textLabel3_2 + + + Group 7: + + + + + kcfg_group_7 + + + + + + + + + + layout13 + + + + unnamed + + + + textLabel2_2 + + + Group 8: + + + + + kcfg_group_8 + + + + + + + + + + + + + + TabPage + + + &State of Matter + + + + unnamed + + + + layout14 + + + + unnamed + + + + layout13 + + + + unnamed + + + + textLabel1 + + + Solid: + + + kcfg_color_solid + + + + + kcfg_color_solid + + + + + + + + + + layout6 + + + + unnamed + + + + textLabel2 + + + Liquid: + + + + + kcfg_color_liquid + + + + + + + + + + layout7 + + + + unnamed + + + + textLabel3 + + + Vaporous: + + + + + kcfg_color_vapor + + + + + + + + + + + + + + TabPage + + + Family + + + + unnamed + + + + layout36 + + + + unnamed + + + + layout12_2 + + + + unnamed + + + + textLabel2_2_2_2 + + + Alkali metals: + + + + + kcfg_alkalie + + + + + + + + + + layout19_2 + + + + unnamed + + + + textLabel8_2 + + + Rare earth: + + + + + kcfg_rare + + + + + + + + + + layout18_2 + + + + unnamed + + + + textLabel7_2 + + + Non-metals: + + + + + kcfg_nonmetal + + + + + + + + + + layout17_2 + + + + unnamed + + + + textLabel6_2 + + + Alkaline earth metals: + + + + + kcfg_alkaline + + + + + + + + + + layout16_2 + + + + unnamed + + + + textLabel5_2_2 + + + Other metals: + + + + + kcfg_other_metal + + + + + + + + + + layout15_2 + + + + unnamed + + + + textLabel4_2_2 + + + Halogens: + + + + + kcfg_halogene + + + + + + + + + + layout14_2 + + + + unnamed + + + + textLabel3_2_2 + + + Transition metals: + + + + + kcfg_transition + + + + + + + + + + layout13_2 + + + + unnamed + + + + textLabel2_2_3 + + + Noble gases: + + + + + kcfg_noble_gas + + + + + + + + + + layout35 + + + + unnamed + + + + textLabel2_2_3_2 + + + Metalloids: + + + + + kcfg_metalloid + + + + + + + + + + + + + + TabPage + + + &No Color Scheme + + + + unnamed + + + + kcfg_noscheme + + + + + + This color will be used if no other scheme is selected + + + This color will be used if no other scheme is selected + + + + + + + + + + + + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + kcolorbutton.h + + diff --git a/kalzium/src/settings_misc.ui b/kalzium/src/settings_misc.ui new file mode 100644 index 00000000..a66693dd --- /dev/null +++ b/kalzium/src/settings_misc.ui @@ -0,0 +1,71 @@ + +setupMisc + + + setupMisc + + + + 0 + 0 + 422 + 220 + + + + + unnamed + + + + kcfg_pselook + + + PSE-Look + + + true + + + + unnamed + + + + radioButton10 + + + Display atomic &mass in the PSE + + + + + radioButton13 + + + Display &only the number of the element + + + + + + + spacer1 + + + Vertical + + + Expanding + + + + 20 + 30 + + + + + + + diff --git a/kalzium/src/settings_units.ui b/kalzium/src/settings_units.ui new file mode 100644 index 00000000..e054021a --- /dev/null +++ b/kalzium/src/settings_units.ui @@ -0,0 +1,167 @@ + +setupUnits + + + setupUnits + + + + 0 + 0 + 400 + 256 + + + + + unnamed + + + + kcfg_temperature + + + &Temperatures + + + Kalzium can show you the temperature in three different scales + + + + unnamed + + + + radioButton19 + + + &Use Kelvin + + + 0 + + + If selected, the temperatures will be displayed in Kelvin + + + If selected, the temperatures will be displayed in Kelvin. This is then saved in configuration and restored next time you start Kalzium. + + + + + radioButton11_2 + + + Use degrees &Fahrenheit + + + 2 + + + If selected, the temperatures will be displayed in Degrees Fahrenheit + + + If selected, the temperatures will be displayed in Degrees Fahrenheit. This is then saved in configuration and restored next time you start Kalzium. + + + + + radioButton21 + + + Use degrees R&ankine + + + 3 + + + If selected, the temperatures will be displayed in Degrees Rankine + + + If selected, the temperatures will be displayed in Degrees Rankine. This is then saved in configuration and restored next time you start Kalzium. + + + + + radioButton22 + + + Use degrees &Réaumur + + + 4 + + + If selected, the temperatures will be displayed in Degrees Réaumur. + + + If selected, the temperatures will be displayed in Degrees Réaumur. This is then saved in configuration and restored next time you start Kalzium. + + + + + radioButton20 + + + Use de&grees Celsius + + + 1 + + + If selected, the temperatures will be displayed in Degrees Celsius + + + If selected, the temperatures will be displayed in Degrees Celsius. This is then saved in configuration and restored next time you start Kalzium. + + + + + + + kcfg_energies + + + Units of &Energies + + + true + + + + unnamed + + + + radioButton3_2_2_2 + + + &Show energies in kJ/mol (kilojoule per mol) + + + Chose the energy unit as kJ/mol (kilojoule per mol) + + + Check this if you prefer the energy unit in kJ/mol (kilojoule per mol). The other choice you have is eV (electronvolt). + + + + + radioButton4_2_2_2 + + + Show energies &in eV (electronvolt) + + + Choose the energy unit as eV (electronvolt) + + + Check this if you prefer the energy unit in eV (electronvolt). The other choice you have is kJ/mol (kilojoule per mol). + + + + + + + + diff --git a/kalzium/src/solver/Makefile b/kalzium/src/solver/Makefile new file mode 100644 index 00000000..4b96fdb7 --- /dev/null +++ b/kalzium/src/solver/Makefile @@ -0,0 +1,92 @@ + +OCAMLC = ocamlc -g +OCAMLMLI = ocamlc +OCAMLOPT = ocamlopt +OCAMLDEP = ocamldep +INCLUDES = -I +facile +OPTOPT = +OCAMLLIB := `ocamlc -where` +FACILELIB = $(OCAMLLIB)/facile + + +# link to these libraries +LIBADD_CMX = $(OCAMLLIB)/facile/facile.cmxa #$(OCAMLLIB)/str.cmxa +LIBADD_CMO = $(OCAMLLIB)/facile/facile.cma #$(OCAMLLIB)/str.cma + +# our sources +SOURCES_CHEM = chemset.ml parser.ml lexer.ml datastruct.ml chem.ml calc.ml +SOURCES_WRAP = modwrap.c + +# the targets +CHEM_CMO = $(SOURCES_CHEM:.ml=.cmo) +CHEM_CMX = $(SOURCES_CHEM:.ml=.cmx) +CHEM_O = $(SOURCES_WRAP:.c=.o) + +# default target : the object files for eqchem +all : solver.o + +# shows how to build a program that embeds the solver +# in compiled ocaml, bytecode ocaml and compiled program using compiled caml code +test: atestprog.opt btestprog.out testcprog + +atestprog.opt: $(CHEM_CMX) main.cmx + $(OCAMLOPT) -o $@ $(LIBADD_CMX) $(CHEM_CMX) main.cmx + +btestprog.out: $(CHEM_CMO) main.cmo + $(OCAMLMLI) -o $@ $(LIBADD_CMO) $(CHEM_CMO) main.cmo + +solver.o: $(CHEM_CMX) $(CHEM_O) + $(OCAMLOPT) -output-obj -o solver.o $(LIBADD_CMX) $(CHEM_CMX) + cp -f solver.o modwrap.o ../ + +testcprog: $(CHEM_CMX) $(CHEM_O) + $(OCAMLOPT) -output-obj -o solver.o $(LIBADD_CMX) $(CHEM_CMX) modwrap.o + gcc -c -o main.o main.c -L $(OCAMLLIB) + gcc -o $@ main.o solver.o -L $(OCAMLLIB) \ + -L $(OCAMLLIB)/facile -lasmrun -lstr -lnums -lm -ldl modwrap.o + +.SUFFIXES: +.SUFFIXES: .ml .mli .mly .mll .cmi .cmo .cmx .p.cmx .c + +.ml.cmo : + $(OCAMLC) $(INCLUDES) $(INCLUDES) -c $< + +.mli.cmi : + $(OCAMLMLI) $(INCLUDES) -c $< + +.ml.cmx : + $(OCAMLOPT) $(OPTOPT) $(INCLUDES) -c $< + +.mly.ml : + ocamlyacc $< + +.mll.ml : + ocamllex $< + +%.o : %.c + $(OCAMLOPT) $(OPTOPT) $(INCLUDES) -c $< + +clean: + \rm -f *.cm[iox] *.o *~ .depend *testprog.* testcprog + +cleanall : clean + \rm -f *.cmxa *.a *.cma + +distclean : clean + +interfaces: + ocamlc -i datastruct.ml > datastruct.mli + ocamlc -I +facile -i chem.ml > chem.mli + ocamlc -I +facile -i calc.ml > calc.mli + +maintainer-clean : clean + +uninstall : clean + +install : + echo "done" + +.depend: parser.ml lexer.ml + $(OCAMLDEP) $(INCLUDES) *.mli *.ml > $@ + +include .depend diff --git a/kalzium/src/solver/README b/kalzium/src/solver/README new file mode 100644 index 00000000..c2501bf5 --- /dev/null +++ b/kalzium/src/solver/README @@ -0,0 +1,19 @@ +You will need a working objective caml installation and +the FaCiLe library properly configured and installed +to compile eqchem. + +In practice, one would only run make in this directory (src/solver) +"make" +"make clean", etc + +To assemble with a c++ or a kde program, the object files +solver.o and modwrap.o must be added and linked with : +-L/usr/lib/ocaml -L/usr/lib/ocaml/facile -lasmrun -lstr -lnums -lm -ldl solver.o modwrap.o + +The program built can then be run without the objective caml tools. + +Console examples can also be generated (try "make test") + + +Thomas Nagy + diff --git a/kalzium/src/solver/calc.ml b/kalzium/src/solver/calc.ml new file mode 100644 index 00000000..745f7c14 --- /dev/null +++ b/kalzium/src/solver/calc.ml @@ -0,0 +1,53 @@ +(*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************) + +open Printf;; +open Chemset;; +open Datastruct;; +open Chem;; +open Hashtbl;; + +let create_equation str = + let lexbuf = Lexing.from_string str in + let result = Parser.main Lexer.token lexbuf in + result +;; + +exception Not_found;; + +let solve_equation (str:string) = + let eq = new eqtable in + try + eq#build (create_equation str); + try +(* eq#print_all (); *) + solve eq; + eq#get_eq_sol (); + + with | _ -> begin + let str = (eq#get_eq_orig ())^" : No solution found" in + (*cleanup eq;*) + str + end + with | _ -> str^" : Parse Error"; +;; + +let _ = Callback.register "solve_equation" solve_equation;; + diff --git a/kalzium/src/solver/calc.mli b/kalzium/src/solver/calc.mli new file mode 100644 index 00000000..32bd5518 --- /dev/null +++ b/kalzium/src/solver/calc.mli @@ -0,0 +1,3 @@ +val create_equation : string -> Chemset.listitems +exception Not_found +val solve_equation : string -> string diff --git a/kalzium/src/solver/chem.ml b/kalzium/src/solver/chem.ml new file mode 100644 index 00000000..2e0dd96d --- /dev/null +++ b/kalzium/src/solver/chem.ml @@ -0,0 +1,60 @@ +(*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************) + +open Facile;; +open Easy;; +open Datastruct;; + +let solve (eq : eqtable) = + let nb_molecules = eq#getsize_j () and nb_elements = eq#getsize_i () in + let dist = Fd.array nb_molecules 1 900 in + + (* trivial constraints on domains *) + for j = 0 to nb_molecules -1 do + let num = try int_of_string (eq#getvar j) with _ -> -1 in + if num > -1 then dist.(j) <- Fd.int num + done; + + (* raises an exception if the problem is not solvable *) + for i = 0 to nb_elements - 1 do + Cstr.post (Arith.scalprod_fd (eq#getline i) dist =~ i2e 0) + done; + + let goal = Goals.GlArray.labeling dist in + if (Goals.solve goal) then Array.iteri (fun cnt i -> eq#setsol cnt (Fd.min i)) dist + else failwith "no solution found" +;; + +(* workaround for (probably) a bug in the facile library 1.0 (fixed in 1.1?) : + * when the constraints make a problem + * unsolvable, an exception is raised + * + * unfortunately the next problem + * solved afterwards is not handled properly *) + +let cleanup (eq : eqtable) = +(* Printf.printf "cleaning up"; *) + let nb_molecules = eq#getsize_j () and nb_elements = eq#getsize_i () in + let dist = Fd.array nb_molecules 0 2 in + let goal = Goals.GlArray.labeling dist in + if not (Goals.solve goal) then failwith "fatal error" +;; + + diff --git a/kalzium/src/solver/chem.mli b/kalzium/src/solver/chem.mli new file mode 100644 index 00000000..0e607b2b --- /dev/null +++ b/kalzium/src/solver/chem.mli @@ -0,0 +1,2 @@ +val solve : Datastruct.eqtable -> unit +val cleanup : Datastruct.eqtable -> unit diff --git a/kalzium/src/solver/chemset.ml b/kalzium/src/solver/chemset.ml new file mode 100644 index 00000000..d8136846 --- /dev/null +++ b/kalzium/src/solver/chemset.ml @@ -0,0 +1,82 @@ +(*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************) + +open Printf;; +open Hashtbl;; +open List;; +open String;; + +type chemtbl = (string, int) Hashtbl.t;; +type chemrecord = {mutable hashtbl:chemtbl; mutable formula:string};; +type item = {ikey:string; itbl:chemrecord; mutable sign:int};; +type listitems = (item) list;; + + +(* add a symbol to a molecule *) +let chem_addsym (tbl:chemtbl) (sym:string) (qte:int) = + let prev_qte = ref 0 in + if Hashtbl.mem tbl sym then prev_qte := Hashtbl.find tbl sym; + Hashtbl.replace tbl sym (!prev_qte+qte) +;; + +(* add merge two sub_molecules *) +let chem_add (tbl1:chemrecord) (tbl2:chemrecord) = + Hashtbl.iter (fun sym qte -> chem_addsym tbl1.hashtbl sym qte) tbl2.hashtbl; + tbl1.formula <- tbl1.formula^tbl2.formula; + tbl1 +;; + +(* multiply a sub-molecule (amount of atoms) by an integer value *) +let chem_mult (tbl:chemrecord) (qte:int) = + Hashtbl.iter (fun sym old_qte-> Hashtbl.replace tbl.hashtbl sym (old_qte*qte) ) tbl.hashtbl; + tbl.formula <- "("^tbl.formula^")"^string_of_int(qte); + tbl +;; + +(* creates a small molecule *) +let createchem (sym:string) (qte:int) = + + let prettyformula () = + if String.contains sym '+' || String.contains sym '-' then begin + if qte == 1 then ""^sym^"" + else ""^string_of_int(qte)^sym^"" end + else begin + if qte == 1 then sym + else sym^""^string_of_int(qte)^"" + end + in + + let table = Hashtbl.create 10 in + Hashtbl.add table sym qte; + { hashtbl=table ; formula=prettyformula() } + (*if (qte!=1) then { hashtbl=table ; formula=prettyformula() } + else { hashtbl=table ; formula=sym }*) +;; + +let chem_negate (l:listitems) = + List.iter (fun i -> i.sign <- -1) l +;; + +(* outputs a molecule *) +let chem_printitem (i:item) = + Printf.printf "item : %s %s %d \n" i.ikey (i.itbl).formula i.sign; + Hashtbl.iter (fun sym qte -> Printf.printf " * %s %d\n" sym qte) i.itbl.hashtbl +;; + diff --git a/kalzium/src/solver/chemset.mli b/kalzium/src/solver/chemset.mli new file mode 100644 index 00000000..64c64bcf --- /dev/null +++ b/kalzium/src/solver/chemset.mli @@ -0,0 +1,10 @@ +type chemtbl = (string, int) Hashtbl.t +and chemrecord = { mutable hashtbl : chemtbl; mutable formula : string; } +and item = { ikey : string; itbl : chemrecord; mutable sign : int; } +and listitems = item list +val chem_addsym : chemtbl -> string -> int -> unit +val chem_add : chemrecord -> chemrecord -> chemrecord +val chem_mult : chemrecord -> int -> chemrecord +val createchem : string -> int -> chemrecord +val chem_negate : listitems -> unit +val chem_printitem : item -> unit diff --git a/kalzium/src/solver/datastruct.ml b/kalzium/src/solver/datastruct.ml new file mode 100644 index 00000000..541ed8cd --- /dev/null +++ b/kalzium/src/solver/datastruct.ml @@ -0,0 +1,141 @@ +(*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************) + +open List;; +open Chemset;; +open Hashtbl;; +open Array;; + +class eqtable = +object (self) + +(* columns : vars + formula | lines : chemical elements *) +val mutable numtbl = Array.make_matrix 0 0 0 +val mutable strtbl = Array.make 0 "" +val mutable vartbl = Array.make 0 "" +val mutable soltbl = Array.make 0 0 +val mutable m_solved = false +val mutable m_middle = 0 + +(* val mutable (table:int array array) = [||] *) + +(* lines : i : chem element *) +(* columns : vars j *) +method getsize_i () = Array.length numtbl +method getsize_j () = if (self#getsize_i () > 0) then Array.length numtbl.(0) else 0 + +method getline j = numtbl.(j) + +method getformula k = strtbl.(k) +method getvar k = vartbl.(k) +method getsol k = soltbl.(k) + +method setsol k v = soltbl.(k) <- v +method isSolved () = m_solved + +method get_eq_sol () = + let str = ref "" in + for j=0 to (self#getsize_j () -1) do + if (j == m_middle) then str := (!str)^" -> " + else if (j>0 && j"^string_of_int(self#getsol j)^" "^(self#getformula j); + done; + !str + +method get_eq_orig () = + let str = ref "" in + for j=0 to (self#getsize_j () -1) do + if (j == m_middle) then str := (!str)^" -> " + else if (j>0 && j"^(self#getvar j)^" "^(self#getformula j); + done; + !str + +method private init i j = numtbl <- Array.make_matrix i j 0; + strtbl <- Array.make j ""; + vartbl <- Array.make j ""; + soltbl <- Array.make j 0 + +method clear () = + self#init 0 0; + +method print_all () = + Printf.printf "--- start print_all ---\n"; + for i = 0 to (self#getsize_i ())-1 do + for j = 0 to (self#getsize_j ())-1 do + Printf.printf "%d " (numtbl.(i).(j)); + done; + Printf.printf "\n"; + done; + Printf.printf "--- end print_all ---\n"; + flush_all () + +(* build the matrix to solve *) +method build (lst:listitems) = + let nb_symbols = ref 0 in + let item_array = Array.of_list lst in + let record:(string, int) Hashtbl.t = Hashtbl.create 10 in + let nb_items = ref (Array.length item_array) in + for i=0 to !nb_items-1 do + Hashtbl.iter (fun sym _ -> + (* take all chemical elements but simplify ions (+ or -) into + *) + let symprocessed = if String.contains sym '+' || String.contains sym '-' + then "+" else sym in + + if not (Hashtbl.mem record symprocessed) then begin + Hashtbl.add record symprocessed !nb_symbols; + nb_symbols := !nb_symbols+1 + end + ) item_array.(i).itbl.hashtbl + done; + + (* initialize the matrix *) + self#init (!nb_symbols) (!nb_items); + + (* process each atom*) + for i=0 to !nb_items-1 do + (* find the middle (->) - nothing to do with the others things in this loop *) + if (item_array.(i).sign<0 && i>0) then (if (item_array.(i-1).sign>0) then m_middle<-i); + + (* store the molecule formula *) + vartbl.(i) <- item_array.(i).ikey; + strtbl.(i) <- item_array.(i).itbl.formula; + + (* for each molecule, process the atoms *) + Hashtbl.iter (fun sym qte -> + + if String.contains sym '+' || String.contains sym '-' then begin + (* it is an electric charge *) + let chargesign = if String.contains sym '-' then -1 else 1 in + let line_idx = (Hashtbl.find record "+") in + numtbl.(line_idx).(i) <- qte * item_array.(i).sign * chargesign + end + else begin + (* check if the atom is already there *) + let line_idx = (Hashtbl.find record sym) in + numtbl.(line_idx).(i) <- (qte * item_array.(i).sign) + end + ) item_array.(i).itbl.hashtbl + done + +end;; + diff --git a/kalzium/src/solver/datastruct.mli b/kalzium/src/solver/datastruct.mli new file mode 100644 index 00000000..f2daeb3b --- /dev/null +++ b/kalzium/src/solver/datastruct.mli @@ -0,0 +1,23 @@ +class eqtable : + object + val mutable m_middle : int + val mutable m_solved : bool + val mutable numtbl : int array array + val mutable soltbl : int array + val mutable strtbl : string array + val mutable vartbl : string array + method build : Chemset.listitems -> unit + method clear : unit -> unit + method get_eq_orig : unit -> string + method get_eq_sol : unit -> string + method getformula : int -> string + method getline : int -> int array + method getsize_i : unit -> int + method getsize_j : unit -> int + method getsol : int -> int + method getvar : int -> string + method private init : int -> int -> unit + method isSolved : unit -> bool + method print_all : unit -> unit + method setsol : int -> int -> unit + end diff --git a/kalzium/src/solver/lexer.ml b/kalzium/src/solver/lexer.ml new file mode 100644 index 00000000..e82d6804 --- /dev/null +++ b/kalzium/src/solver/lexer.ml @@ -0,0 +1,189 @@ +# 22 "lexer.mll" + + open Parser;; + exception IllegalChar + +# 7 "lexer.ml" +let __ocaml_lex_tables = { + Lexing.lex_base = + "\000\000\244\255\255\255\075\000\253\255\036\000\251\255\249\255\ + \248\255\247\255\246\255\000\000\243\255\245\255"; + Lexing.lex_backtrk = + "\255\255\255\255\255\255\001\000\255\255\003\000\255\255\255\255\ + \255\255\255\255\255\255\005\000\255\255\255\255"; + Lexing.lex_default = + "\001\000\000\000\000\000\255\255\000\000\255\255\000\000\000\000\ + \000\000\000\000\000\000\255\255\000\000\000\000"; + Lexing.lex_trans = + "\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\002\000\002\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \002\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \007\000\008\000\000\000\006\000\000\000\011\000\000\000\000\000\ + \003\000\003\000\003\000\003\000\003\000\003\000\003\000\003\000\ + \003\000\003\000\000\000\000\000\000\000\000\000\013\000\000\000\ + \000\000\004\000\004\000\004\000\004\000\004\000\004\000\004\000\ + \004\000\004\000\004\000\004\000\004\000\004\000\004\000\004\000\ + \004\000\004\000\004\000\004\000\004\000\004\000\004\000\004\000\ + \004\000\004\000\004\000\009\000\000\000\010\000\000\000\000\000\ + \000\000\005\000\005\000\005\000\005\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\003\000\003\000\003\000\003\000\003\000\ + \003\000\003\000\003\000\003\000\003\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \012\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000"; + Lexing.lex_check = + "\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\000\000\000\000\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \000\000\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \000\000\000\000\255\255\000\000\255\255\000\000\255\255\255\255\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\255\255\255\255\255\255\255\255\011\000\255\255\ + \255\255\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\255\255\000\000\255\255\255\255\ + \255\255\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ + \000\000\000\000\000\000\003\000\003\000\003\000\003\000\003\000\ + \003\000\003\000\003\000\003\000\003\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\005\000\ + \005\000\005\000\005\000\005\000\005\000\005\000\005\000\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \000\000\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ + \255\255\255\255\255\255\255\255"; + Lexing.lex_base_code = + ""; + Lexing.lex_backtrk_code = + ""; + Lexing.lex_default_code = + ""; + Lexing.lex_trans_code = + ""; + Lexing.lex_check_code = + ""; + Lexing.lex_code = + ""; +} + +let rec token lexbuf = + __ocaml_lex_token_rec lexbuf 0 +and __ocaml_lex_token_rec lexbuf __ocaml_lex_state = + match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with + | 0 -> +# 28 "lexer.mll" + (token lexbuf) +# 125 "lexer.ml" + + | 1 -> +# 29 "lexer.mll" + ( INT(int_of_string(Lexing.lexeme lexbuf)) ) +# 130 "lexer.ml" + + | 2 -> +# 30 "lexer.mll" + ( CAPITAL(Lexing.lexeme lexbuf) ) +# 135 "lexer.ml" + + | 3 -> +# 31 "lexer.mll" + ( MINOR(Lexing.lexeme lexbuf) ) +# 140 "lexer.ml" + + | 4 -> +# 32 "lexer.mll" + ( PLUS ) +# 145 "lexer.ml" + + | 5 -> +# 33 "lexer.mll" + ( MINUS ) +# 150 "lexer.ml" + + | 6 -> +# 34 "lexer.mll" + ( LPAREN ) +# 155 "lexer.ml" + + | 7 -> +# 35 "lexer.mll" + ( RPAREN ) +# 160 "lexer.ml" + + | 8 -> +# 36 "lexer.mll" + ( LBRACKET ) +# 165 "lexer.ml" + + | 9 -> +# 37 "lexer.mll" + ( RBRACKET ) +# 170 "lexer.ml" + + | 10 -> +# 38 "lexer.mll" + ( ARROW ) +# 175 "lexer.ml" + + | 11 -> +# 39 "lexer.mll" + ( raise IllegalChar; ) +# 180 "lexer.ml" + + | 12 -> +# 40 "lexer.mll" + ( EOF ) +# 185 "lexer.ml" + + | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf; __ocaml_lex_token_rec lexbuf __ocaml_lex_state + +;; + diff --git a/kalzium/src/solver/lexer.mll b/kalzium/src/solver/lexer.mll new file mode 100644 index 00000000..a6a4ab49 --- /dev/null +++ b/kalzium/src/solver/lexer.mll @@ -0,0 +1,41 @@ +(*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************) + +(* File lexer.mll*) +{ + open Parser;; + exception IllegalChar +} + +rule token = parse +[' ' '\t' '\n'] {token lexbuf} (* ignore whitespaces *) +| ['0'-'9']+ { INT(int_of_string(Lexing.lexeme lexbuf)) } +| ['A'-'Z'] { CAPITAL(Lexing.lexeme lexbuf) } +| ['a'-'z']+ { MINOR(Lexing.lexeme lexbuf) } +| '+' { PLUS } +| '-' { MINUS } +| '(' { LPAREN } +| ')' { RPAREN } +| '[' { LBRACKET } +| ']' { RBRACKET } +| "->" { ARROW } +| _ { raise IllegalChar; } +| eof { EOF } + diff --git a/kalzium/src/solver/main.c b/kalzium/src/solver/main.c new file mode 100644 index 00000000..d8e5e1bc --- /dev/null +++ b/kalzium/src/solver/main.c @@ -0,0 +1,46 @@ +/*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include +#include + +int main(int argc, char ** argv) +{ + caml_startup(argv); + + char * eq = " a CH3(CH2)3COOH + b O2 -> c H2O + d CO2"; + char * eq2= " a CH3(CH2)3COOH + b O2 -> c H2O + d CO"; + char * result = solve_equation(eq); + char * result2 = solve_equation(eq2); + + printf("solution : %s\n", result); + + printf("solution : %s\n", result2); + free(result2); + + result2 = solve_equation(eq); + printf("solution : %s\n", result2); + + free(result); + free(result2); + + return 0; +} + diff --git a/kalzium/src/solver/main.ml b/kalzium/src/solver/main.ml new file mode 100644 index 00000000..f940f1de --- /dev/null +++ b/kalzium/src/solver/main.ml @@ -0,0 +1,46 @@ +(*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************) + +open Printf;; +open Calc;; + + +let myeq1 = " a CH3(CH2)3COOH + b O2 -> c H2O + d CO2";; +let myeq2 = " a CH3COOH + b O2 -> c H2O + d CO2";; +let myeq3 = " a CH3(CH2)3COOH + b O2 -> invalid equation ";; +let myeq4 = "2CH4+aC2H6+cO2->eH2O+5CO2";; +let myeq5 = "a NaNO2 + b NH3 -> b NaN3 + e NaNO3";; +let myeq6 = "a HNO2 + b NH3 -> b HN3 + e HNO3";; +let myeq7 = "a H3O[+] + dCO2 + eO2 -> fH2O + dCO3[2+]";; + +(* Printf.printf "%s \n" (solve_equation myeq1);; +Printf.printf "%s \n" (solve_equation myeq2);; +Printf.printf "%s \n" (solve_equation myeq3);; *) +(* +Printf.printf "%s \n" (solve_equation myeq5);; +Printf.printf "%s \n" (solve_equation myeq6);; +Printf.printf "%s \n" (solve_equation myeq6);; + +Printf.printf "%s \n" (solve_equation myeq6);;*) +Printf.printf "%s \n" (solve_equation myeq7);; + + + + diff --git a/kalzium/src/solver/modwrap.c b/kalzium/src/solver/modwrap.c new file mode 100644 index 00000000..0ab5359e --- /dev/null +++ b/kalzium/src/solver/modwrap.c @@ -0,0 +1,37 @@ +/*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include +#include + +#include +#include + +char* solve_equation(const char * eq) +{ + static value * solve_equation_closure = NULL; + if (solve_equation_closure == NULL) + { + solve_equation_closure = caml_named_value("solve_equation"); + } + + return strdup(String_val(callback(*solve_equation_closure, copy_string(eq)) )); +} + diff --git a/kalzium/src/solver/parser.ml b/kalzium/src/solver/parser.ml new file mode 100644 index 00000000..8d7cc3c6 --- /dev/null +++ b/kalzium/src/solver/parser.ml @@ -0,0 +1,317 @@ +type token = + | INT of (int) + | PLUS + | MINUS + | LPAREN + | RPAREN + | LBRACKET + | RBRACKET + | EOF + | CAPITAL of (string) + | MINOR of (string) + | ARROW + +open Parsing;; +# 26 "parser.mly" + open Chemset + + (*let parse_error somestring = Printf.printf "%s \n" somestring;; + *) +# 21 "parser.ml" +let yytransl_const = [| + 258 (* PLUS *); + 259 (* MINUS *); + 260 (* LPAREN *); + 261 (* RPAREN *); + 262 (* LBRACKET *); + 263 (* RBRACKET *); + 0 (* EOF *); + 266 (* ARROW *); + 0|] + +let yytransl_block = [| + 257 (* INT *); + 264 (* CAPITAL *); + 265 (* MINOR *); + 0|] + +let yylhs = "\255\255\ +\001\000\002\000\003\000\003\000\004\000\004\000\005\000\005\000\ +\006\000\006\000\006\000\006\000\006\000\006\000\006\000\007\000\ +\007\000\000\000" + +let yylen = "\002\000\ +\002\000\003\000\001\000\003\000\002\000\002\000\001\000\002\000\ +\002\000\001\000\004\000\004\000\004\000\003\000\003\000\002\000\ +\001\000\002\000" + +let yydefred = "\000\000\ +\000\000\000\000\000\000\000\000\018\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\006\000\000\000\000\000\005\000\001\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\016\000\008\000\ +\009\000\002\000\004\000\000\000\000\000\000\000\014\000\015\000\ +\011\000\012\000\013\000" + +let yydgoto = "\002\000\ +\005\000\006\000\007\000\008\000\012\000\013\000\014\000" + +let yysindex = "\255\255\ +\003\255\000\000\010\255\010\255\000\000\003\000\252\254\011\255\ +\010\255\018\255\008\255\000\000\010\255\021\255\000\000\000\000\ +\003\255\003\255\020\255\007\255\019\255\022\255\000\000\000\000\ +\000\000\000\000\000\000\026\255\023\255\024\255\000\000\000\000\ +\000\000\000\000\000\000" + +let yyrindex = "\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\005\000\ +\000\000\000\000\001\000\000\000\015\000\008\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000" + +let yygindex = "\000\000\ +\000\000\000\000\006\000\000\000\254\255\000\000\000\000" + +let yytablesize = 281 +let yytable = "\001\000\ +\017\000\015\000\016\000\003\000\003\000\017\000\019\000\010\000\ +\029\000\030\000\024\000\004\000\018\000\009\000\007\000\010\000\ +\023\000\011\000\020\000\021\000\022\000\025\000\026\000\027\000\ +\028\000\031\000\033\000\000\000\032\000\034\000\035\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\ +\000\000\017\000\017\000\000\000\017\000\017\000\017\000\000\000\ +\017\000\010\000\017\000\010\000\010\000\010\000\003\000\010\000\ +\007\000\010\000\000\000\007\000\000\000\000\000\000\000\000\000\ +\007\000" + +let yycheck = "\001\000\ +\000\000\004\000\000\000\001\001\000\000\010\001\009\000\000\000\ +\002\001\003\001\013\000\009\001\002\001\004\001\000\000\006\001\ +\009\001\008\001\001\001\002\001\003\001\001\001\017\000\018\000\ +\005\001\007\001\001\001\255\255\007\001\007\001\007\001\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\255\ +\255\255\001\001\002\001\255\255\004\001\005\001\006\001\255\255\ +\008\001\002\001\010\001\004\001\005\001\006\001\010\001\008\001\ +\002\001\010\001\255\255\005\001\255\255\255\255\255\255\255\255\ +\010\001" + +let yynames_const = "\ + PLUS\000\ + MINUS\000\ + LPAREN\000\ + RPAREN\000\ + LBRACKET\000\ + RBRACKET\000\ + EOF\000\ + ARROW\000\ + " + +let yynames_block = "\ + INT\000\ + CAPITAL\000\ + MINOR\000\ + " + +let yyact = [| + (fun _ -> failwith "parser") +; (fun parser_env -> + let _1 = (peek_val parser_env 1 : 'equation) in + Obj.repr( +# 44 "parser.mly" + ( _1 ) +# 177 "parser.ml" + : Chemset.listitems)) +; (fun parser_env -> + let _1 = (peek_val parser_env 2 : 'expr) in + let _3 = (peek_val parser_env 0 : 'expr) in + Obj.repr( +# 49 "parser.mly" + ( chem_negate _3; List.append _1 _3 ) +# 185 "parser.ml" + : 'equation)) +; (fun parser_env -> + let _1 = (peek_val parser_env 0 : 'item) in + Obj.repr( +# 53 "parser.mly" + ( _1::[] ) +# 192 "parser.ml" + : 'expr)) +; (fun parser_env -> + let _1 = (peek_val parser_env 2 : 'item) in + let _3 = (peek_val parser_env 0 : 'expr) in + Obj.repr( +# 54 "parser.mly" + ( _1::_3 ) +# 200 "parser.ml" + : 'expr)) +; (fun parser_env -> + let _1 = (peek_val parser_env 1 : string) in + let _2 = (peek_val parser_env 0 : 'symbols) in + Obj.repr( +# 58 "parser.mly" + ( {ikey=_1; itbl=_2; sign=1} ) +# 208 "parser.ml" + : 'item)) +; (fun parser_env -> + let _1 = (peek_val parser_env 1 : int) in + let _2 = (peek_val parser_env 0 : 'symbols) in + Obj.repr( +# 59 "parser.mly" + ( {ikey=string_of_int(_1); itbl=_2; sign=1} ) +# 216 "parser.ml" + : 'item)) +; (fun parser_env -> + let _1 = (peek_val parser_env 0 : 'qte) in + Obj.repr( +# 63 "parser.mly" + ( _1 ) +# 223 "parser.ml" + : 'symbols)) +; (fun parser_env -> + let _1 = (peek_val parser_env 1 : 'qte) in + let _2 = (peek_val parser_env 0 : 'symbols) in + Obj.repr( +# 64 "parser.mly" + ( chem_add _1 _2 ) +# 231 "parser.ml" + : 'symbols)) +; (fun parser_env -> + let _1 = (peek_val parser_env 1 : 'element) in + let _2 = (peek_val parser_env 0 : int) in + Obj.repr( +# 68 "parser.mly" + ( createchem _1 _2 ) +# 239 "parser.ml" + : 'qte)) +; (fun parser_env -> + let _1 = (peek_val parser_env 0 : 'element) in + Obj.repr( +# 69 "parser.mly" + ( createchem _1 1 ) +# 246 "parser.ml" + : 'qte)) +; (fun parser_env -> + let _2 = (peek_val parser_env 2 : 'symbols) in + let _4 = (peek_val parser_env 0 : int) in + Obj.repr( +# 70 "parser.mly" + ( chem_mult _2 _4 ) +# 254 "parser.ml" + : 'qte)) +; (fun parser_env -> + let _2 = (peek_val parser_env 2 : int) in + Obj.repr( +# 71 "parser.mly" + ( createchem "+" _2 ) +# 261 "parser.ml" + : 'qte)) +; (fun parser_env -> + let _2 = (peek_val parser_env 2 : int) in + Obj.repr( +# 72 "parser.mly" + ( createchem "-" _2 ) +# 268 "parser.ml" + : 'qte)) +; (fun parser_env -> + Obj.repr( +# 73 "parser.mly" + ( createchem "+" 1 ) +# 274 "parser.ml" + : 'qte)) +; (fun parser_env -> + Obj.repr( +# 74 "parser.mly" + ( createchem "-" 1 ) +# 280 "parser.ml" + : 'qte)) +; (fun parser_env -> + let _1 = (peek_val parser_env 1 : string) in + let _2 = (peek_val parser_env 0 : string) in + Obj.repr( +# 78 "parser.mly" + ( _1 ^ _2 ) +# 288 "parser.ml" + : 'element)) +; (fun parser_env -> + let _1 = (peek_val parser_env 0 : string) in + Obj.repr( +# 79 "parser.mly" + ( _1 ) +# 295 "parser.ml" + : 'element)) +(* Entry main *) +; (fun parser_env -> raise (YYexit (peek_val parser_env 0))) +|] +let yytables = + { actions=yyact; + transl_const=yytransl_const; + transl_block=yytransl_block; + lhs=yylhs; + len=yylen; + defred=yydefred; + dgoto=yydgoto; + sindex=yysindex; + rindex=yyrindex; + gindex=yygindex; + tablesize=yytablesize; + table=yytable; + check=yycheck; + error_function=parse_error; + names_const=yynames_const; + names_block=yynames_block } +let main (lexfun : Lexing.lexbuf -> token) (lexbuf : Lexing.lexbuf) = + (yyparse yytables 1 lexfun lexbuf : Chemset.listitems) diff --git a/kalzium/src/solver/parser.mli b/kalzium/src/solver/parser.mli new file mode 100644 index 00000000..63d8dece --- /dev/null +++ b/kalzium/src/solver/parser.mli @@ -0,0 +1,15 @@ +type token = + | INT of (int) + | PLUS + | MINUS + | LPAREN + | RPAREN + | LBRACKET + | RBRACKET + | EOF + | CAPITAL of (string) + | MINOR of (string) + | ARROW + +val main : + (Lexing.lexbuf -> token) -> Lexing.lexbuf -> Chemset.listitems diff --git a/kalzium/src/solver/parser.mly b/kalzium/src/solver/parser.mly new file mode 100644 index 00000000..5aa83cc1 --- /dev/null +++ b/kalzium/src/solver/parser.mly @@ -0,0 +1,83 @@ +/*************************************************************************** + * Copyright (C) 2004 by Thomas Nagy * + * tnagy2^8@yahoo.fr * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +/* File parser.mly */ + + + +%{ + open Chemset + + (*let parse_error somestring = Printf.printf "%s \n" somestring;; + *) +%} + +%token INT +%token PLUS MINUS +%token LPAREN RPAREN LBRACKET RBRACKET +%token EOF +%token CAPITAL +%token MINOR +%token ARROW +%start main +%type main +%% + +main: + equation EOF { $1 } +; + + +equation: + expr ARROW expr { chem_negate $3; List.append $1 $3 } +; + +expr: + item { $1::[] } + | item PLUS expr { $1::$3 } +; + +item: + MINOR symbols { {ikey=$1; itbl=$2; sign=1} } + | INT symbols { {ikey=string_of_int($1); itbl=$2; sign=1} } +; + +symbols: + qte { $1 } + | qte symbols { chem_add $1 $2 } +; + +qte: + element INT { createchem $1 $2 } + | element { createchem $1 1 } + | LPAREN symbols RPAREN INT { chem_mult $2 $4 } + | LBRACKET INT PLUS RBRACKET { createchem "+" $2 } + | LBRACKET INT MINUS RBRACKET { createchem "-" $2 } + | LBRACKET PLUS RBRACKET { createchem "+" 1 } + | LBRACKET MINUS RBRACKET { createchem "-" 1 } +; + +element: + CAPITAL MINOR { $1 ^ $2 } + | CAPITAL { $1 } +; + + + diff --git a/kalzium/src/somwidget.ui b/kalzium/src/somwidget.ui new file mode 100644 index 00000000..83e19209 --- /dev/null +++ b/kalzium/src/somwidget.ui @@ -0,0 +1,185 @@ + +SOMWidget + + + SOMWidget + + + + 0 + 0 + 200 + 400 + + + + + unnamed + + + + spacer3 + + + Vertical + + + Fixed + + + + 21 + 10 + + + + + + text + + + + 1 + + + + Move the slider +to find out about +the state of matter + + + + + spacer3 + + + Vertical + + + Fixed + + + + 21 + 10 + + + + + + layout3 + + + + unnamed + + + + lbl1 + + + Temperature: + + + + + spacer1 + + + Horizontal + + + Expanding + + + + 20 + 21 + + + + + + + + layout4 + + + + unnamed + + + + temp_slider + + + 0 + + + 5000 + + + 295 + + + Horizontal + + + Below + + + 500 + + + + + spacer4 + + + Horizontal + + + Fixed + + + + 5 + 20 + + + + + + Number1 + + + 5000 + + + 0 + + + 295 + + + + + lblUnit + + + + + + + + + + + + + + + + knuminput.h + + diff --git a/kalzium/src/somwidget_impl.cpp b/kalzium/src/somwidget_impl.cpp new file mode 100644 index 00000000..ae1c19d8 --- /dev/null +++ b/kalzium/src/somwidget_impl.cpp @@ -0,0 +1,172 @@ +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "somwidget_impl.h" + +#include +#include +#include +#include +#include + +#include +#include +#include + +#include + +#include "element.h" +#include "kalziumdataobject.h" +#include "prefs.h" +#include "tempunit.h" + +SOMWidgetIMPL::SOMWidgetIMPL( QWidget *parent, const char* name ) + : SOMWidget( parent,name ) +{ + m_list = KalziumDataObject::instance()->ElementList; + + text->setAlignment( text->alignment() | Qt::WordBreak ); + text->setTextFormat( Qt::RichText ); + text->setReadOnly( true ); + text->setPaletteBackgroundColor( paletteBackgroundColor() ); + text->setFrameStyle( QFrame::NoFrame ); + + m_htmlBegin = ""; + m_htmlEnd = ""; + m_prevUnit = Prefs::temperature(); + + connect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( spinValueChanged( double ) ) ); + connect( temp_slider, SIGNAL( valueChanged( int ) ), + this, SLOT( sliderValueChanged( int ) ) ); + connect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( setNewTemp( double ) ) ); + + reloadUnits(); +} + +void SOMWidgetIMPL::reloadUnits() +{ + lblUnit->setText( TempUnit::unitListSymbol( Prefs::temperature() ) ); + QPair range = TempUnit::rangeForUnit( Prefs::temperature() ); + + double newvalue = TempUnit::convert( Number1->value(), m_prevUnit, Prefs::temperature() ); + Number1->setRange( range.first, range.second, 0.1, 1 ); + Number1->setValue( newvalue ); + setNewTemp( newvalue ); +kdDebug() << "min: " << Number1->minValue() << " - max: " << Number1->maxValue() << endl; + m_prevUnit = Prefs::temperature(); +} + +void SOMWidgetIMPL::sliderValueChanged( int temp ) +{ +// TODO check if in Qt4 the RangeControl emits the signal again + disconnect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( spinValueChanged( double ) ) ); + disconnect( temp_slider, SIGNAL( valueChanged( int ) ), + this, SLOT( sliderValueChanged( int ) ) ); + disconnect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( setNewTemp( double ) ) ); + double newvalue = TempUnit::convert( (double)temp, (int)TempUnit::Kelvin, Prefs::temperature() ); + Number1->setValue( newvalue ); + setNewTemp( newvalue ); + connect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( spinValueChanged( double ) ) ); + connect( temp_slider, SIGNAL( valueChanged( int ) ), + this, SLOT( sliderValueChanged( int ) ) ); + connect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( setNewTemp( double ) ) ); +} + +void SOMWidgetIMPL::spinValueChanged( double temp ) +{ + disconnect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( spinValueChanged( double ) ) ); + disconnect( temp_slider, SIGNAL( valueChanged( int ) ), + this, SLOT( sliderValueChanged( int ) ) ); + disconnect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( setNewTemp( double ) ) ); + int newvalue = (int)TempUnit::convert( temp, Prefs::temperature(), (int)TempUnit::Kelvin ); + temp_slider->setValue( newvalue ); + setNewTemp( temp ); + connect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( spinValueChanged( double ) ) ); + connect( temp_slider, SIGNAL( valueChanged( int ) ), + this, SLOT( sliderValueChanged( int ) ) ); + connect( Number1, SIGNAL( valueChanged( double ) ), + this, SLOT( setNewTemp( double ) ) ); +} + +void SOMWidgetIMPL::setNewTemp( double newtemp ) +{ + static const int threshold = 25; + + double temp = TempUnit::convert( newtemp, Prefs::temperature(), (int)TempUnit::Kelvin ); + + QValueList::ConstIterator it = m_list.begin(); + const QValueList::ConstIterator itEnd = m_list.end(); + + QStringList listMeltingPoint; + QStringList listBoilingPoint; + QStringList listBoilingPointValue; + QStringList listMeltingPointValue; + for ( ; it != itEnd; ++it ) + { + if ( ( ( *it )->melting() > 0.0 ) && fabs( ( *it )->melting() - temp ) <= threshold ) + { + listMeltingPoint << ( *it )->elname(); + listMeltingPointValue << ( *it )->adjustUnits( Element::MELTINGPOINT ); + } + if ( ( ( *it )->boiling() > 0.0 ) && fabs( ( *it )->boiling() - temp ) <= threshold ) + { + listBoilingPoint << ( *it )->elname(); + listBoilingPointValue << ( *it )->adjustUnits( Element::BOILINGPOINT ); + } + } + QString htmlcode; + if ( listMeltingPoint.count() > 0 ) + { + htmlcode += i18n( "Elements with melting point around this temperature:" ) + "
"; + for ( uint i = 0; i < listMeltingPoint.count(); i++ ) + { + htmlcode += " · " + i18n( "For example: Carbon (300K)", "%1 (%2)" ).arg( listMeltingPoint[i] ).arg( listMeltingPointValue[i] ) + "
"; + } + htmlcode += "
"; + } + else + { + htmlcode += i18n( "No elements with a melting point around this temperature" ); + htmlcode += "

"; + } + if ( listBoilingPoint.count() > 0 ) + { + htmlcode += i18n( "Elements with boiling point around this temperature:" ) + "
"; + for ( uint i = 0; i < listBoilingPoint.count(); i++ ) + { + htmlcode += " · " + i18n( "For example: Carbon (300K)", "%1 (%2)" ).arg( listBoilingPoint[i] ).arg( listBoilingPointValue[i] ) + "
"; + } + htmlcode += "
"; + } + else + { + htmlcode += i18n( "No elements with a boiling point around this temperature" ); + htmlcode += "
"; + } + +// kdDebug() << m_htmlBegin + htmlcode + m_htmlEnd << endl; + + text->setText( m_htmlBegin + htmlcode + m_htmlEnd ); + +} + +#include "somwidget_impl.moc" diff --git a/kalzium/src/somwidget_impl.h b/kalzium/src/somwidget_impl.h new file mode 100644 index 00000000..0c61c355 --- /dev/null +++ b/kalzium/src/somwidget_impl.h @@ -0,0 +1,63 @@ +#ifndef SOMWIDGET_IMPL_H +#define SOMWIDGET_IMPL_H +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "somwidget.h" + +class Element; + +/** + * @class SOMWidgetIMPL + * @author Carsten Niehaus + * @author Pino Toscano + * + * The SOMWidgetIMPL provides a QSlider. When this slider is moved, + * this widget will display which elements have a boiling or melting + * point near the temperature the user entered using the slider. + */ +class SOMWidgetIMPL : public SOMWidget +{ + Q_OBJECT + + public: + /** + * @param parent The parent of this widget + * @param name The name of this widget + */ + SOMWidgetIMPL( QWidget *parent = 0, const char* name = 0 ); + + public slots: + /** + * Reload the current unit from the preferences + */ + void reloadUnits(); + + private: + QValueList m_list; + QString m_htmlBegin; + QString m_htmlEnd; + int m_prevUnit; + + private slots: + void sliderValueChanged( int temp ); + void spinValueChanged( double temp ); + + /** + * in this slot the elements will be compared with + * the temperature @p newtemp. The content of the HTML + * will be generated + */ + void setNewTemp( double newtemp ); +}; +#endif // SOMWIDGET_IMPL_H diff --git a/kalzium/src/spectrum.cpp b/kalzium/src/spectrum.cpp new file mode 100644 index 00000000..4b74eadb --- /dev/null +++ b/kalzium/src/spectrum.cpp @@ -0,0 +1,151 @@ +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ +#include "spectrum.h" + +#include "element.h" + +#include + +#include + +double Spectrum::minBand() +{ + double value = ( *m_bandlist.begin() ).wavelength; + QValueList::const_iterator it = m_bandlist.begin(); + const QValueList::const_iterator itEnd = m_bandlist.end(); + for (;it!=itEnd;++it) + { + if ( value > ( *it ).wavelength ) + value = ( *it ).wavelength; + } + return value; +} + +double Spectrum::maxBand() +{ + double value = ( *m_bandlist.begin() ).wavelength; + QValueList::const_iterator it = m_bandlist.begin(); + const QValueList::const_iterator itEnd = m_bandlist.end(); + for (;it!=itEnd;++it) + { + if ( value < ( *it ).wavelength ) + value = ( *it ).wavelength; + } + return value; +} + + +Spectrum* Spectrum::adjustToWavelength( double min, double max ) +{ + Spectrum *spec = new Spectrum(); + + QValueList::const_iterator it = m_bandlist.begin(); + const QValueList::const_iterator itEnd = m_bandlist.end(); + + for ( ; it != itEnd; ++it ) + { + if ( ( *it ).wavelength < min || ( *it ).wavelength > max ) + continue; + + spec->addBand( *it ); + } + + spec->adjustMinMax(); + + return spec; +} + +void Spectrum::adjustIntensities() +{ + int maxInt = 0; + QValueList::Iterator it = m_bandlist.begin(); + const QValueList::Iterator itEnd = m_bandlist.end(); + + //find the highest intensity + for ( ; it != itEnd; ++it ) + { + if ( ( *it ).intensity > maxInt ) + maxInt = ( *it ).intensity; + } + + //check if an adjustment is needed or not + if ( maxInt == 1000 ) return; + + double max = ( double ) maxInt; + + //now adjust the intensities. + it = m_bandlist.begin(); + for ( ; it != itEnd; ++it ) + { + double curInt = ( ( double )( *it ).intensity ); + + double newInt = max*1000/curInt; + ( *it ).intensity = qRound( newInt ); + } +} + +QValueList Spectrum::wavelengths( double min, double max ) +{ + QValueList list; + + QValueList::const_iterator it = m_bandlist.begin(); + const QValueList::const_iterator itEnd = m_bandlist.end(); + + for ( ; it != itEnd; ++it ) + { + if ( ( *it ).wavelength < min || ( *it ).wavelength > max ) + continue; + + list.append( ( *it ).wavelength ); + } + + return list; +} + +QString Spectrum::bandsAsHtml() +{ + QString html = "Chemical datai"; + + html += ""; + + QValueList::const_iterator it = m_bandlist.begin(); + const QValueList::const_iterator itEnd = m_bandlist.end(); + for (;it!=itEnd;++it) + { + html += QString( "" ) + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "\n"; + } + + html += "
" + i18n( "Wavelength: %1 nm" ).arg( ( *it ).wavelength ) + "" + i18n( "Intensity: %1" ).arg( ( *it ).intensity ) + "" + i18n( "Probability: %1 108s-1" ).arg( ( *it ).aki ) + "" + i18n( "Energy 1: %1" ).arg( ( *it ).energy1 ) + "" + i18n( "Energy 2: %1" ).arg( ( *it ).energy2 ) + "" + i18n( "Electron Configuration 1: %1" ).arg( ( *it ).electronconfig1 ) + "" + i18n( "Electron Configuration 2: %1" ).arg( ( *it ).electronconfig2 ) + "" + i18n( "Term 1: %1" ).arg( ( *it ).term1 ) + "" + i18n( "Term 2: %1" ).arg( ( *it ).term2 ) + "" + i18n( "J 1: %1" ).arg( ( *it ).J1 ) + "" + i18n( "J 2: %1" ).arg( ( *it ).J2 ) + "
"; + + html += ""; + return html; +} diff --git a/kalzium/src/spectrum.h b/kalzium/src/spectrum.h new file mode 100644 index 00000000..7578973d --- /dev/null +++ b/kalzium/src/spectrum.h @@ -0,0 +1,174 @@ +#ifndef SPECTRUM_H +#define SPECTRUM_H +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include +#include + +class QPixmap; +class Element; + +/** + * @author Carsten Niehaus + * + * This class represents an spectrum with all its properties + */ +class Spectrum +{ + public: + /** + * This spectrum doesn't belong to any element + */ + Spectrum(){} + + /** + * public destructor + */ + ~Spectrum(){} + + /** + * a band is one line in the spectrum of an element + */ + struct band + { + ///in nm) + double wavelength; + + ///Transition Probabilities + ///10^8s-1 (1000000000 per second) + double aki; + + ///number of energylevels per centimeter + double energy1; + + ///number of energylevels per centimeter + double energy2; + + ///relative. The highest is per definition 1000 + int intensity; + + QString electronconfig1; + QString electronconfig2; + QString term1; + QString term2; + QString J1; + QString J2; + }; + + /** + * adds the band @p b to the internal + * lists of bands + */ + void addBand( band b ){ + m_bandlist.append( b ); + } + + /** + * @param min the lowest allowed wavalength in nanometer + * @param max the highest allowed wavalength in nanometer + * + * @returns a spectrum with the wavelength in the range + * of @p min to @p max. The intensities are readjusted + * so that the biggest intensity is again 1000 and the + * others are adopted. + */ + Spectrum* adjustToWavelength( double min, double max ); + + /** + * sets the highest intensity to 1000 and adjusts the + * others + */ + void adjustIntensities(); + + /** + * @param min the lowest allowed wavalength in nanometer + * @param max the highest allowed wavalength in nanometer + * + * @return the wavelength in a QValueList + */ + QValueList wavelengths( double min, double max ); + + /** + * @return the smallest wavelength + */ + double min() const{ + return m_min; + } + + /** + * @return the highest wavelength + */ + double max() const{ + return m_max; + } + + /** + * @return the list of bands of the spectrum + */ + QValueList* bandlist(){ + return &m_bandlist; + } + + /** + * cache the values of the biggest and + * smallest wavelenght + */ + void adjustMinMax(){ + m_min = minBand(); + m_max = maxBand(); + } + + /** + * @return the data of a spectrum as HTML code + */ + QString bandsAsHtml(); + + /** + * @return the parent element of this spectrum + */ + Element* parentElement() + { return m_parentElement; } + + private: + /** + * @return the smallest wavelength + */ + double minBand(); + + /** + * @return the biggest wavelength + */ + double maxBand(); + + /** + * the internal dataset + */ + QValueList m_bandlist; + + /** + * the cached values of the highest and lowest wavelength + */ + double m_max, m_min; + + Element* m_parentElement; +}; +#endif // SPECTRUM_H diff --git a/kalzium/src/spectrumview.ui b/kalzium/src/spectrumview.ui new file mode 100644 index 00000000..2787ab66 --- /dev/null +++ b/kalzium/src/spectrumview.ui @@ -0,0 +1,224 @@ + +SpectrumView + + + SpectrumView + + + + 0 + 0 + 469 + 316 + + + + This page gives an overview about the spectrum this element. With the mouse you can zoom into the spectrum. + + + This page gives an overview about the spectrum this element + + + + unnamed + + + 0 + + + + m_spectrumWidget + + + This is the spectrum of the element + + + This is the spectrum of the element + + + + + layout2 + + + + unnamed + + + + label1 + + + &Minimum value: + + + minimumValue + + + + + minimumValue + + + 999 + + + 1 + + + 380 + + + This sets the leftmost wavelength of the spectrum + + + This sets the leftmost wavelength of the spectrum + + + + + label2 + + + Maximum &value: + + + maximumValue + + + + + maximumValue + + + 1000 + + + 2 + + + 780 + + + This sets the rightmost wavelength of the spectrum + + + This sets the rightmost wavelength of the spectrum + + + + + + + layout4 + + + + unnamed + + + + spacer4 + + + Horizontal + + + Expanding + + + + 211 + 21 + + + + + + exportButton + + + + + + Using this button you can export the spectrum as a graphic + + + Using this button you can export the spectrum as a graphic + + + + + + + spacer3 + + + Vertical + + + Expanding + + + + 21 + 1 + + + + + + + + SpectrumWidget +
spectrumwidget.h
+ + 400 + 230 + + 0 + + 5 + 5 + 0 + 0 + + image0 + setRightBorder(int) + setLeftBorder(int) +
+
+ + + 89504e470d0a1a0a0000000d4948445200000016000000160806000000c4b46c3b000003dd49444154388dad954168145718c77f13a7f64d59ca1b6a601ea4b20b82ee41ea1e7258a987067a301050410a965c02855e4a2f1e8a4df59443ab5028f494da1e5ae36d3d04d283150f858e07710583533074b698f60d98320f5cba9f65747a98d9a850430bfde0637830fce7ffbef9f1fdbdb22c1997e77913c02ec0072600afee9daaacfb0950008fcbb27ce28d8517cf2cbeda3dd07d7fe0060ba3add1fed4a504048c18613058ec3f9e739793dc4b36e29bf10a0517813f80475e5996789e3771ad77edb4d6f9a768c10efb844a918b256c1872b1988601c9418538b168353e07c4776eb1f64d9fb51fdc79e00b20f7ebebec4aee270bdd294d7ff322ea614a52082684e43eb84c613341a108f640e720a408da874c209a042605e01de012f0682cec3364bf953eaa106ce130939a7e0cb7be17aedfcc503e4821285f13ed53bc3b1fd29e1ed1d4900d85e61e05c85e207cd6f1c4ddec2e1d25240f134ca8595b1556961d14a0b5c2ec53280576200c3684a58f534ecc479c9887a816af2b00768f853dd330e492622615fd187ab5e8a963119d3968b70caeb028427a5746f4961dbd6f07b49b6d3a4703a28600424d95373116b6434ba8143687b5558714c2ecb188990568b584ac48e041c0cae59c53f321a73ed0e02bbe5cb6a821b86dc315a263c79886212f52702d92db7db48e786b0e222d3801551896cee7a4eb8efc012c9e35c4571de9cf42dc1f61f4f3708f1d638716d3502483147c304d68bd0e990848c8d2194bb2ee505a317b2424f773da1d8d1482dd043b7c8170c52918a5a0105a8d6a626a68583a9b93ae4bf5231b8a600a5a1af041f90a29c068f562c7289006e06b7e1a088a80deeaa872da5044539ac120e3c2394b1c87d8549042683503f2a754d4fc3ee3d8494af720349b8a6c20f4ae8c5878af45fe40983d1a1268b8700e061b198b1f5a64e888224dbb03e27698b1560a87307b52218554485d49593c63684d8fe874479cfec410451ab795410187e7349d436077728c58b4af387c04642be2ebe5012b9f437cd5d19dd6b8026c9ae3b6a49a2d42f2a310df08686945cdf173c265ba59d19089d06cc0cc4985d26d7a972dc9ba90dc1e546f17a0f768668e6b6e5d17ecd0a1fc9064735bb404ca6de1e45eb211276a5f64149908918699b911b36fb789fb16d9827c08ed0306d376740e417c2340fb6d5c9192de01e077e031508ed76680cf47dd37d5d9d054488908a80a21557f5ef9358280508dc33948fa82cd04977109f80af8857ad1bf04ec053e037ee5692afcdbfe0df80e380ebc014c6e2f7aaaad1402afd5cf807aa1b07395f5f547404e9520f97634799ee7032f03afd4a2bbf96f99f7572dfe27e3681ad7ff19a67f032fb1f0843cf31fdf0000000049454e44ae426082 + + + + + minimumValue + valueChanged(int) + m_spectrumWidget + setLeftBorder(int) + + + maximumValue + valueChanged(int) + m_spectrumWidget + setRightBorder(int) + + + exportButton + clicked() + SpectrumView + slotExportAsImage() + + + + slotExportAsImage() + + + + spectrumwidget.h + kpushbutton.h + +
diff --git a/kalzium/src/spectrumviewimpl.cpp b/kalzium/src/spectrumviewimpl.cpp new file mode 100644 index 00000000..b7a3b479 --- /dev/null +++ b/kalzium/src/spectrumviewimpl.cpp @@ -0,0 +1,47 @@ +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ +#include "spectrumviewimpl.h" + +#include + +#include +#include +#include +#include +#include + +#include "exporter.h" + +SpectrumViewImpl::SpectrumViewImpl( QWidget *parent, const char* name ) + : SpectrumView( parent, name ) +{ + resize( minimumSizeHint() ); + // simulating an update + m_spectrumWidget->setRightBorder( maximumValue->value() ); + exportButton->setGuiItem( KGuiItem( i18n( "&Export Spectrum as Image" ), "fileexport" ) ); +} + +void SpectrumViewImpl::slotExportAsImage() +{ + Exporter* exporter = new Exporter(); + QString fileName = KFileDialog::getSaveFileName( + QString::null, exporter->supportedImageFormats(), + this, i18n( "Save Spectrum" ) ); + if( !fileName.isEmpty() ) + { + if ( !exporter->saveAsImage( &m_spectrumWidget->pixmap(), fileName ) ) + KMessageBox::error( this, i18n( "The spectrum could not be saved" ), i18n( "Image Could Not Be Saved") ); + } + delete exporter; +} +#include "spectrumviewimpl.moc" diff --git a/kalzium/src/spectrumviewimpl.h b/kalzium/src/spectrumviewimpl.h new file mode 100644 index 00000000..131a602c --- /dev/null +++ b/kalzium/src/spectrumviewimpl.h @@ -0,0 +1,49 @@ +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ +#ifndef SPECTRUMVIEWIMPL_H +#define SPECTRUMVIEWIMPL_H + +#include "spectrumview.h" +#include "spectrum.h" +#include "spectrumwidget.h" + +/** + * @author Carsten Niehaus + */ +class SpectrumViewImpl : public SpectrumView +{ + Q_OBJECT + + public: + /** + * @param parent the parent widget + * @param name the name used internally + */ + SpectrumViewImpl( QWidget* parent, const char* name ); + + /** + * sets the spectrum to @p spec + * @param spec the spectrum to display + */ + void setSpectrum( Spectrum* spec ){ + m_spectrumWidget->setSpectrum( spec ); + } + + private slots: + /** + * export the spectrum as an image + */ + void slotExportAsImage(); +}; + +#endif // SPECTRUMVIEWIMPL_H diff --git a/kalzium/src/spectrumwidget.cpp b/kalzium/src/spectrumwidget.cpp new file mode 100644 index 00000000..5531163c --- /dev/null +++ b/kalzium/src/spectrumwidget.cpp @@ -0,0 +1,430 @@ +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ +#include "spectrumwidget.h" +#include "spectrum.h" +#include "element.h" +#include "kalziumutils.h" + +#include +#include +#include +#include + +#include +#include +#include +#include +#include + +#include +#if defined(Q_OS_SOLARIS) +#include +#endif + +SpectrumWidget::SpectrumWidget( QWidget *parent, const char* name ) : QWidget( parent, name ) +{ + startValue = 0; + endValue = 0; + + m_LMBPointCurrent.setX( -1 ); + m_LMBPointPress.setX( -1 ); + + m_showtooltip = false; + + m_realHeight = 200; + + Gamma = 0.8; + IntensityMax = 255; + + setType( EmissionSpectrum ); + + setMinimumSize( 400, 230 ); + setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Expanding ); + setBackgroundMode( NoBackground ); +} + +void SpectrumWidget::paintEvent( QPaintEvent * /*e*/ ) +{ + if ( !m_spectrum ) + return; + + m_pixmap.resize( width(), height() ); + m_pixmap.fill( this, width(), height() ); + + QPainter p; + p.begin( &m_pixmap, this ); + p.fillRect( 0, 0, width(), m_realHeight, Qt::black ); + + paintBands( &p ); + + drawTickmarks( &p ); + + if ( m_showtooltip ) + drawTooltip( &p ); + + if ( m_LMBPointPress.x() != -1 && m_LMBPointCurrent.x() != -1 ) + drawZoomLine( &p ); + + p.end(); + bitBlt( this, 0, 0, &m_pixmap ); +} + +void SpectrumWidget::drawZoomLine( QPainter* p ) +{ + p->setPen( Qt::white ); + p->drawLine( m_LMBPointPress.x(), m_LMBPointPress.y(), m_LMBPointCurrent.x(), m_LMBPointPress.y() ); + p->drawLine( m_LMBPointCurrent.x(), m_LMBPointPress.y()+10, m_LMBPointCurrent.x(), m_LMBPointPress.y()-10 ); + p->drawLine( m_LMBPointPress.x(), m_LMBPointPress.y()+10, m_LMBPointPress.x(), m_LMBPointPress.y()-10 ); + +} + +void SpectrumWidget::paintBands( QPainter* p ) +{ + if ( m_type == AbsorptionSpectrum ) + { + for ( double va = startValue; va <= endValue ; va += 0.1 ) + { + int x = xPos( va ); + p->setPen( linecolor( va ) ); + p->drawLine( x,0,x, m_realHeight ); + } + + p->setPen( Qt::black ); + } + + int i = 0; + int x = 0; + int temp = 0; + + for ( QValueList::Iterator it = m_spectrum->bandlist()->begin(); + it != m_spectrum->bandlist()->end(); + ++it ) + { + if ( ( *it ).wavelength < startValue || ( *it ).wavelength > endValue ) + continue; + + x = xPos( ( *it ).wavelength ); + + temp = 0; + + switch ( m_type ) + { + case EmissionSpectrum: + p->setPen( linecolor( ( *it ).wavelength ) ); + p->drawLine( x,0,x, m_realHeight-1 ); + + p->setPen( Qt::black ); +// p->drawLine( x,m_realHeight,x, m_realHeight ); + break; + + case AbsorptionSpectrum: + p->setPen( Qt::black ); + p->drawLine( x,0,x, m_realHeight-1 ); + break; + } + + i++; + } +} + +QColor SpectrumWidget::linecolor( double spectrum ) +{ + int r,g,b; + wavelengthToRGB( spectrum, r,g,b ); + + QColor c( r,g,b ); + return c; +} + + +void SpectrumWidget::wavelengthToRGB( double wavelength, int& r, int& g, int& b ) +{ + double blue = 0.0, green = 0.0, red = 0.0, factor = 0.0; + + int wavelength_ = ( int ) floor( wavelength ); + if ( wavelength_ < 380 || wavelength_ > 780 ) + { + //make everything white + r = g = b = 255; + return; + } + else if ( wavelength_ > 380 && wavelength_ < 439 ) + { + red = -( wavelength-440 ) / ( 440-380 ); + green = 0.0; + blue = 1.0; + + } + else if ( wavelength_ > 440 && wavelength_ < 489 ) + { + red = 0.0; + green = ( wavelength-440 ) / ( 490-440 ); + blue = 1.0; + } + else if ( wavelength_ > 490 && wavelength_ < 509 ) + { + red = 0.0; + green = 1.0; + blue = -( wavelength-510 ) / ( 510-490 ); + } + else if ( wavelength_ > 510 && wavelength_ < 579 ) + { + red = ( wavelength-510 ) / ( 580-510 ); + green = 1.0; + blue = 0.0; + } + else if ( wavelength_ > 580 && wavelength_ < 644 ) + { + red = 1.0; + green = -( wavelength-645 ) / ( 645-580 ); + blue = 0.0; + } + else if ( wavelength_ > 645 && wavelength_ < 780 ) + { + red = 1.0; + green = 0.0; + blue = 0.0; + } + + if ( wavelength_ > 380 && wavelength_ < 419 ) + factor = 0.3 + 0.7*( wavelength - 380 ) / ( 420 - 380 ); + else if ( wavelength_ > 420 && wavelength_ < 700 ) + factor = 1.0; + else if ( wavelength_ > 701 && wavelength_ < 780 ) + factor = 0.3 + 0.7*( 780 - wavelength ) / ( 780 - 700 ); + else + factor = 0.0; + + r = Adjust( red, factor ); + g = Adjust( green, factor ); + b = Adjust( blue, factor ); +} + +int SpectrumWidget::Adjust( double color, double factor ) +{ + if ( color == 0.0 ) + return 0; + else + return qRound( IntensityMax * pow( color*factor, Gamma ) ); +} + +void SpectrumWidget::drawTickmarks( QPainter* p ) +{ + //the size of the text on the tickmarks + const int space = 20; + + //the distance between the tickmarks in pixel + const int d = 10; + + //the total number of tickmarks to draw (small and long) + const int numberOfTickmarks = ( int )floor( width()/d ); + + double pos = 0.0; + + for ( int i = 0; i < numberOfTickmarks; i++ ) + { + if( i%5 == 0 ) + {//long tickmarks plus text + p->drawLine( i*d, m_realHeight, i*d, m_realHeight+10 ); + if ( i%10 == 0 && + i*d > space && + i*d < width()-space ) + { + pos = ( double ) ( i*d )/width(); + p->fillRect( i*d-space, m_realHeight+12, 2*space, 15, Qt::white ); + p->drawText( i*d-space, m_realHeight+12, 2*space, 15, Qt::AlignCenter, KalziumUtils::localizedValue( KalziumUtils::strippedValue( Wavelength( pos ) ), 6 ) ); + } + } + else {//small tickmarks + p->drawLine( i*d, m_realHeight, i*d, m_realHeight+5 ); + } + } +} + +void SpectrumWidget::keyPressEvent( QKeyEvent *e ) +{ + kdDebug() << "SpectrumWidget::keyPressEvent()" << endl; + switch ( e->key() ) + { + case Key_Plus: + slotZoomIn(); + break; + case Key_Minus: + slotZoomOut(); + break; + } +} + +void SpectrumWidget::slotZoomOut() +{ + kdDebug() << "SpectrumWidget::slotZoomOut() "<< startValue << ":: "<< endValue << endl; + + double diff = endValue - startValue; + + double offset = diff * 0.05; + + endValue = endValue + offset; + startValue = startValue - offset; + + //check for invalid values + if ( startValue < 0.0 ) + startValue = 0.0; + + if ( endValue > 800.0 ) + endValue = 800.0; + + setBorders( ( int ) startValue, ( int )endValue ); + + kdDebug() << "SpectrumWidget::slotZoomOut() "<< startValue << ":: "<< endValue << endl; +} + +void SpectrumWidget::slotZoomIn() +{ + kdDebug() << "SpectrumWidget::slotZoomIn() "<< startValue << ":: "<< endValue << endl; + + double diff = endValue - startValue; + + double offset = diff * 0.05; + + endValue = endValue - offset; + startValue = startValue + offset; + + setBorders( ( int ) startValue, ( int )endValue ); + + kdDebug() << "SpectrumWidget::slotZoomIn() "<< startValue << ":: "<< endValue << endl; +} + +void SpectrumWidget::mouseMoveEvent( QMouseEvent *e ) +{ + m_LMBPointCurrent = e->pos(); + update(); +} + +void SpectrumWidget::mousePressEvent( QMouseEvent *e ) +{ + if ( e->button() == QMouseEvent::LeftButton ) + m_LMBPointPress = e->pos(); + if ( e->button() == QMouseEvent::RightButton ) + slotZoomOut(); +//FIXME +//the tooltip is not really working. Better to not have it +//in KDE 3.4 and think of a better solution. +//PrepareTooltip( Wavelength( ( double )e->pos().x()/width() ) ); +} + +void SpectrumWidget::PrepareTooltip( double wavelength ) +{ + Spectrum::band band; + + QValueList::const_iterator it = m_spectrum->bandlist()->begin(); + const QValueList::const_iterator itEnd = m_spectrum->bandlist()->end(); + + //find the difference in percent (1.0 is 100%, 0.1 is 10%) + double dif = 0.0; + + bool foundWavelentgh = false; + + //find the highest intensity + for ( ; it != itEnd; ++it ) + { + double thisdif = ( *it ).wavelength / wavelength; + + if ( thisdif < 0.9 || thisdif > 1.1 ) + continue; + + if ( thisdif > 1.0 ){//convert for example 1.3 to 0.7 + thisdif = thisdif-1; + thisdif = 1-thisdif; + } + + if ( thisdif > dif ) + { + dif = thisdif; + band = *it; + foundWavelentgh = true; + } + } + if ( foundWavelentgh ) + { + m_band = band; + m_showtooltip = true; + } + else + m_showtooltip = false; + + kdDebug() << "SpectrumWidget::PrepareTooltip(): "<< m_showtooltip << endl; + update(); +} + +void SpectrumWidget::drawTooltip( QPainter *p ) +{ + p->setPen( Qt::white ); + QPoint pt = mapFromGlobal( QCursor::pos() ); + p->drawText( pt, i18n("Wavelength: %1").arg(m_band.wavelength) ); + pt.setY( pt.y() + 15 ); + p->drawText( pt, i18n("Intensity: %1").arg(m_band.intensity) ); + pt.setY( pt.y() + 15 ); + p->drawText( pt, i18n("Energy 1, Energy 2: %1, %2").arg(m_band.energy1).arg( m_band.energy2 )); + pt.setY( pt.y() + 15 ); + p->drawText( pt, i18n("Term 1, Term 2: %1, %2").arg(m_band.term1).arg( m_band.term2 )); + pt.setY( pt.y() + 15 ); + p->drawText( pt, i18n("J 1, J 2: %1, %2").arg(m_band.J1).arg( m_band.J2 )); +} + +void SpectrumWidget::mouseReleaseEvent( QMouseEvent *e ) +{ + if ( e->button() == QMouseEvent::LeftButton ) + { + int left = (int)Wavelength( ( double )m_LMBPointPress.x()/width() ); + int right = (int)Wavelength( ( double )e->pos().x()/width() ); + + if ( left == right ) + return; + + if ( left > right ) + setBorders( right, left ); + else + setBorders( left, right ); + } + + m_LMBPointPress.setX( -1 ); + m_LMBPointCurrent.setX( -1 ); +} + +QPixmap SpectrumWidget::pixmap() +{ + QPixmap tmp( m_pixmap ); + QString text; + + if( m_type == EmissionSpectrum ) + text = i18n( "Emission spectrum of %1" ).arg( m_spectrum->parentElement()->elname() ); + else + text = i18n( "Absorption spectrum of %1" ).arg( m_spectrum->parentElement()->elname() ); + + QPainter p( &tmp ); + p.setPen( Qt::black ); + p.drawText( 30, m_realHeight + 70, text ); + + return tmp; +} + +#include "spectrumwidget.moc" + diff --git a/kalzium/src/spectrumwidget.h b/kalzium/src/spectrumwidget.h new file mode 100644 index 00000000..84a6fd80 --- /dev/null +++ b/kalzium/src/spectrumwidget.h @@ -0,0 +1,234 @@ +/*************************************************************************** + * Copyright (C) 2005 by Carsten Niehaus * + * cniehaus@kde.org * + * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ +#ifndef SPECTRUMWIDGET_H +#define SPECTRUMWIDGET_H + +#include + +#include + +#include "spectrum.h" + +/** + * @author Carsten Niehaus + * + */ +class SpectrumWidget : public QWidget +{ + Q_OBJECT + + public: + SpectrumWidget( QWidget *parent, const char* name = 0 ); + + ~SpectrumWidget(){} + + void setSpectrum( Spectrum* spec ){ + m_spectrum = spec; + update(); + } + + Spectrum* spectrum()const{ + return m_spectrum; + } + + /** + * This limits the width of the spectrum in terms of + * wavelength. For example you can set it to only + * show the area between 500 and 550 nm. Invalid values + * will be set back to the default start- and stopvalues + * + * @param left the left border + * @param right the right border + */ + void setBorders( double left, double right ){ + //check for invalid values + if ( startValue < 0.0 ) + startValue = 0.0; + + if ( endValue > 800.0 ) + endValue = 800.0; + + startValue = left; + endValue = right; + + update(); + } + + /** + * find the nearest band. The returned value is the number + * of pixel the next band is away + */ + int findNearestBand( QValueList::iterator it ); + + /** + * there are several possible types. + */ + enum SpectrumType + { + EmissionSpectrum = 0, + AbsorptionSpectrum + }; + + /** + * sets the type of the spectrum to @p t + * @param t the type of the spectrum + */ + void setType( SpectrumType t ){ + m_type = t; + } + + /** + * @return the currently active type + * of the spectrum + */ + SpectrumType spectrumType() const{ + return m_type; + } + + /** + * @returns the color of a line + * @param spectrum the value of the spectrum + */ + QColor linecolor( double spectrum ); + + double Gamma; + int IntensityMax; + + /** + * @return the adjusted value of the @p color. The + * correction depends on @p factor which has been + * figured out emperically + */ + int Adjust( double color, double factor ); + + /** + * @return the postion in the widget of a band + * with the wavelength @p wavelength + * + * @param wavelength the wavelength for which the position is needed + */ + inline int xPos( double wavelength ){ + return ( int ) ( ( wavelength-startValue ) * width() / ( endValue - startValue ) ); + } + + void PrepareTooltip( double wavelength ); + + void showTooltip( Spectrum::band band ); + + /** + * @param xpos The ratio of the position relative to the width + * of the widget. + * @return the wavelength on position @p xpos + */ + inline double Wavelength( double xpos ){ + return startValue + ( ( endValue-startValue ) * xpos ); + } + + /** + * This method changes the three values @p r, @p g and @p b to the + * correct values + * @param wavelength the wavelength for which the color is searched + * @param r red + * @param g green + * @param b blue + */ + void wavelengthToRGB( double wavelength, int& r, int& g, int& b ); + + QPixmap pixmap(); + + private: + QValueList m_spectra; + + SpectrumType m_type; + + Spectrum *m_spectrum; + + QPixmap m_pixmap; + + bool m_showtooltip; + + Spectrum::band m_band; + + void paintBands( QPainter* p ); + void drawZoomLine( QPainter* p ); + void drawTooltip( QPainter *p ); + + /** + * Draw the scale + */ + void drawTickmarks( QPainter *p ); + + double startValue; + double endValue; + + int m_realHeight; + + /** + * this QPoint stores the information where + * the left mouse button has been pressed. This + * is used for the mouse zooming + */ + QPoint m_LMBPointPress; + + QPoint m_LMBPointCurrent; + + public slots: + /** + * set the the maximum value to @p value + */ + void setRightBorder( int value ){ + endValue = value; + if ( endValue < startValue ) + startValue = endValue-1; + update(); + } + + /** + * set the the minimum value to @p value + */ + void setLeftBorder( int value ){ + startValue = value; + if ( startValue > endValue ) + endValue = startValue+1; + update(); + } + + /** + * activates the spectrum of the type @p spectrumtype + */ + void slotActivateSpectrum( int spectrumtype ){ + m_type = ( SpectrumType )spectrumtype; + update(); + } + + private slots: + void slotZoomIn(); + void slotZoomOut(); + + protected: + virtual void paintEvent( QPaintEvent *e ); + virtual void keyPressEvent(QKeyEvent *e); + virtual void mouseMoveEvent( QMouseEvent *e ); + virtual void mousePressEvent( QMouseEvent *e ); + virtual void mouseReleaseEvent( QMouseEvent *e ); +}; + +#endif // SPECTRUMWIDGET_H diff --git a/kalzium/src/tempunit.cpp b/kalzium/src/tempunit.cpp new file mode 100644 index 00000000..55d3630f --- /dev/null +++ b/kalzium/src/tempunit.cpp @@ -0,0 +1,134 @@ +/*************************************************************************** + * Copyright (C) 2005 by Pino Toscano * + * toscano.pino@tiscali.it * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "tempunit.h" + +double TempUnit::convert( double value, TempUnit::Unit from, TempUnit::Unit to ) +{ + /** + * These are the four formula needed to convert from + * Kelvin the the other units: + + Kelvin Celsius °C = K - 273,15 + Kelvin Fahrenheit °F = K × 1,8 - 459,67 + Kelvin Rankine °Ra = K × 1,8 + Kelvin Reaumur °R = ( K - 273,15 ) × 0,8 + */ + + if ( from != Kelvin ) + value = convertToKelvin( value, from ); + + //now 'value' is in Kelvin + switch( to ) + { + case Celsius: + return value - 273.16; + case Fahrenheit: + return value * 1.8 - 459.67; + case Rankine: + return value * 1.8; + case Reaumur: + return ( value - 273.15 )* 0.8; + case Kelvin: + return value; + } + return value; +} + +double TempUnit::convertToKelvin( const double value, TempUnit::Unit from ) +{ + switch( from ) + { + case Kelvin: + return value; + case Celsius: + return value + 273.16; + case Fahrenheit: + return ( value + 459.67 )/1.8; + case Rankine: + return value / 1.8; + case Reaumur: + return ( value * 1.25 ) + 273.15; + } + return value; +} + +double TempUnit::convert( const double value, int from, int to ) +{ + return convert( value, (TempUnit::Unit)from, (TempUnit::Unit)to ); +} + +QStringList TempUnit::unitListSymbols() +{ + QStringList list; + list << "K"; + list << QString::fromUtf8("°C"); + list << QString::fromUtf8("°F"); + list << QString::fromUtf8("°Ra"); + list << QString::fromUtf8("°R"); + return list; +} + +QString TempUnit::unitListSymbol( int i ) +{ + QStringList l = unitListSymbols(); + if ( ( i < 0 ) || ( i >= (int)l.count() ) ) + return l[0]; + return l[i]; +} + +QPair TempUnit::rangeForUnit( TempUnit::Unit u ) +{ + switch( u ) + { + case Kelvin: + { + return QPair( 0.0, 5000.0 ); + break; + } + case Celsius: + { + return QPair( -273.16, 4726.84 ); + break; + } + case Fahrenheit: + { + return QPair( -459.67, 8540.33 ); + break; + } + case Rankine: + { + return QPair( 0.0, 9000.0 ); + break; + } + case Reaumur: + { + return QPair( -218.52, 3781.48 ); + break; + } + } + return QPair( 0.0, 5000.0 ); +} + +QPair TempUnit::rangeForUnit( int u ) +{ + return rangeForUnit( (TempUnit::Unit)u ); +} + diff --git a/kalzium/src/tempunit.h b/kalzium/src/tempunit.h new file mode 100644 index 00000000..db4c366e --- /dev/null +++ b/kalzium/src/tempunit.h @@ -0,0 +1,92 @@ +#ifndef TEMPUNIT_H +#define TEMPUNIT_H +/*************************************************************************** + * Copyright (C) 2005 by Pino Toscano * + * toscano.pino@tiscali.it * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include +#include + +/** + * This class obtains all the info needed to work with the units of measure + * of temperature. + * + * It has static methods you can call to get the various infos. The most + * important methods is convert(), that performs conversions. + * + * @author Pino Toscano + */ +class TempUnit +{ + public: + + enum Unit { Kelvin = 0, + Celsius, + Fahrenheit, + Rankine, + Reaumur + }; + + /** + * Convert the temperature unit @p value given in the unit + * @p from to the unit @p to. + * + * @return the value converted + */ + static double convert( double value, + TempUnit::Unit from, + TempUnit::Unit to ); + + + /** + * @param value the temperature to convert + * @param from the unit from which to convert + * + * @return the temperature to Kelvin + */ + static double convertToKelvin( const double value, + TempUnit::Unit from ); + + /** + * @overload + */ + static double convert( const double value, + int from, + int to ); + + /** + * @return a list with the symbols of the temperature units + * we support + */ + static QStringList unitListSymbols(); + + /** + * @return the symbol of the @p i -th unit + */ + static QString unitListSymbol( int i ); + + static QPair rangeForUnit( TempUnit::Unit u ); + + /** + * @overload + */ + static QPair rangeForUnit( int u ); + +}; +#endif // TEMPUNIT_H diff --git a/kalzium/src/timewidget.ui b/kalzium/src/timewidget.ui new file mode 100644 index 00000000..fcb46391 --- /dev/null +++ b/kalzium/src/timewidget.ui @@ -0,0 +1,201 @@ + +TimeWidget + + + TimeWidget + + + + 0 + 0 + 196 + 396 + + + + + unnamed + + + + spacer3 + + + Vertical + + + Fixed + + + + 21 + 20 + + + + + + layout3 + + + + unnamed + + + + lbl1_2 + + + + 5 + 0 + 0 + 0 + + + + Year: + + + + + spacer1_2 + + + Horizontal + + + Expanding + + + + 20 + 21 + + + + + + + + layout5 + + + + unnamed + + + + time_slider + + + 1650 + + + 2005 + + + 1994 + + + Horizontal + + + Below + + + 50 + + + + + spacer9 + + + Horizontal + + + Fixed + + + + 5 + 21 + + + + + + Number1 + + + 2005 + + + 1650 + + + 1994 + + + + + + + verticalSpacer + + + Vertical + + + Fixed + + + + 20 + 16 + + + + + + text + + + + 1 + + + + Move the slider +to find out about +the discovery dates +of the elements + + + WidgetWidth + + + + + + + + + Number1 + valueChanged(int) + time_slider + setValue(int) + + + time_slider + valueChanged(int) + Number1 + setValue(int) + + + + + knuminput.h + + diff --git a/kalzium/src/timewidget_impl.cpp b/kalzium/src/timewidget_impl.cpp new file mode 100644 index 00000000..5f460f4a --- /dev/null +++ b/kalzium/src/timewidget_impl.cpp @@ -0,0 +1,40 @@ +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + copyright : (C) 2005 by Pino Toscano + email : kalzium@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ +#include "timewidget_impl.h" + +#include +#include +#include +#include + +#include + +TimeWidgetIMPL::TimeWidgetIMPL( QWidget *parent, const char* name ) + : TimeWidget( parent, name ) +{ + text->setAlignment( text->alignment() | Qt::WordBreak ); + text->setTextFormat( Qt::RichText ); + text->setReadOnly( true ); + text->setPaletteBackgroundColor( paletteBackgroundColor() ); + text->setFrameStyle( QFrame::NoFrame ); +} + +void TimeWidgetIMPL::slotChanged( int value ) +{ + ( void )value; + text->hide(); + verticalSpacer->changeSize( 21, 5, QSizePolicy::Fixed, QSizePolicy::Expanding ); +} + +#include "timewidget_impl.moc" diff --git a/kalzium/src/timewidget_impl.h b/kalzium/src/timewidget_impl.h new file mode 100644 index 00000000..6664ca15 --- /dev/null +++ b/kalzium/src/timewidget_impl.h @@ -0,0 +1,41 @@ +#ifndef TIMEWIDGET_IMPL_H +#define TIMEWIDGET_IMPL_H + +/*************************************************************************** + copyright : (C) 2005 by Carsten Niehaus + email : cniehaus@kde.org + ***************************************************************************/ +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ***************************************************************************/ + +#include "timewidget.h" + +/** + * @author Carsten Niehaus + */ +class TimeWidgetIMPL : public TimeWidget +{ + Q_OBJECT + + public: + /** + * @param parent The parent of this widget + * @param name The name of this widget + */ + TimeWidgetIMPL( QWidget *parent = 0, const char* name = 0 ); + + public slots: + /** + * this slot will react to the new year + * @param value the new year + */ + void slotChanged( int value ); +}; +#endif // TIMEWIDGET_IMPL_H + -- cgit v1.2.1