00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #include "materialsolid.h"
00023
00024 using namespace zeitgeist;
00025 using namespace kerosin;
00026 using namespace salt;
00027 using namespace boost;
00028
00029 static bool readRGBA(const zeitgeist::ParameterList& in, RGBA& m)
00030 {
00031 if (
00032 (in.GetSize() != 4) ||
00033 (! in.GetValue(in[0], m.r())) ||
00034 (! in.GetValue(in[1], m.g())) ||
00035 (! in.GetValue(in[2], m.b())) ||
00036 (! in.GetValue(in[3], m.a()))
00037 )
00038 {
00039 return false;
00040 }
00041
00042 return true;
00043 }
00044
00045 FUNCTION(MaterialSolid,setAmbient)
00046 {
00047 RGBA m;
00048 if (! readRGBA(in,m))
00049 {
00050 return false;
00051 }
00052
00053 obj->SetAmbient(m);
00054 return true;
00055 }
00056
00057 FUNCTION(MaterialSolid,setDiffuse)
00058 {
00059 RGBA m;
00060 if (! readRGBA(in,m))
00061 {
00062 return false;
00063 }
00064
00065 obj->SetDiffuse(m);
00066 return true;
00067 }
00068
00069 FUNCTION(MaterialSolid,setSpecular)
00070 {
00071 RGBA m;
00072 if (! readRGBA(in,m))
00073 {
00074 return false;
00075 }
00076
00077 obj->SetSpecular(m);
00078 return true;
00079 }
00080
00081 FUNCTION(MaterialSolid,setEmission)
00082 {
00083 RGBA m;
00084 if (! readRGBA(in,m))
00085 {
00086 return false;
00087 }
00088
00089 obj->SetEmission(m);
00090 return true;
00091 }
00092
00093 void CLASS(MaterialSolid)::DefineClass()
00094 {
00095 DEFINE_BASECLASS(kerosin/Material);
00096 DEFINE_FUNCTION(setAmbient);
00097 DEFINE_FUNCTION(setDiffuse);
00098 DEFINE_FUNCTION(setSpecular);
00099 DEFINE_FUNCTION(setEmission);
00100 }