1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
|
/***************************************************************************
kvaluecolumn.cpp - description
-------------------
begin : Mit Sep 3 2003
copyright : (C) 2003 by Friedrich W. H. Kossebau
email : Friedrich.W.H@Kossebau.de
***************************************************************************/
/***************************************************************************
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License version 2 as published by the Free Software Foundation. *
* *
***************************************************************************/
// qt specific
#include <qpainter.h>
// lib specific
#include "kcolumnsview.h"
#include "kbuffercursor.h"
#include "kbufferlayout.h"
#include "kbufferranges.h"
#include "kvaluecolumn.h"
#include "helper.h"
using namespace KHE;
static const KCoding DefaultCoding = HexadecimalCoding;
static const KCoding NotDefaultCoding = DecimalCoding;
static const int DefaultBinaryGapWidth = 1;
KValueColumn::KValueColumn( KColumnsView *CV, KDataBuffer *B, KBufferLayout *L, KBufferRanges *R )
: KBufferColumn( CV, B, L, R ),
Coding( NotDefaultCoding ),
BinaryGapWidth( DefaultBinaryGapWidth )
{
setCoding( DefaultCoding );
}
KValueColumn::~KValueColumn()
{
}
bool KValueColumn::setCoding( KCoding C )
{
// no changes?
if( Coding == C )
return false;
Coding = C;
CodingWidth = KByteCodec::codingWidth( Coding );
DigitsFilledLimit = KByteCodec::digitsFilledLimit( Coding );
CodingFunction = KByteCodec::codingFunction( Coding );
AppendingFunction = KByteCodec::appendingFunction( Coding );
RemovingLastDigitFunction = KByteCodec::removingLastDigitFunction( Coding );
// recalculate depend sizes
recalcByteWidth();
if( PosX )
recalcX();
return true;
}
bool KValueColumn::setBinaryGapWidth( KPixelX BGW )
{
// no changes?
if( BinaryGapWidth == BGW )
return false;
BinaryGapWidth = BGW;
// recalculate depend sizes
recalcByteWidth();
if( PosX )
recalcX();
return true;
}
void KValueColumn::recalcByteWidth()
{
ByteWidth = CodingWidth * DigitWidth;
if( Coding == BinaryCoding )
{
BinaryHalfOffset = 4 * DigitWidth + BinaryGapWidth;
ByteWidth += BinaryGapWidth;
}
recalcVerticalGridX();
}
// perhaps sometimes there will be a grammar
void KValueColumn::paintEditedByte( QPainter *P, char Byte, const char *EditBuffer )
{
const QColorGroup &CG = View->colorGroup();
P->fillRect( 0,0,ByteWidth,LineHeight, QBrush(colorForByte(Byte),Qt::SolidPattern) );
drawCode( P, EditBuffer, CG.base() );
}
void KValueColumn::drawByte( QPainter *P, char Byte, const QColor &Color ) const
{
codingFunction()( CodedByte, Byte );
drawCode( P, CodedByte, Color );
}
void KValueColumn::drawCode( QPainter *P, const char *Code, const QColor &Color ) const
{
P->setPen( Color );
if( Coding == BinaryCoding )
{
// leave a gap in the middle
P->drawText( 0, DigitBaseLine, QString::fromLocal8Bit(Code,4) );
P->drawText( BinaryHalfOffset, DigitBaseLine, QString::fromLocal8Bit(&Code[4],4) );
}
else
P->drawText( 0, DigitBaseLine, QString::fromLocal8Bit(Code) );
}
|