本文整理匯總了C++中Colorf函數的典型用法代碼示例。如果您正苦於以下問題:C++ Colorf函數的具體用法?C++ Colorf怎麽用?C++ Colorf使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Colorf函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: Colorf
bool EditRectOP::onDraw() const
{
if (ZoomViewOP::onDraw()) return true;
if (m_captured.shape)
{
if (m_cmpt)
{
if (RectShape* rect = dynamic_cast<RectShape*>(m_captured.shape))
{
PrimitiveDraw::drawCircle(Vector(rect->m_rect.xCenter(), rect->m_rect.yCenter()),
m_cmpt->getNodeCaptureDistance(), true, 2, Colorf(0.4f, 1.0f, 0.4f));
if (m_captured.pos.isValid())
PrimitiveDraw::drawCircle(m_captured.pos, m_cmpt->getNodeCaptureDistance(),
true, 2, Colorf(1.0f, 0.4f, 0.4f));
}
}
}
else
{
if (m_firstPress.isValid() && m_currPos.isValid())
PrimitiveDraw::drawRect(m_firstPress, m_currPos);
}
return false;
}
示例2: Colorf
bool EditBezierOP::onDraw() const
{
if (ZoomViewOP::onDraw()) return true;
if (m_captured.shape)
{
if (m_cmpt)
{
if (BezierShape* bezier = dynamic_cast<BezierShape*>(m_captured.shape))
{
PrimitiveDraw::drawCircle(Vector(bezier->getRect().xCenter(), bezier->getRect().yCenter()),
m_cmpt->getNodeCaptureDistance(), true, 2, Colorf(0.4f, 1.0f, 0.4f));
if (m_captured.pos.isValid())
PrimitiveDraw::drawCircle(m_captured.pos, m_cmpt->getNodeCaptureDistance(),
true, 2, Colorf(1.0f, 0.4f, 0.4f));
}
}
}
else
{
if (m_firstPress.isValid() && m_currPos.isValid())
{
BezierShape bezier(m_firstPress, m_currPos);
bezier.draw();
}
// PrimitiveDraw::drawRect(m_firstPress, m_currPos);
}
return false;
}
示例3: Colorf
Light::Light()
{
m_diffuse = Colorf(1,1,1);
m_specular = Colorf(1,1,1);
m_ambient = Colorf(0,0,0);
m_intensity = 1.f;
}
示例4: name
Colorf CVar::toColorf(bool* isValid) const
{
if (m_type != Color)
{
if (com_developer && com_developer->toBoolean())
orConsoleRef.print(orConsoleRef.Warning, "CVar %s is not a color", name().c_str());
if (isValid != NULL)
*isValid = false;
return Colorf();
}
if (isValid != NULL)
*isValid = true;
int r, g, b, a;
std::stringstream ss;
ss << m_value;
ss >> r;
ss >> g;
ss >> b;
ss >> a;
return Colorf(r*inv255, g*inv255, b*inv255, a*inv255);
}
示例5: create_window
bool FullScreen::update()
{
const float virtual_screen_width = 800.0f;
const float virtual_screen_height = 600.0f;
game_time.update();
// Check for fullscreen switch
if (fullscreen_requested != is_fullscreen)
{
is_fullscreen = fullscreen_requested;
create_window();
}
if (window.get_gc() != canvas.get_gc())
{
canvas = Canvas(window); // Always get the graphic context, the window may have been recreated
}
canvas.clear(Colorf(0.0f,0.0f,0.2f));
int font_size = 28;
font_size *= canvas.get_width() / virtual_screen_width;
font.set_height(font_size);
canvas.set_transform(Mat4f::identity());
if (is_fullscreen)
{
font.draw_text(canvas, 16, font_size, "Full Screen Mode. Press 'F' to switch to resizable window.");
}
else
{
font.draw_text(canvas, 16, font_size, "Resizable Window. Press 'F' to switch to full screen mode.");
}
// Scale the drawing to the screen to a virtual screen size
Mat4f matrix = Mat4f::scale( (float) canvas.get_width() / virtual_screen_width, (float) canvas.get_height() /virtual_screen_height, 1.0f);
canvas.set_transform(matrix);
spr_logo.draw(canvas, virtual_screen_width-spr_logo.get_width(), virtual_screen_height-spr_logo.get_height());
spr_background.set_scale(0.5f, 0.5f);
spr_background.draw(canvas, 100, 100);
// Show a few alpha-blending moving rectangles that moves in circles
float x = cos(sin_count)*120.0f;
float y = sin(sin_count)*120.0f;
sin_count += 2.0f * game_time.get_time_elapsed();
canvas.fill_rect(Rectf( 320.0f + x -30.0f, 300.0f + y -30.0f, Sizef(60.0f, 60.0f)), Colorf(0.0f, 1.0f, 0.0, 0.5f));
x = cos(sin_count+3.14159f)*120.0f;
y = sin(sin_count+3.14159f)*120.0f;
canvas.fill_rect(Rectf( 320.0f + x -30.0f, 300 + y -30.0f, Sizef(60.0f, 60.0f)), Colorf(1.0f, 1.0f, 0.0, 0.5f));
window.flip(1);
return !quit;
}
示例6: Colorf
ColorHSLx<float, Colorf>::operator Colorf()
{
float hue = min(359.0f, max(0.0f, h)) / 360.0f;
float saturation = min(1.0f, max(0.0f, s));
float lightness = min(1.0f, max(0.0f, l));
if (saturation == 0.0f)
{
return Colorf(lightness, lightness, lightness, a);
}
float q;
if (lightness < 0.5f)
{
q = lightness * (1 + saturation);
}
else
{
q = lightness + saturation - lightness * saturation;
}
float p = 2.0f * lightness - q;
float temp_rgb[3];
temp_rgb[0] = hue + 1.0f / 3.0f;
temp_rgb[1] = hue;
temp_rgb[2] = hue - 1.0f / 3.0f;
for (auto & elem : temp_rgb)
{
while (elem < 0.0f)
{
elem += 1.0f;
}
while (elem > 1.0f)
{
elem -= 1.0f;
}
if (elem < (1.0f / 6.0f))
{
elem = p + (q - p) * 6.0f * elem;
}
else if (elem < 0.5f)
{
elem = q;
}
else if (elem < (2.0f / 3.0f))
{
elem = p + (q - p) * 6.0f * ((2.0f / 3.0f) - elem);
}
else
{
elem = p;
}
}
return Colorf(temp_rgb[0], temp_rgb[1], temp_rgb[2], a);
}
示例7: Colorf
Colorf ChessPiece::getColor(Surface32f surface, Vec2i pixel)
{
float r = *surface.getDataRed(pixel);
float g = *surface.getDataGreen(pixel);
float b = *surface.getDataBlue(pixel);
return Colorf(r, g, b);
}
示例8: hsvToRgb
/////////////////////////////////////////////////////////////////////////////
// Utilities
Colorf hsvToRgb( const vec3 &hsv )
{
float hue = hsv.x;
float sat = hsv.y;
float val = hsv.z;
float x = 0.0f, y = 0.0f, z = 0.0f;
if( hue == 1 ) hue = 0;
else
hue *= 6;
int i = static_cast<int>( floorf( hue ) );
float f = hue - i;
float p = val * ( 1 - sat );
float q = val* ( 1 - ( sat * f ) );
float t = val* ( 1 - ( sat * ( 1 - f ) ) );
switch( i ) {
case 0: x = val; y = t; z = p; break;
case 1: x = q; y = val; z = p; break;
case 2: x = p; y = val; z = t; break;
case 3: x = p; y = q; z = val; break;
case 4: x = t; y = p; z = val; break;
case 5: x = val; y = p; z = q; break;
}
return Colorf( x, y, z );
}
示例9: Colorf
void BoxStyle::set_border_none()
{
impl->border.left.type = BoxBorderValue::type_none;
impl->border.left.color = Colorf();
impl->border.left.width = 0.0f;
impl->border.right.type = BoxBorderValue::type_none;
impl->border.right.color = Colorf();
impl->border.right.width = 0.0f;
impl->border.top.type = BoxBorderValue::type_none;
impl->border.top.color = Colorf();
impl->border.top.width = 0.0f;
impl->border.bottom.type = BoxBorderValue::type_none;
impl->border.bottom.color = Colorf();
impl->border.bottom.width = 0.0f;
if (impl->style_changed) impl->style_changed();
}
示例10: Colorf
void App::draw_font_example()
{
int offset_x = 10;
int offset_y = 600;
int descender = (int) font_metrics.get_descent();
// Surrounding box
canvas.fill_rect(Rect(offset_x, offset_y+descender, offset_x + font_size.width, offset_y+descender - font_size.height), Colorf(0.0f, 0.0f, 0.0f));
// Draw the external leading line
int external_leading_offset = offset_y+font_metrics.get_external_leading() + font_metrics.get_descent();
canvas.draw_line(offset_x, external_leading_offset, offset_x + font_size.width, external_leading_offset, Colorf(0.5f, 0.5f, 0.0f));
// Draw the internal leading line
int internal_leading_offset = offset_y - font_metrics.get_ascent() + font_metrics.get_internal_leading();
canvas.draw_line(offset_x, internal_leading_offset, offset_x + font_size.width, internal_leading_offset, Colorf(0.5f, 0.5f, 0.0f));
// Draw outline to the bounding box
canvas.draw_line(offset_x, offset_y+descender, offset_x + font_size.width, offset_y+descender, Colorf(1.0f, 0.0f, 0.0f));
canvas.draw_line(offset_x, offset_y+descender- font_size.height, offset_x + font_size.width, offset_y+descender - font_size.height, Colorf(1.0f, 0.0f, 0.0f));
canvas.draw_line(offset_x + font_size.width, offset_y+descender, offset_x + font_size.width, offset_y+descender - font_size.height, Colorf(1.0f, 0.0f, 0.0f));
canvas.draw_line(offset_x, offset_y+descender, offset_x, offset_y+descender - font_size.height, Colorf(1.0f, 0.0f, 0.0f));
// Base line
canvas.draw_line(offset_x, offset_y, offset_x + font_size.width, offset_y, Colorf(0.0f, 1.0f, 0.0f));
selected_font.draw_text(canvas, offset_x, offset_y, font_text, Colorf::white);
}
示例11: radius_
CylinderMy::CylinderMy(double radius, const Point3d &base_center, const Point3d &top_center)
: radius_(radius)
, base_center_(base_center)
, top_center_(top_center)
, internal_rep_(NULL)
{
facet_color_ = Colorf(0.0f, 0.0f, 0.0f, 1.0f);
}
示例12: Colorf
void PhysicsDebugDraw_Impl::DrawPoint(const b2Vec2& p, float32 size, const b2Color& color)
{
used_canvas->fill_rect(p.x-size,
p.y-size,
p.x+size,
p.y+size,
Colorf(color.r,color.g,color.b));
}
示例13: PT
//Sets up some default lighting
void World::setup_lights() const
{
PT(AmbientLight) ambientLightPtr = new AmbientLight("ambientLight");
PT(DirectionalLight) directionalLightPtr = new DirectionalLight("directionalLight");
if(ambientLightPtr == NULL || directionalLightPtr == NULL)
{
nout << "ERROR: out of memory." << endl;
return;
}
ambientLightPtr->set_color(Colorf(.4,.4,.35,1));
directionalLightPtr->set_direction(LVector3f(0,8,-2.5));
directionalLightPtr->set_color(Colorf(0.9,0.8,0.9,1));
NodePath renderNp = m_windowFrameworkPtr->get_render();
renderNp.set_light(renderNp.attach_new_node(directionalLightPtr));
renderNp.set_light(renderNp.attach_new_node(ambientLightPtr));
}
示例14: Colorf
Sky::Sky() {
turbidity = 10;
// Initialize the Sun.
sun_direction = Eigen::Vector3f(0, 20, 1);
sun_direction.normalize();
sun_power = Colorf(150e3, 150e3, 150e3); // lx
}
示例15: drawGrid
void NanoApp::drawGrid (float size, float step)
{
gl::color (Colorf (0.2f, 0.2f, 0.2f));
for (float i = -size; i <= size; i += step)
{
gl::drawLine (vec3 (i, 0.0f, -size), vec3 (i, 0.0f, size));
gl::drawLine (vec3 (-size, 0.0f, i), vec3 (size, 0.0f, i));
}
}