Solved

AVI Files

Posted on 1998-09-11
6
365 Views
Last Modified: 2012-06-22
How can i play an AVI file in vb5, but i want the image to appear in my own location, without the MCI control to apperar. ie. My own control buttons,play,stop,pause
0
Comment
Question by:abidsml
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
6 Comments
 
LVL 12

Accepted Solution

by:
mark2150 earned 10 total points
ID: 1434392
Turn off all of the buttons on the MCI object. This will give you a "naked" picture frame. Add your objects on the form and set them to issue the appropriate MCI commands when clicked. This will give you full AVI functionality with your own "look & feel".

IMHO tho, this will get your software panned for a "non standard" UI. But, I can see there would be times when your own controls would be handy (or even NO controls).

0
 

Author Comment

by:abidsml
ID: 1434393
just how can i view the animation in my own picture box in this case?
0
 

Author Comment

by:abidsml
ID: 1434394
can u please sending a sample code on a form contain a picture box to view the file in it.
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 12

Expert Comment

by:mark2150
ID: 1434395
You can't put the picture in your *own* picture box, you still have to have the MCI control box for playback, but you can align it so it *looks* just like your picture box and it'll have no borders to mess things up.

I use ActiveMovie control and set ShowControls, ShowDisplay, ShowPositionControls, ShowSelectionControls, ShowTracker properties to False. Then when I need to "roll tape" I simply code:

Public movieover As Boolean
Public imready As Boolean
Public AtEnd As AMovieCtl.StateConstants
Public rs As AMovieCtl.ReadyStateConstants
.

' This fires the movie:
'
    Call showmovie("EXCEL.AVI")
.
Public Sub showmovie(moviename As String)
    Dim movie As String
    movie = ourdir & moviename
    ActiveMovie1.filename = movie
    Do While Not movieover
        DoEvents
    Loop
    Me.Refresh
    Me.SetFocus
End Sub

The above plays the movie and waits for it to complete before proceeding

Support routines include:

 Private Sub ActiveMovie1_StateChange(ByVal oldState As Long, ByVal newState As Long)
   If newState = amvStopped Then
     ActiveMovie1.Visible = False
     movieover = True
   End If
   '
End Sub

Private Sub ActiveMovie1_ReadyStateChange(ReadyState As AMovieCtl.ReadyStateConstants)
'
   If ReadyState = amvComplete Or ReadyState = amvInteractive Then
      ' It's ready to run.
    ActiveMovie1.Visible = True
     ActiveMovie1.Run
     movieover = False
   End If
'
End Sub
'
' Ensure movie is off at load time
'
Private Sub Form_Activate()
ActiveMovie1.Visible = False
ActiveMovie1.Stop
End Sub

0
 

Author Comment

by:abidsml
ID: 1434396
thanks, i will try this
0
 

Expert Comment

by:cameron2
ID: 1434397
This will make it so that you can view files within your form using command buttons

Step-by-Step Example
--------------------

1. Start a new project in Visual Basic. Add a module (.BAS) file, and make
   sure the MCI control is included in the project. Add a MCI control
   (MMControl1), a Command Button (Command1), and a Picture box (Picture1)
   to Form1. Set Form1's ScaleMode property to Pixels (3).

2. In the General declarations section of the .BAS file, add this code:

   Type RECT
      Left As Long
      Top As Long
      Right As Long
      Bottom As Long
   End Type

   Type MCI_OVLY_RECT_PARMS
      dwCallback As Long
      rc As RECT
   End Type

   Global Const MCI_OVLY_WHERE_SOURCE = &H20000
   Global Const MCI_OVLY_WHERE_DESTINATION = &H40000
   Global Const MCI_WHERE = &H843

   'Enter the following Declare statement:
   Declare Function mciSendCommand Lib "winmm.dll" _
      Alias "mciSendCommandA" ( _
         ByVal wDeviceID As Long, _
         ByVal uMessage As Long, _
         ByVal dwParam1 As Long,
         dwParam2 As Any) As Long

   ' Enter the following Declare statement:
   Declare Function mciGetErrorString Lib "winmm.dll" _
      Alias "mciGetErrorStringA" ( _
         ByVal dwError As Long, _
         ByVal lpstrBuffer As String, _
         ByVal uLength As Long) As Long

3. In the Command1_Click() method for the Command button on Form1, enter
   this code:

   Sub Command1_Click ()
      Const MB_OK = 0
      Const MB_ICONSTOP = 16

      Dim Retval&, Buffer$
      Dim dwParam2 As MCI_OVLY_RECT_PARMS

      MMControl1.Command = "Close"
      MMControl1.Filename = "WndSurf1.avi"  'Sample AVI file to
                                            'played.

      'Get the MCI control to display the video in Picture1:
      MMControl1.hWndDisplay = Picture1.hWnd

      MMControl1.Command = "Open"

      'Initialize the structure being passed with mciSendCommand, and
      'set it in case you want to use the Notify property:
      dwParam2.dwCallback = MMControl1.hWnd
      dwParam2.rc.Left = 0
      dwParam2.rc.Top = 0
      dwParam2.rc.Right = 0
      dwParam2.rc.Bottom = 0

      'Send the message:
      'Enter the following two lines as one, single line of code:
      Retval& = mciSendCommand(MMControl1.DeviceID, MCI_WHERE,
                MCI_OVLY_WHERE_SOURCE, dwParam2)

      If Retval& <> 0 Then  ' An error occurred.
         Buffer$ = Space$(100)
         'Get a description of the error:
         Retval& = mciGetErrorString(Retval&, Buffer$, Len(Buffer$))
         MsgBox Trim$(Buffer$), MB_OK + MB_ICONSTOP, "ERROR"
      Else
         'Resize the picture box:
         Picture1.Width = dwParam2.rc.right - dwParam2.rc.left
         Picture1.Height = dwParam2.rc.bottom - dwParam2.rc.top

         'Play the video:
         MMControl1.Wait = True ' Wait for the next command to complete
         MMControl1.Command = "play" 'Play the video clip
         MMControl1.Command = "close"
      End If
   End Sub

4. Test the program by pressing the F5 key to run it, and clicking the
   command button. The AVI file will play back in the picture box, which
   will have been resized to fit the video clip exactly.

Additional reference words: 3.00 4.00 MCI AVI vb4win vb432
KBCategory: kbprg kbcode kbhowto
KBSubcategory: APrgWindow


Make the mci buttons not visible by going to the properties and scroll down until you find visible change it to false





0

Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
Background What I'm presenting in this article is the result of 2 conditions in my work area: We have a SQL Server production environment but no development or test environment; andWe have an MS Access front end using tables in SQL Server but we a…
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question