تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
التحكم فى ضبط حواف الورقة فى طباعة الفورم
#1
السلام عليكم اساتذتنا 

هذا الكود يقوم بطباعة الفورم مباشرتا ولكن يوجد مشكلة بحواف الورقة 

اول الطباعة تكون بعد اول الورقة بحوالى 4 سنتى

اريد ان اتحكم فى الحواف لطباعة الورقة و شكرا


الكود


Imports System.Drawing.Printing

Public Class Form1

    Dim WithEvents mPrintDocument As New PrintDocument
    Dim mPrintBitMap As Bitmap


    Private Sub m_PrintDocument_PrintPage(ByVal sender As Object, ByVal e As System.Drawing.Printing.PrintPageEventArgs) Handles mPrintDocument.PrintPage

    

        ' Draw the image centered.
        Dim lWidth As Integer = e.MarginBounds.X + (e.MarginBounds.Width - mPrintBitMap.Width) \ 1.5
        Dim lHeight As Integer = e.MarginBounds.Y + (e.MarginBounds.Height - mPrintBitMap.Height) \ 1.5
        e.Graphics.DrawImage(mPrintBitMap, lWidth, lHeight)

        ' There's only one page.
        e.HasMorePages = False
    End Sub

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

      
        ' Copy the form's image into a bitmap.
        mPrintBitMap = New Bitmap(Me.Width, Me.Width)
        Dim lRect As System.Drawing.Rectangle
        lRect.Width = Me.Width
        lRect.Height = Me.Width
        Me.DrawToBitmap(mPrintBitMap, lRect)


        ' Make a PrintDocument and print.
        mPrintDocument = New PrintDocument
        mPrintDocument.Print()
    End Sub

  
End Class


يوجد مثال فى المرفقات


الملفات المرفقة
.rar   طباعة الفورم.rar (الحجم : 71.39 ك ب / التحميلات : 66)
الرد
تم الشكر بواسطة:
#2
شكرا لكم اخوتى على عدم الرد ولقد وفقنى الله فى البحث و لقد وجدة ضالتى و اعتقد افضل كود لطباعة الفورم 

الكود فى هذا الرابط http://arbtech.forumegypt.net/t28-topic

الكود منقول


Private Declare Function BitBlt Lib "gdi32.dll" Alias "BitBlt" (ByVal _
hdcDest As IntPtr, ByVal nXDest As Integer, ByVal nYDest As _
Integer, ByVal nWidth As Integer, ByVal nHeight As Integer, ByVal _
hdcSrc As IntPtr, ByVal nXSrc As Integer, ByVal nYSrc As Integer, _
ByVal dwRop As System.Int32) As Long
Dim memoryImage As Bitmap
Private Sub CaptureScreen()
Dim mygraphics As Graphics = Me.CreateGraphics()
Dim s As Size = Me.Size
memoryImage = New Bitmap(s.Width, s.Height, mygraphics)
Dim memoryGraphics As Graphics = Graphics.FromImage(memoryImage)
Dim dc1 As IntPtr = mygraphics.GetHdc
Dim dc2 As IntPtr = memoryGraphics.GetHdc
BitBlt(dc2, 0, 0, Me.ClientRectangle.Width, _
Me.ClientRectangle.Height, dc1, 0, 0, 13369376)
mygraphics.ReleaseHdc(dc1)
memoryGraphics.ReleaseHdc(dc2)
End Sub
Private Sub PrintDocument1_PrintPage(ByVal sender As System.Object, _
ByVal e As System.Drawing.Printing.PrintPageEventArgs) Handles _
PrintDocument1.PrintPage
e.Graphics.DrawImage(memoryImage, 0, 0)
End Sub
Private Sub PrintButton_Click(ByVal sender As System.Object, ByVal e As _
System.EventArgs) Handles PrintButton.Click
CaptureScreen()
PrintDocument1.Print()
End Sub
الرد
تم الشكر بواسطة: sendbad100
#3
اعتذر لك بس ما اعرف حلل للمشكلة
الرد
تم الشكر بواسطة:
#4
(14-03-17, 09:42 PM)supercool999 كتب : اعتذر لك بس ما اعرف حلل للمشكلة

