X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fport.cpp;h=678be06e991bdfb4dce3bbd31f88c36732795cbd;hb=e7ccd0d35487219da5d1e447e5fd435ad763ba4c;hp=1c940af8a4c69e4ea5808cd668dfe42238b51060;hpb=398c5e3e6e03080b6b057fd56858ab04694969ed;p=netvis.git diff --git a/source/port.cpp b/source/port.cpp index 1c940af..678be06 100644 --- a/source/port.cpp +++ b/source/port.cpp @@ -22,6 +22,7 @@ using namespace Msp; Port::Port(NetVis &v, unsigned n): netvis(v), number(n), + registered(false), mesh((GL::COLOR4_UBYTE, GL::VERTEX2)) { char buf[128]; @@ -31,13 +32,16 @@ Port::Port(NetVis &v, unsigned n): addr.sin_addr.s_addr = 0; int err = getnameinfo(reinterpret_cast(&addr), sizeof(sockaddr_in), 0, 0, buf, sizeof(buf), 0); if(err==0) + { name = buf; + registered = !isdigit(name[0]); + } else - name = Msp::lexical_cast(number); + name = Msp::lexical_cast(number); const map &ports = netvis.get_ports(); unsigned tries = 100; - if(ports.size()>100 && number>=1024) + if(ports.size()>100 && !registered) tries = 10000/ports.size()+1; float best_score = 0; for(unsigned i=0; (i::const_iterator j=ports.begin(); j!=ports.end(); ++j) { - if(number<1024 && j->first>1024) + if(registered && !j->second->is_registered()) break; const GL::Color &other = j->second->get_color(); float dr = c.r-other.r; @@ -88,13 +92,38 @@ Port::Port(NetVis &v, unsigned n): bld.end(); } +void Port::set_name(const string &n) +{ + name = n; +} + +void Port::add_activity(unsigned bytes) +{ + activity.add_bytes(bytes); +} + +void Port::tick(const Time::TimeDelta &dt) +{ + activity.tick(dt); +} + void Port::render() const { - GL::PushMatrix push_; + GL::MatrixStack::Push push_(GL::MatrixStack::modelview()); mesh.draw(); - GL::translate(16, 1, 0); - GL::scale_uniform(10); - GL::Immediate imm((GL::COLOR4_UBYTE, GL::TEXCOORD2, GL::VERTEX2)); - netvis.get_font().draw_string(name, imm); + { + GL::Immediate imm((GL::COLOR4_UBYTE, GL::VERTEX2)); + imm.begin(GL::QUADS); + imm.color(color.r, color.g, color.b, color.a); + unsigned x = static_cast(activity.get_average()/4096); + imm.vertex(14, 0); + imm.vertex(14+x, 0); + imm.vertex(14+x, 10); + imm.vertex(14, 10); + imm.end(); + } + GL::MatrixStack::modelview() *= GL::Matrix::translation(16, 1, 0); + GL::MatrixStack::modelview() *= GL::Matrix::scaling(10); + netvis.get_font().draw_string(name); GL::Texture::unbind(); }