/* * selectopague.h -- Part of Chalk * * Copyright (c) 2004 Boudewijn Rempt (boud@valdyas.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 #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "selectopaque.h" typedef KGenericFactory SelectOpaqueFactory; K_EXPORT_COMPONENT_FACTORY( chalkselectopaque, SelectOpaqueFactory( "chalk" ) ) SelectOpaque::SelectOpaque(TQObject *tqparent, const char *name, const TQStringList &) : KParts::Plugin(tqparent, name) { if (tqparent->inherits("KisView")) { setInstance(SelectOpaqueFactory::instance()); setXMLFile(locate("data","chalkplugins/selectopaque.rc"), true); m_view = dynamic_cast(tqparent); m_view->canvasSubject()->selectionManager()->addSelectionAction( new KAction(i18n("&Select All Opaque Pixels..."), 0, 0, this, TQT_SLOT(slotActivated()), actionCollection(), "selectopaque") ); } } SelectOpaque::~SelectOpaque() { } void SelectOpaque::slotActivated() { KisSelectedTransaction *transaction; KisPaintDeviceSP layer = m_view->canvasSubject()->currentImg()->activeDevice(); if (!layer) return; TQApplication::setOverrideCursor(KisCursor::waitCursor()); if (layer->image()->undo()) transaction = new KisSelectedTransaction(i18n("Select Opaque Pixels"), layer); // XXX: Multithread this! TQ_INT32 x, y, w, h; layer->exactBounds(x, y, w, h); KisColorSpace * cs = layer->colorSpace(); if(! layer->hasSelection()) layer->selection()->clear(); KisSelectionSP selection = layer->selection(); KisHLineIterator hiter = layer->createHLineIterator(x, y, w, false); KisHLineIterator selIter = selection ->createHLineIterator(x, y, w, true); for (int row = 0; row < h; ++row) { while (!hiter.isDone()) { // Don't try to select transparent pixels. if (cs->getAlpha( hiter.rawData() ) > OPACITY_TRANSPARENT) { *(selIter.rawData()) = MAX_SELECTED; } ++hiter; ++selIter; } hiter.nextRow(); selIter.nextRow(); } TQApplication::restoreOverrideCursor(); layer->setDirty(); layer->emitSelectionChanged(); if (layer->image()->undo()) m_view->canvasSubject()->undoAdapter()->addCommand(transaction); } #include "selectopaque.moc"