fix color picking
This commit is contained in:
@@ -80,20 +80,18 @@ void CanvasModePen::on_MouseEvent(MouseEvent* me, glm::vec2& loc)
|
||||
else
|
||||
{
|
||||
canvas->stroke_start(loc, me->m_pressure, node->m_brush);
|
||||
m_dragging = true;
|
||||
}
|
||||
m_dragging = true;
|
||||
node->mouse_capture();
|
||||
break;
|
||||
case kEventType::MouseUpL:
|
||||
if (m_dragging)
|
||||
if (m_dragging && !m_picking)
|
||||
{
|
||||
canvas->stroke_end();
|
||||
m_dragging = false;
|
||||
node->mouse_release();
|
||||
canvas->stroke_end();
|
||||
}
|
||||
if (m_picking)
|
||||
if (m_dragging && m_picking)
|
||||
{
|
||||
m_picking = false;
|
||||
node->mouse_release();
|
||||
|
||||
glm::vec4 pix = canvas->pick_get(loc);
|
||||
@@ -136,11 +134,13 @@ void CanvasModePen::on_MouseEvent(MouseEvent* me, glm::vec2& loc)
|
||||
App::I.color->m_quad->set_value(1.f - hsv.y, 1.f - hsv.z);
|
||||
*/
|
||||
}
|
||||
m_dragging = false;
|
||||
m_picking = false;
|
||||
break;
|
||||
case kEventType::MouseMove:
|
||||
if (m_dragging)
|
||||
if (m_dragging && !m_picking)
|
||||
canvas->stroke_update(loc, me->m_pressure);
|
||||
if (m_picking)
|
||||
if (m_dragging && m_picking)
|
||||
{
|
||||
glm::vec4 pix = canvas->pick_get(loc);
|
||||
auto hsv = convert_rgb2hsv(glm::vec3(pix[0], pix[1], pix[2]));
|
||||
@@ -158,7 +158,6 @@ void CanvasModePen::on_MouseEvent(MouseEvent* me, glm::vec2& loc)
|
||||
if (m_picking)
|
||||
{
|
||||
m_picking = false;
|
||||
node->mouse_release();
|
||||
}
|
||||
break;
|
||||
default:
|
||||
|
||||
Reference in New Issue
Block a user