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 @ 6324

History | View | Annotate | Download (2.7 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 pageManager
24
     */
25
    public PaginatedBandByte(int rows, int columns, NoData noData, BandPageManager pageManager) {
26
        super(rows, columns, noData, pageManager);
27
        data = ByteBuffer.allocate(rowsPerPage * columns);
28

    
29
    }
30

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

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

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

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

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

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

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

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

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

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

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

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

    
101
}