/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code 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
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* Represents a single tile, used to store the rectangles covering the area
* of the mask where the tile is located.
*
* @author Clemens Eisserer
*/
public class MaskTile {
public MaskTile()
{
dirtyArea = new DirtyRegion();
}
}
/*
* EXA is not able to accalerate diagonal lines, we try to "guide" it a
* bit to avoid excessive migration See project documentation for an
* detailed explanation
*/
} else {
}
}
/* Entfernung in beiden Dimensionen berechnen */
/* Vorzeichen des Inkrements bestimmen */
if (dx < 0)
if (dy < 0)
/* feststellen, welche Entfernung groesser ist */
/* x ist schnelle Richtung */
} else {
/* y ist schnelle Richtung */
pdx = 0;
}
/* Initialisierungen vor Schleifenbeginn */
x = xstart;
y = ystart;
/* Pixel berechnen */
{
/* Aktualisierung Fehlerterm */
if (err < 0) {
/* Fehlerterm wieder positiv (>=0) machen */
/* Schritt in langsame Richtung, Diagonalschritt */
x += ddx;
y += ddy;
} else {
/* Schritt in schnelle Richtung, Parallelschritt */
x += pdx;
y += pdy;
}
// SetPixel(x,y);
// System.out.println(x+":"+y);
}
}
public void calculateDirtyAreas()
{
dirtyArea.growDirtyRegion(x, y,
}
}
public void reset() {
}
public void translate(int x, int y) {
}
rects.translateRects(x, y);
}
return rects;
}
return dirtyArea;
}
}