Solved

VBA - Background image positioning

Posted on 2006-07-06
15
656 Views
Last Modified: 2010-08-05
Hello

I want to be able to call an image from my VBA script and have it display on the page. I have some code but I do not know if I am doing it right?

Dim backgrd As String
   
    backgrd = Application_Paths.ScreenBckPth + "\Logon.bmp"

    'Call CreateDesktopShortcut("frmFlash")
   
    Me.imgBack.Picture = backgrd

In order to use the backslash to find the image does it need to be in the same folder? How would I located a file that is in the same file. Within a folder I have my database and also a folder named PNG. Within that folder is a background called "background.png". Does anybody know how to navigate this??
0
Comment
Question by:andyb7901
  • 7
  • 6
  • 2
15 Comments
 
LVL 35

Expert Comment

by:Raynard7
ID: 17049777
The folder needs to be in th epath of backgrnd - as long as you can specify the folder and the file and put it into backgrd then it will work.

You can hard code it ie - C:\temp\background.png or you can use a relative location
0
 
LVL 65

Expert Comment

by:rockiroads
ID: 17049793
If u want the image to be in the same folder as your mdb

u can use this instead


CurrentProject.Path

to get filename its then

CurrentProject.Path & "\Logon.bmp"


0
 

Author Comment

by:andyb7901
ID: 17049960
Whenever I hard code it I get an error on this line;

Me.imgBack.Picture = backgrd

How would I call the background image to the screen??
0
Use Case: Protecting a Hybrid Cloud Infrastructure

Microsoft Azure is rapidly becoming the norm in dynamic IT environments. This document describes the challenges that organizations face when protecting data in a hybrid cloud IT environment and presents a use case to demonstrate how Acronis Backup protects all data.

 
LVL 35

Expert Comment

by:Raynard7
ID: 17050005
Try me.Picture instead of Me.imgBack.Picture
0
 

Author Comment

by:andyb7901
ID: 17050109
that has solved that error, but it tells me object requiremed when I try to find my image through the path.

backgrd = Application_Paths.ScreenBckPth + "C:\Documents and Settings\Andy\Desktop\PraktisIT\PNG\Blank_form.png"

Do you think this is the correect way to do it?
0
 
LVL 35

Expert Comment

by:Raynard7
ID: 17050169
This is not the correct way;

You can either do

backgrd = "C:\Documents and Settings\Andy\Desktop\PraktisIT\PNG\Blank_form.png"

or

backgrd = Application.CurrentProject.Path & "\Blank_Form.png"

Depending if you want to set it relative to the location to the db or if the image will always be in the one spot
0
 

Author Comment

by:andyb7901
ID: 17050272
I think it would be sensible to use the bottom piece of code. In case the images and DB are moved. However, would it be possible for me to code it as ..\..\ to come out of the folder and into a new one. Or currently I have a db and a folder named PNG's in the same folder. What I would need is to go into the PNG folder and find an address. Would that be as simple as /PNG/filename.png.
0
 
LVL 35

Expert Comment

by:Raynard7
ID: 17050292
It would be as simple addressing \PNG\Filename.png - if the PNG folder is always in the db folder
0
 

Author Comment

by:andyb7901
ID: 17050440
yeah they are. What would be allthe code for the image then?

Dim backgrd As String
   
backgrd = Application_Paths.ScreenBckPth + "\PNG\hEADED PAPER\MainLogoncopy_newlogo"
   
Me.imgBack.Picture = backgrd

Would it be as simple as this?
0
 
LVL 35

Expert Comment

by:Raynard7
ID: 17050475
Yes it would be - i would note , it is best if you use & and not + when joining text fields
0
 

Author Comment

by:andyb7901
ID: 17050578
I have done the following but I keep getting the error object required(***). Im pretty sure the path is correct. I placed an image on the page using the irght click and properties command, and then browsing the file. I then copied the files path, and inserted it into my path in my code. So I think it is right?? Any ideas?

Dim backgrd As String

    'on load maxmise this form
    DoCmd.Maximize
   
    ****backgrd = Application_Paths.ScreenBckPth & "\PNG\hEADED PAPER\MainLogon copy_new Logo.png"
   
    Me.Picture = backgrd

    Me.admin.Visible = False
    Me.continue.Visible = False
   
    Me.Picture = backgrd
0
 
LVL 35

Accepted Solution

by:
Raynard7 earned 500 total points
ID: 17050620
This is because you should be using

backgrd =  Application.CurrentProject.Path  & "\PNG\hEADED PAPER\MainLogon copy_new Logo.png"
0
 

Author Comment

by:andyb7901
ID: 17050691
Ah that seems to work now, Thanks!! Do you know why the image is displaying dead centre though. Can the window being opened only be the size of the image? Itsd just that I have spaces in the background image where things like buttons and text boxes need to go?
0
 
LVL 65

Expert Comment

by:rockiroads
ID: 17051789
andyb7901, I went away to a meeting so I didnt get a chance to help you further on this
But Raynard7 sorted u out
But just wondering, did u not see my post where I mentioned using CurrentProject.Path? though I used logon.bmp as per your example code
0
 

Author Comment

by:andyb7901
ID: 17051894
Im sorry, I did not see your answer. However, Raynard did provide me with a great deal of help, and pointed out other areas to.
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Dinamic report to Crosstab query 9 33
rECORD SET NOT UPDATEABLE 21 59
Access Web App or PowerApp 29 41
Treeview control in 64 bit Office. 2 23
When you are entering numbers in a speadsheet, and don't remember what 6×7 is, you just type “=6*7" instead. It works in every cell! This is not so in Access. To enter the elusive 42 in a text box, you have to find a calculator, and then copy the re…
Phishing attempts can come in all forms, shapes and sizes. No matter how familiar you think you are with them, always remember to take extra precaution when opening an email with attachments or links.
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…

829 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