Statistics
| Revision:

gvsig-raster / org.gvsig.raster / branches / org.gvsig.raster.2.4 / org.gvsig.raster / org.gvsig.raster.lib / org.gvsig.raster.lib.buffer / org.gvsig.raster.lib.buffer.impl / src / main / java / org / gvsig / raster / lib / buffer / impl / PaginatedBandByte.java @ 6220

History | View | Annotate | Download (2.73 KB)

1
package org.gvsig.raster.lib.buffer.impl;
2

    
3
import java.nio.ByteBuffer;
4
import java.util.Arrays;
5

    
6
import org.gvsig.raster.lib.buffer.api.Band.BandByte;
7
import org.gvsig.raster.lib.buffer.api.BandNotification;
8
import org.gvsig.raster.lib.buffer.api.BandPageManager;
9
import org.gvsig.raster.lib.buffer.api.BufferManager;
10
import org.gvsig.raster.lib.buffer.api.NoData;
11

    
12
/**
13
 * @author fdiaz
14
 *
15
 */
16
public class PaginatedBandByte extends AbstractPaginatedBand implements BandByte {
17

    
18

    
19
    /**
20
     * @param rows
21
     * @param columns
22
     * @param noData
23
     * @param rowsPerPage
24
     * @param pageManager
25
     */
26
    public PaginatedBandByte(int rows, int columns, NoData noData, BandPageManager pageManager) {
27
        super(rows, columns, noData, pageManager);
28
        data = ByteBuffer.allocate(rowsPerPage * columns);
29

    
30
    }
31

    
32
    @Override
33
    public int getDataType() {
34
        return BufferManager.TYPE_BYTE;
35
    }
36

    
37
    protected int getDataSize() {
38
        return 1;
39
    }
40

    
41
    @Override
42
    public Object get(int row, int column) {
43
        return getValue(row, column);
44
    }
45

    
46
    @Override
47
    protected void doSet(int row, int column, Object value) {
48
        setValue(row, column, (byte) value);
49
    }
50

    
51
    @Override
52
    protected void doFill(Object value) {
53
        value = nullValueToNoData(value);
54
        if(value == null){
55
            value = 0;
56
        }
57

    
58
        for(int row=0; row<this.rows; row+=this.rowsPerPage){
59
            loadPage(row);
60
            Arrays.fill((byte[])data.array(), (byte)value);
61
        }
62
    }
63

    
64
    @Override
65
    public byte getValue(int row, int column) {
66
        loadPage(row);
67
        return ((ByteBuffer) data).get( ((row-firstRowOfPage)*this.columns) + column);
68
    }
69

    
70
    @Override
71
    public void setValue(int row, int column, byte value) {
72
        doSetValue(row, column, value);
73
        notifyObservers(new DefaultBandNotification(BandNotification.SET, new Object[]{row, column, value}));
74
    }
75

    
76
    protected void doSetValue(int row, int column, byte value) {
77
        loadPage(row);
78
        ((ByteBuffer) data).put(((row-firstRowOfPage)*this.columns) + column, value);
79
    }
80

    
81
    @Override
82
    public byte[] createRowBuffer() {
83
        return new byte[getColumns()];
84
    }
85

    
86
    @Override
87
    public void fetchRow(int row, Object rowBuffer) {
88
        loadPage(row);
89
        byte[] source = (byte[]) data.array();
90
        byte[] target = (byte[]) rowBuffer;
91
        System.arraycopy(source, (row-firstRowOfPage)*this.columns, target, 0, this.columns);
92
    }
93

    
94
    @Override
95
    protected void doPutRow(int row, Object rowBuffer) {
96
        loadPage(row);
97
        byte[] source = (byte[]) rowBuffer;
98
        byte[] target = (byte[]) data.array();
99
        System.arraycopy(source, 0, target, (row-firstRowOfPage)*this.columns, this.columns);
100
    }
101

    
102
}