لا عليك اخى لقد تم حل المشكلة و الكود فى الرد
الرد
تم الشكر بواسطة: أبووسم
#5
شكراً على الكود أخي الغالي ،،

و لكن الكود لا يطبع الصفحة كاملة ؟

يطبع جزء منها فقط
الرد
تم الشكر بواسطة:
#6
(16-03-17, 08:27 PM)أبووسم كتب : شكراً على الكود أخي الغالي ،،

و لكن الكود لا يطبع الصفحة كاملة ؟

يطبع جزء منها فقط

اخى اضبط size الفورم اجعل width 796 اما ال Height اجعله اى مقاس حسب طول الفورم
الرد
تم الشكر بواسطة: أبووسم
#7
شكراً اخي نبيل و الله يعطيك العافية
الرد
تم الشكر بواسطة:
#8
لأن الفورم مصمم بحيث ان أبعاده تتناسب مع ابعاد شاشة الكمبيوتر
عليك ان تستخدم مقياس رسم بحيث تضبط صورة الفورم لتتناسب مع ابعاد ورقة الطباعة
مثلا تاخذ صورة الفورم ثم تعيد رسمها بأبعاد أقل قليلا علي صورة فاضية بابعاد اخري اقل من ابعاد صورة الفورم
ثم ترسم تلك الصورة علي ورقة الطباعة

الخلاصة أنت تحتاج مقياس رسم مناسب و حينها ستكتشف أن كل الكود الخاص بك و الخاص باستخدام دوال API يمكن الاستغناء عنه
الرد
تم الشكر بواسطة:
#9
هذا هو الكود الخاص بك بعد التعديل عليه قليلا


PHP كود :
Imports System.Drawing.Printing

Public Class Form1

    Dim WithEvents mPrintDocument 
As New PrintDocument
    Dim mPrintBitMap 
As Bitmap Nothing

    Private Sub m_PrintDocument_PrintPage
(ByVal sender As ObjectByVal e As System.Drawing.Printing.PrintPageEventArgsHandles mPrintDocument.PrintPage

        Dim w 
As Integer e.MarginBounds.+ (e.MarginBounds.Width mPrintBitMap.Width) \ 1.5
        Dim h 
As Integer e.MarginBounds.+ (e.MarginBounds.Height mPrintBitMap.Height) \ 1.5
        Dim scale 
As Double 0.7
        e
.Graphics.DrawImageUnscaled(mPrintBitMapscalescale)

 
       ' There's only one page.
 
       e.HasMorePages False
    End Sub

    Private Sub Button1_Click
(ByVal sender As System.ObjectByVal e As System.EventArgsHandles Button1.Click
        mPrintBitMap 
= New Bitmap(CaptureFormImage)
 
       mPrintDocument = New PrintDocument
        mPrintDocument
.Print()
 
   End Sub

    Private 
Function CaptureFormImage() As Bitmap
        Dim formRect 
As Rectangle = New Rectangle(Me.Bounds.LocationMe.Bounds.Size)
 
       Dim pt As Point = New Point(Me.Location.XMe.Location.Y)
 
       Dim r As Rectangle TrnasformRect(ptformRect)
 
       Dim formBitmap As Bitmap = New Bitmap(r.Widthr.Height)
 
       Me.DrawToBitmap(formBitmapr)
 
       Return formBitmap
    End 
Function

 
   Public Function TrnasformRect(offset As PointoriginalRect As Rectangle) As Rectangle
        Return 
New Rectangle(originalRect.offset.XoriginalRect.offset.YoriginalRect.WidthoriginalRect.Height)
 
   End Function

End Class 
الرد
تم الشكر بواسطة: sendbad100
#10
(19-03-17, 06:36 AM)silverlight كتب : هذا هو الكود الخاص بك بعد التعديل عليه قليلا


PHP كود :
Imports System.Drawing.Printing

Public Class Form1

    Dim WithEvents mPrintDocument 
As New PrintDocument
    Dim mPrintBitMap 
As Bitmap Nothing

    Private Sub m_PrintDocument_PrintPage
(ByVal sender As ObjectByVal e As System.Drawing.Printing.PrintPageEventArgsHandles mPrintDocument.PrintPage

        Dim w 
As Integer e.MarginBounds.+ (e.MarginBounds.Width mPrintBitMap.Width) \ 1.5
        Dim h 
As Integer e.MarginBounds.+ (e.MarginBounds.Height mPrintBitMap.Height) \ 1.5
        Dim scale 
As Double 0.7
        e
.Graphics.DrawImageUnscaled(mPrintBitMapscalescale)

 
       ' There's only one page.
 
       e.HasMorePages False
    End Sub

    Private Sub Button1_Click
(ByVal sender As System.ObjectByVal e As System.EventArgsHandles Button1.Click
        mPrintBitMap 
= New Bitmap(CaptureFormImage)
 
       mPrintDocument = New PrintDocument
        mPrintDocument
.Print()
 
   End Sub

    Private 
Function CaptureFormImage() As Bitmap
        Dim formRect 
As Rectangle = New Rectangle(Me.Bounds.LocationMe.Bounds.Size)
 
       Dim pt As Point = New Point(Me.Location.XMe.Location.Y)
 
       Dim r As Rectangle TrnasformRect(ptformRect)
 
       Dim formBitmap As Bitmap = New Bitmap(r.Widthr.Height)
 
       Me.DrawToBitmap(formBitmapr)
 
       Return formBitmap
    End 
Function

 
   Public Function TrnasformRect(offset As PointoriginalRect As Rectangle) As Rectangle
        Return 
New Rectangle(originalRect.offset.XoriginalRect.offset.YoriginalRect.WidthoriginalRect.Height)
 
   End Function

End Class 

شكرا على مجهودك اخى لقد تم ما اريد و جزاكم الله خيرا
الرد
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  ممكن مساعدة طباعة دفاتر صكوك مصرفية الزوي 10 95 منذ 5 ساعة مضت
آخر رد: elgokr
  [VB.NET] إنهاء مهام الفورم larbihamri 4 64 منذ 6 ساعة مضت
آخر رد: elgokr
Music التحكم في أصوت الجهاز YousefOkasha 0 31 اليوم, 01:24 AM
آخر رد: YousefOkasha
  [كود] تكرار خلفية الفورم الصوتية m.reyati 6 75 19-07-18, 07:57 PM
آخر رد: anoname
  [VB.NET] سؤال بخصوص تصغير الفورم محمد اسماعيل 10 116 18-07-18, 05:57 PM
آخر رد: محمد اسماعيل
  الطباعة على نصف الورقة A5 عبد العزيز البسكري 10 160 14-07-18, 02:03 AM
آخر رد: عبد العزيز البسكري
  [VB.NET] طريقة طباعة نتيجة البحث في الداتاريبورت larbihamri 3 139 11-07-18, 05:56 PM
آخر رد: ghaner joseph
  طباعة ليبل من الفورم نور الهدى الهدى 8 145 05-07-18, 08:41 PM
آخر رد: نور الهدى الهدى
  مشكلة فى طباعة بون كاشير Osama Bayoumy 12 206 28-06-18, 06:58 AM
آخر رد: elgokr
Exclamation [VB.NET] كيف عمل هذا الفورم لعرض هذا النتائج به elgokr 10 1,975 23-06-18, 10:47 PM
آخر رد: YousefOkasha

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


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