Преобразование единиц измерения - структура класса в VB.net - PullRequest
0 голосов
/ 14 сентября 2011

Я работаю над модулем преобразования единиц.Я нашел несколько хороших идей здесь, а также на CodeProject.Мой код очень похож на этот код C # на http://www.codeproject.com/KB/cs/Unit_Conversion_Sample.aspx Из следующего вы, вероятно, поймете, что я довольно новичок в программировании :)

Я создал базовый класс Units, который янаследовать для создания каждого типа блока.

Public Class Units
Private _unitvalue As Double
Private _unittype As [Enum]

Public Sub New(UnitValue As Double, UnitType As [Enum])
    _unitvalue = UnitValue
    _unittype = UnitType
End Sub

Public Property UnitValue() As Double
    Get
        Return _unitvalue
    End Get
    Set(value As Double)
        _unitvalue = value
    End Set
End Property

Public Property UnitType() As [Enum]
    Get
        Return _unittype
    End Get
    Set(value As [Enum])
        _unittype = value
    End Set
End Property

Public Overrides Function ToString() As String
    Return String.Format("{0} {1}", UnitValue.ToString(), UnitType.ToString())
End Function

End Class

Затем я наследую этот класс, чтобы начать создавать модули с включенной функцией преобразования единиц.

Public Class WeightUnit
Inherits Units
Enum WeightSym
    'Pounds
    Lbs
    'Kilograms
    Kg
End Enum
Sub New(UnitValue As Double, UnitType As WeightSym)
    MyBase.New(UnitValue, UnitType)
End Sub
Public Function Convert(toUnit As WeightSym) As WeightUnit
    'Base Weight Unit is Lbs

    Dim fromUnit As WeightSym
    fromUnit = UnitType

    Dim Lbs As Double = 0
    Select Case fromUnit
        'Standard
        Case WeightSym.Lbs
            Lbs = UnitValue
        Case WeightSym.Kg
            Lbs = UnitValue * 2.2046226
    End Select

    Dim toVal As Double = 0
    'to unit based on Lbs
    Select Case toUnit
        'Standard
        Case WeightSym.Lbs
            toVal = Lbs
        Case WeightSym.Kg
            toVal = Lbs * 0.4535924
    End Select
    Return New WeightUnit(toVal, toUnit)
End Function
End Class

Мне нужно создать несколько различных типов единиц, таких как длина, давление и т. Д.Это работает хорошо, за исключением одного вопроса.Я хотел бы иметь возможность изменить UnitType и автоматически обновить UnitValue.Так что если объект Unit имеет значение 1 и тип Inch, а тип изменяется на Cm, значение будет обновлено до 2,54.

Примерно так ... Я видел примерыиз этого, но разница здесь в том, что я не могу указать функцию Covert в моем базовом классе, потому что она меняется с каждым новым UnitClass, который я создаю.

Public Property UnitType() As [Enum]
Get
    Return _unittype
End Get
Set(value As [Enum])
    _unittype = value
    _unitvalue = Convert(value).UnitValue
End Set
End Property

Я попытался сделать свойство UnitType Overridable и создать новое свойство переопределения для UnitType в каждом созданном мной UnitClass, но мне не удалось заставить его работать.

Любые предложения очень ценятся.Большое спасибо!

1 Ответ

0 голосов
/ 14 сентября 2011

Я отвечаю на свои вопросы, когда нашел способ обновить UnitValue и UnitType, слегка переставив код. Я разбил функцию преобразования на две части. Сначала я создал функцию WeightConversion, которая просто возвращает Double.

Public Function WeightConversion(Quantity As Double,fromUnit As WeightSym,_
toUnit As WeightSym) As Double
'Base Weight Unit is Lbs

Dim fromUnit As WeightSym
fromUnit = UnitType

Dim Lbs As Double = 0
Select Case fromUnit
    'Standard
    Case WeightSym.Lbs
        Lbs = Quantity
    Case WeightSym.Kg
        Lbs = Quantity * 2.2046226
End Select

Dim toVal As Double = 0
'to unit based on Lbs
Select Case toUnit
    'Standard
    Case WeightSym.Lbs
        toVal = Lbs
    Case WeightSym.Kg
        toVal = Lbs * 0.4535924
End Select
Return toVal
End Function

Затем я создал функцию, которая выглядит следующим образом ... В моей реализации я создал переопределяемую функцию в своем базовом классе и переопределил ее следующим образом.

Public Function ToUnit(toType As LengthSym) As Boolean
    'First Set UnitValue 
    Me.UnitValue = LengthConversion(Me.UnitValue, Me.UnitType, toType)
    'Then Set the UnitType to the newly choosen unit
    Me.UnitType = toType
    Return True
End Function

Это дало мне эффект, который я искал ... Теперь преобразование в другой UnitType просто изменяет значения существующего объекта вместо создания нового объекта.

Мне все еще было бы интересно услышать другие идеи для преобразования единиц ...

...