تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
كلاس Conversions من برمجتي لتحويلات الأنظمة العددية (كود + شرح + مثال)
#1
السلام عليكم و رحمة الله و بركاته
اليوم أقدم لكم Class من برمجتي 100% لتحويلات الأنظمة العددية،
فالنبدأ بالشرح مباشرتاً:

الكلاس به 15 دالة منهم دالتين أساسيتين و البقية تعتمد على تلك الدالتين

قبل البدء أبحث في موقع You Tube عن فيديو بعنوان
Number System - Base System - 1 of 2
لمعرفة طريقة التحويل على الورق التي سوف نحولها إلى كود برمجي

لم أضع الرابط مباشرتاً لأنه يظهر في هيئة *******


الدالة الأولى:BaseToDecimal
الكود:
PHP كود :
''' <summary>
    ''' 
Converts (numberfrom (currentBaseto Base 10
    
''' </summary>
    ''' 
<param name="number">The number that you want to convert it Base</param>
    
''' <param name="currentBase">The current Base for (number)</param>
    ''' 
<returns></returns>
    
''' <remarks></remarks>
    Public Function BaseToDecimal(ByVal number As String, ByVal currentBase As UShort) As ULong
        If currentBase < 2 Then Return 0 : Exit Function
        Try
            Dim _OS As Integer() = New Integer() {}
            For I As Integer = 0 To number.Length - 1
                ReDim Preserve _OS(I)
                _OS(I) = (currentBase ^ I)
            Next
            Dim OverAllRes As ULong
            OverAllRes = 0
            For X As Integer = 0 To number.Length - 1
                Dim CharConv As String
                CharConv = number
                If CharConv.Substring(0, 1) = "-" Then CharConv = Strings.Right(CharConv, CharConv.Length - 1)
                CharConv = StrReverse(CharConv)
                CharConv = CharConv.Substring(X, 1)
                If currentBase > 9 Then
                    Select Case CharConv.ToUpper
                        Case "A"
                            CharConv = "10"
                        Case "B"
                            CharConv = "11"
                        Case "C"
                            CharConv = "12"
                        Case "D"
                            CharConv = "13"
                        Case "E"
                            CharConv = "14"
                        Case "F"
                            CharConv = "15"
                        Case "G"
                            CharConv = "16"
                        Case "H"
                            CharConv = "17"
                        Case "I"
                            CharConv = "18"
                        Case "J"
                            CharConv = "19"
                        Case "K"
                            CharConv = "20"
                        Case "L"
                            CharConv = "21"
                        Case "M"
                            CharConv = "22"
                        Case "N"
                            CharConv = "23"
                        Case "O"
                            CharConv = "24"
                        Case "P"
                            CharConv = "25"
                        Case "Q"
                            CharConv = "26"
                        Case "R"
                            CharConv = "27"
                        Case "S"
                            CharConv = "28"
                        Case "T"
                            CharConv = "29"
                        Case "U"
                            CharConv = "30"
                        Case "V"
                            CharConv = "31"
                        Case "W"
                            CharConv = "32"
                        Case "X"
                            CharConv = "33"
                        Case "Y"
                            CharConv = "34"
                        Case "Z"
                            CharConv = "35"
                    End Select
                End If
                CharConv = CInt(CInt(CharConv) * _OS(X))
                OverAllRes += CDec(CharConv)
            Next
            BaseToDecimal = Math.Abs(OverAllRes)
            Return BaseToDecimal
        Catch
            Return 0 : Exit Function
        End Try
    End Function
    '
Programmed by Aly El-Haddad 
طبعاً أنت تقول الآن في ذهنك "ألم يقل شرح :confused: " فأقول لك لو أنتظرت قليلاً لما قلت ذلك Rolleyes
طبعاً كما نعلم أن القواعد العددية لا يمكن أن تقل عن 2 و ذلك هو عمل السطر الأول
ملاحظة: عند حدوث أي خطأ في أي دالة الدالة تعود الدالة بـ0 لذلك تلك الدالة و بقية الدوال موضوعة بين Try و Catch و End Try
ثم بعد ذلك ننشئ مصفوفة رقمية لتحتوي على قيم الأسس
PHP كود :
Dim _OS As Integer() = New Integer() {} 
ثم نعبئها بالقيم عن طريق الكود التالي
PHP كود :
For As Integer 0 To number.Length 1
                ReDim Preserve _OS
(I)
                
_OS(I) = (currentBase I)
            
Next 
ثم نضع الحلقة التكرارية For و لا أعتقد أنها تحتاج إلى شرح لكن سأشرحها للمبتدئين
الحلقة التكرارية For هي لتكرار أمر معين عدة مرات و صيغتها كالتالي:
PHP كود :
For [Variable] As [NumericDataType] = [StartFromTo [FinishAtStep 1
'Your code
Next 

و الآن إلى ما بداخل الحلقة التكرارية For
طبعاً كما رأينا في شرح الفيديو فالأسس يبدأ وضعها من اليمين لليسار لذلك أستخدمت الدالة StrReverse ثم بعد ذلك يتم أستبدال كل حرف بالرقم الذي يواجهه ليتم ضربه في الأس و تستخدم الدالة Math.Abs للعودة بالقيمة الموجبة لرقم


الدالة الثانية: DecimalToBase
الكود:
PHP كود :
''' <summary>
    ''' 
Converts (numberfrom Base 10 to (targetBase)
    
''' </summary>
    ''' 
<param name="number">The number that you want to convert it Base</param>
    
''' <param name="targetBase">The Base that you want to convert to</param>
    ''' 
<returns></returns>
    
''' <remarks></remarks>
    Public Function DecimalToBase(ByVal number As ULong, ByVal targetBase As UShort) As String
        If targetBase < 2 Then Return 0 : Exit Function
        Try
            Dim VN As ULong
            VN = Math.Abs(number)
            Dim B As UShort = targetBase
            Dim R As Decimal
            Dim SOP As String
            Dim OverAll As String = String.Empty
            Do Until VN < 1
                R = VN / B
                R = Decimal.Subtract(R, Math.Truncate(R))
                R = CULng(R * B)
                If B > 9 Then
                    Select Case R
                        Case 10
                            SOP = "A"
                        Case 11
                            SOP = "B"
                        Case 12
                            SOP = "C"
                        Case 13
                            SOP = "D"
                        Case 14
                            SOP = "E"
                        Case 15
                            SOP = "F"
                        Case 16
                            SOP = "G"
                        Case 17
                            SOP = "H"
                        Case 18
                            SOP = "I"
                        Case 19
                            SOP = "J"
                        Case 20
                            SOP = "K"
                        Case 21
                            SOP = "L"
                        Case 22
                            SOP = "M"
                        Case 23
                            SOP = "N"
                        Case 24
                            SOP = "O"
                        Case 25
                            SOP = "P"
                        Case 26
                            SOP = "Q"
                        Case 27
                            SOP = "SOP"
                        Case 28
                            SOP = "S"
                        Case 29
                            SOP = "T"
                        Case 30
                            SOP = "U"
                        Case 31
                            SOP = "V"
                        Case 32
                            SOP = "W"
                        Case 33
                            SOP = "X"
                        Case 34
                            SOP = "Y"
                        Case 35
                            SOP = "Z"
                        Case Else
                            SOP = R
                    End Select
                Else
                    SOP = R
                End If
                VN = Math.Truncate(VN / B)
                OverAll &= SOP
            Loop
            OverAll = StrReverse(OverAll)
            DecimalToBase = OverAll
            Return DecimalToBase
            OverAll = String.Empty
            VN = Nothing
        Catch
            Return 0 : Exit Function
        End Try
    End Function
    '
Programmed by Aly El-Haddad 
أول سطرين كما هو الحال في الدالة السابقة
بعد ذلك نضع متغير تحمل القيمة الموجبة للرقم المدخل ثم متغير يحمل قيمة القاعدة ثم متغير لجلب باقي القسمة ثم متغير لتحويل الأرقام الأكبر من 10 إلى الحروف التي تمثلها ثم متغير للنتيجة النهائية ثم أستخدام الحلقة التكرارية Do Until و أعتقد أنها لا تحتاج إلى شرح لأن أسمها يوضح شرحها
يستخدم الكود التالي لجلب باقي القسمة
PHP كود :
VN B
                R 
Decimal.Subtract(RMath.Truncate(R))
                
CULng(B
ثم يتم تحويل الأرقام إلى الحروف التي تمثلها
ثم تم أستخدام الدالة Math.Truncate لجلب الرقم بدون كسور ثم إضافة الحرف\الرقم إلى متغير النتيجة النهائية و كما لاحظت في الفيديو السابق أنه يأخذ الأرقام من الأسفل إلى الأعلى لذلك تم أستخدام الدالة StrReverse


الدالة الثالثة: BaseToBase
الكود:
PHP كود :
''' <summary>
    ''' 
Converts (numberfrom (currentBaseto (targetBase)
    
''' </summary>
    ''' 
<param name="number">The number that you want to convert it Base</param>
    
''' <param name="currentBase">The current Base for (number)</param>
    ''' 
<param name="targetBase">The Base that you want to convert to</param>
    
''' <returns></returns>
    ''' 
<remarks></remarks>
    Public Function 
BaseToBase(ByVal number As StringByVal currentBase As UShortByVal targetBase As UShort) As String
        
If currentBase 2 Then Return : Exit Function
        If 
targetBase 2 Then Return : Exit Function
        
number BaseToDecimal(numbercurrentBase)
        
number DecimalToBase(numbertargetBase)
        Return 
number
    End 
Function
    
'Programmed by Aly El-Haddad 



أول سطرين كما هو الحال في الدالتين السابقتين
ثم يحول الرقم من النظام الحالي إلى النظام العشري و من ثم إلى النظام المطلوب التحويل إليه

الدالة الرابعة، ......، الدالة الخامسة عشر:

ليس بهم أفكار جديدة فكلها معتمدة بشكلٍ كلي على أول ثلاث دوال

أما بخصوص الكود المكتوب قبل كل دالة
PHP كود :
''' <summary>
    ''' 
Converts (numberfrom (currentBaseto (targetBase)
    
''' </summary>
    ''' 
<param name="number">The number that you want to convert it Base</param>
    
''' <param name="currentBase">The current Base for (number)</param>
    ''' 
<param name="targetBase">The Base that you want to convert to</param>
    
''' <returns></returns>
    ''' 
<remarks></remarks
فهو لوضع شرح للدالة عند كتابتها في محرر كواد الـVB.Net و يكتب بين summary شرح الدالة عموماً و بين param name="name" يتم كتابة وصف البراميتر أما بخصوص returns و remarks فلا أعلم
[FONT=&amp]

[/FONT]
[FONT=&amp]يوجد بالمرفقات الكلاس كاملاً(الـ15 دالة) و مثال عن أستخدامهم[/FONT]
[FONT=&amp]

[/FONT][FONT=&amp]و في النهاية أتمنى من الله أن أكود قد وفقت في شرحي[/FONT][FONT=&amp]

و لا أنتظر منكم سوى الدعوة الصالحة

و السلام عليكم و رحمة الله و بركاته[/FONT]
Smile


الملفات المرفقة
.rar   Conversions.rar (الحجم : 1.65 ك ب / التحميلات : 57)
.rar   Conversions Test.rar (الحجم : 219.59 ك ب / التحميلات : 59)
الرد }}}
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  مثال للتعامل مع الجداول المرتبطة - عن طريق الكلاسات ابو ليلى 25 15,192 04-10-20, 06:16 PM
آخر رد: محمد بن عطية
Rainbow [VB.NET] كلاس ResizeControls وطريقة جديد ومميزة لتكبير وتصغير ادوات الفورم تلقائيا الماجيك مسعد 8 8,731 01-10-18, 03:03 AM
آخر رد: LEO
  مثال القراءة والكتابه على ملف تيكست Txt على الانترنت + مثال + شرح m.sami.ak 11 8,398 02-06-18, 09:46 PM
آخر رد: YousefOkasha
  [درس فيديو] مثال بسيط لبرنامج إجازات فقط لأغراض الشرح (الدرس الأول) عبدالله الدوسري 7 11,538 28-04-18, 06:55 PM
آخر رد: moniam
  موضوع الاستاذ رامي مثال \ لطريقة تفعيل برنامجك عند العميل وتغيير كلمة مرور اRamilove سعود 8 7,693 06-10-17, 01:43 AM
آخر رد: حمادة دراز
  صمم الكلاس الخاص بك - كلاس للتعامل مع SQL SERVER ابو ليلى 11 8,708 03-09-16, 07:43 PM
آخر رد: tryold
  [درس فيديو] تشغيل اوامر Run من البرنامج & مثال غلق الويندوز بعد وقت محدد باستخدام VB.net أحمد النجار 1 3,854 23-12-15, 04:26 AM
آخر رد: الماجيك مسعد
  [مقال] شرح الدوال العامة في كلاس ( Process ) Dev Saeed 4 5,119 06-04-15, 06:54 PM
آخر رد: es5s930
  ابسط مثال لتشغيل ملفات mp3 مستضافة على موقع سعود 4 4,129 01-04-13, 04:04 AM
آخر رد: سامى ابوسريع
  مثال تشغيل ملف صوتى او فيديو RainBow 0 2,112 14-03-13, 08:37 PM
آخر رد: RainBow

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم