Reputation: 107221
Recently I joined GitHub. I hosted some projects there.
I need to include some images in my README File. I don't know how to do that.
I searched about this, but all I got was some links which tell me to "host images on web and specify the image path in README.md file".
Is there any way to do this without hosting the images on any third-party web hosting services?
Upvotes: 3515
Views: 2737711
Reputation: 21
data:image/s3,"s3://crabby-images/bcf19/bcf1922aef2ebc581698b7d27e5584fce131ce35" alt="alt text"
This is it
Or
Try this markdown:
data:image/s3,"s3://crabby-images/3b894/3b894660493bcb34ce0f216b79d8bd0bf845b883" alt="alt text"
I think you can link directly to the raw version of an image if it's stored in your repository. i.e.
Upvotes: 1
Reputation:
Just add your image to the repository, and link to the filename, like so:
data:image/s3,"s3://crabby-images/86114/86114e3f4356b59600d0679a9bbb47909553c050" alt="screenshot"
Upvotes: 356
Reputation: 10134
In case you need to upload some pictures for documentation, a nice approach is to use git-lfs. Asuming that you have installed the git-lfs follow these steps:
Intialize git lfs for your each image type:
git lfs *.png
git lfs *.svg
git lfs *.gif
git lfs *.jpg
git lfs *.jpeg
Create a folder that will be used as image location eg. doc
. On GNU/Linux and Unix based systems this can be done via:
cd project_folder
mkdir doc
git add doc
Copy paste any images into doc folder. Afterwards add them via git add
command.
Commit and push.
The images are publicly available in the following url:
https://media.githubusercontent.com/media/^github_username^/^repo^/^branch^/^image_location in the repo^
Where:
^github_username^
is the username in github (you can find it in the profile page)^repo_name^
is the repository name^branch^
is the repository branch where the image is uploaded^image_location in the repo^
is the location including the folder that the image is stored.Also you can upload the image first then visit the location in your projects github page and navigate through until you find the image then press the download
button and then copy-paste the url from the browser's address bar.
Look this from my project as reference.
Then you can use the url to include them using the markdown syntax mentioned above:
data:image/s3,"s3://crabby-images/23006/23006a90a5d83ccb7a904859f90ed47f7acfcd5f" alt="some alternate text that describes the image"
Eg: Let us suppose we use this photo Then you can use the markdown syntax:
data:image/s3,"s3://crabby-images/bf586/bf5868f4e6fa475fca82ab80549e47134699e7a2" alt="In what order to compile the files"
Upvotes: 6
Reputation: 24
for me I resolved this problem in 2 steps:
I have uploaded the photo in the repository I get his url (which I will use in step 2)
data:image/s3,"s3://crabby-images/b76ed/b76edbf61f85c003d99c65f7f72b3a9847e52a4d" alt="Screenshot (624)"
Hope it works :)
Upvotes: 0
Reputation: 24712
You can also insert animated SVG images in the markdown file like any other format.
It can be a good alternative to GIF images.
data:image/s3,"s3://crabby-images/0e817/0e817168282f4065d3c8643f511d4d0d44236064" alt="image description"
OR
<img src="relative/path/in/repository/to/image.svg" width="128"/>
Example (assuming the image is in assets
directory in the repository):
data:image/s3,"s3://crabby-images/278f9/278f96e3b20cd45ea656c40d1fc13d989ebf9484" alt="My animated logo"
Result:
To use different images based on GitHub dark/light theme see this post.
Upvotes: 106
Reputation: 1912
Use markdown syntax:
data:image/s3,"s3://crabby-images/aef78/aef780619b96da885b32e015eaa7bc46c62dd71e" alt="ALT TEXT"
or
data:image/s3,"s3://crabby-images/8b32d/8b32df028ec124ef0bc92dc653b45912d573d289" alt="ALT TEXT"
You can also use online tools to generate the markdown for your content. Some of the tools which I used:
Upvotes: 5
Reputation: 1340
1- Using Relative URLs:
If image is stored in the same repository as the README.md file then use this.
data:image/s3,"s3://crabby-images/4477e/4477e0f3cec5ec9e8ee37bb0776b157ee29accb1" alt="Alt text"
2- Using Absolute URLs:
use this when the image is hosted on a public server.
data:image/s3,"s3://crabby-images/de2ff/de2ff4fe6990b26f373d5731acc5c15162653bfc" alt="Alt text"
3- Method no 3:
4- Using GitHub's Raw Content URL:
data:image/s3,"s3://crabby-images/fe180/fe180b51cfb7db81849e5bc1dd57578122784861" alt="Alt text"
5- Using HTML Tag
<img src="https://example.com/path/to/image.png" alt="Alt text">
7- Sheild IO Badges:
data:image/s3,"s3://crabby-images/69ec7/69ec75766a749cd859a4ba3802c4fabe336dd4cb" alt="Build Status"
Hope it helps.
Upvotes: 2
Reputation: 717
To upload images with size managing option:
<img src="a.jpg" alt="J" width="200"/>
Upvotes: 4
Reputation: 13330
You can also use relative paths like
data:image/s3,"s3://crabby-images/a2ad1/a2ad10d8ceb5aa5e9b8f286f3537514a9594c66c" alt="Alt text"
Also try the following with the desired .fileExtention
:
data:image/s3,"s3://crabby-images/2c173/2c173d53f247e2dce424651adb42f09ede174aa8" alt="plot"
Upvotes: 983
Reputation: 117
This one works for me!!!.
data:image/s3,"s3://crabby-images/bcf19/bcf1922aef2ebc581698b7d27e5584fce131ce35" alt="alt text"
alt text is the alternative text you wanna display incase the image URL doest not exist.
user_name
is your GitHub username.
reponame
is your GitHub repo name.
Upvotes: 2
Reputation: 51
In the latest Github i have tried all the above ways and failed to show images on my readme page. The best that i found if it's a public repo is to use githubpages for the master or main branch and then reference the link in the readme file.
Steps:
now your repo should be hosted on (https://*username*.github.io/*reponame*/)
now you can simply add your image by
data:image/s3,"s3://crabby-images/8ab05/8ab0529d94fa2b5d9ad8245f4a7c1a5afe19f637" alt="Preview Image"
Upvotes: 1
Reputation: 371
No need to write any code. readme file on GitHub now supports drag
and drop
README.md
fileUpvotes: 10
Reputation: 133
Although GitHub markdown can also add pictures I will suggest you use an HTML IMG tag
GitHub Markdown
data:image/s3,"s3://crabby-images/0b0f3/0b0f3fbbe556e0a04bcce71be8126c07b6b9ae9a" alt="me"
HTML TAG
<img src='https://github.com/samadpls'/>
Upvotes: 9
Reputation: 55
You can as well drop the image at the appropriate part in the Read Me file.
Upvotes: 1
Reputation: 4320
If you dont't want to "mess up" your branch's content with these images and it's not a problem for you that the link is absolute, then I recommend to use a separate orphan branch to store these images. In this case, images will be integrated with the repo while not included in the main content. In addition, you can use LFS for larger files (all the leading git hosts support LFS).
You can easily create an orphan branch in the command line:
git checkout --orphan images
git reset --hard
cp /path/to/your/image.jpg ./image.jpg
git add --all
git commit -m "Add some images"
git checkout master
git log -n 3 --all --graph
If everyhing is OK, push the new branch:
git push -u origin images
Then use the raw github URL of the image.
Upvotes: 0
Reputation: 1583
Most of the answers here directly or indirectly involve uploading the image somewhere else & then providing a link to it.
It can be done very simply by just copying any image and pasting it while editing Readme.md
Ctrl + C
or may copy the screenshot image to your clipboard using the snipping toolCtrl + V
while editing Readme.mdGuithub will automatically upload it to user-images.githubusercontent.com and a link to it will be inserted there
Upvotes: 122
Reputation: 570
You Can use
data:image/s3,"s3://crabby-images/ae3df/ae3df321b6c8f64305011bf17eccd7c24a62f556" alt="A test image"
Where ![A test image]
is your alt text and (image.png)
is the link to your image.
You can have the image on a cloud service or other online image hosting platforms Or you can provide the image link from the repository if it is in the repo
You can also make a specific folder inside your repository dedicated to your readme images
Upvotes: 20
Reputation: 1575
You can now drag and drop the images while editing the readme file.
Github will create a link for you which will be in the format of:
https://user-images.githubusercontent.com/******/********.file_format
Alternatively, at the bottom of the file, it says "Attach files by dragging & dropping, selecting or pasting them". If you click on that one, it will give you an option to upload a file directly or you can just paste it!
Upvotes: 20
Reputation: 3810
In new Github UI, this works for me -
Example - Commit your image.png in a folder (myFolder) and add the following line in your README.md:
data:image/s3,"s3://crabby-images/0c958/0c9588ce679f76435023e1314a3463a1ca24c08c" alt="Optional Text"
Upvotes: 12
Reputation: 535
Step by step process, First create a folder ( name your folder ) and add the image/images that you want to upload in Readme.md file. ( you can also add the image/images in any existing folder of your project. ) Now,Click on edit icon of Readme.md file,then
data:image/s3,"s3://crabby-images/e22bc/e22bcefee6ce51815db4b9d87a6f3386746881f4" alt="" // refrence_image is the name of image in my case.
After adding image, you can see preview of changes in the, "Preview Changes" tab.you will find your image here. for example like this, In my case,
data:image/s3,"s3://crabby-images/e1e38/e1e380f4c7b5c3c35b5615d82ff3b64aeb1f4da3" alt=""
app folder -> src folder -> main folder -> res folder -> drawable folder -> and inside drawable folder refrence_image.png file is located. For adding multiple images, you can do it like this,
data:image/s3,"s3://crabby-images/c872b/c872bd71c2e5b45741c555be1a6320ddd539ace6" alt=""
data:image/s3,"s3://crabby-images/8b80c/8b80cc3c50ce33f1dee1ea65db55d3ef178eb779" alt=""
data:image/s3,"s3://crabby-images/cda21/cda21798a643cd611d45ad18e878f40695b5013b" alt=""
Note 1 - Make sure your image file name does not contain any spaces. If it contain spaces then you need to add %20 for each space between the file name. It's better to remove the spaces.
Note 2 - you can even resize the image using HTML tags, or there are other ways. you can google it for more. if you need it.
After this, write your commit changes message, and then commit your Changes.
There are many other hacks of doing it like, create a issue and etc and etc. By far this is the best method that I have came across.
Upvotes: 17
Reputation: 17218
Many of the posted solutions are incomplete or not to my taste.
My preferred solution, inspired by this gist, is to use an assets branch with permalinks to specific revisions.
git checkout --orphan assets
git reset --hard
cp /path/to/cat.png .
git add .
git commit -m 'Added cat picture'
git push -u origin assets
git rev-parse HEAD # Print the SHA, which is optional, you'll see below.
Construct a "permalink" to this revision of the image, and wrap it in Markdown.
Looking up the commit SHA by hand is inconvenient, however, so as a shortcut press Y to a permalink to a file in a specific commit as this help.github page says.
To always show the latest image on the assets branch, use the blob URL:
https://github.com/github/{repository}/blob/assets/cat.png
(From the same GitHub help page File views show the latest version on a branch)
Upvotes: 83
Reputation: 940
If you want to show an image hosted at any website (say url is "http:// abc.def.com/folder/image.jpg
") then in your README.md
file use the below syntax:
data:image/s3,"s3://crabby-images/699ef/699efe92cfec8072f0f27d163ef02123edc31c19" alt="alt text"
For images hosted in your own github repository you can use relative path in addition to the above url format
data:image/s3,"s3://crabby-images/7285f/7285f4b2944b28421a2eff240f8f420ae6ec9c26" alt="alt text"
README.md
file (special case of relative path url), then you can use:data:image/s3,"s3://crabby-images/eb087/eb0878a3a58be9c94621b76cf32300fae176d70f" alt="alt text"
Note the angular brackets "<" and ">" enclosing the url. Sometimes these are required for the url to work.
Upvotes: 1
Reputation: 42775
Try this markdown:
data:image/s3,"s3://crabby-images/3b894/3b894660493bcb34ce0f216b79d8bd0bf845b883" alt="alt text"
I think you can link directly to the raw version of an image if it's stored in your repository. i.e.
data:image/s3,"s3://crabby-images/bcf19/bcf1922aef2ebc581698b7d27e5584fce131ce35" alt="alt text"
Upvotes: 3547
Reputation: 2804
This Answer can also be found at: https://github.com/YourUserAccount/YourProject/blob/master/DirectoryPath/ReadMe.md
?sanitize=true&raw=true
<img />
tagraw.githubusercontent.com/
YourUserAccount/
YourProject/
YourBranch/
DirectoryPath/
example.png
Works for SVG, PNG, and JPEG
- `raw.githubusercontent.com/YourUserAccount/YourProject/YourBranch/DirectoryPath/svgdemo1.svg?sanitize=true&raw=true`
Working example code displayed below after used:
**raw.githubusercontent.com**:
<img src="https://raw.githubusercontent.com/YourUserAccount/YourProject/master/DirectoryPath/Example.png?raw=true" />
<img src="https://raw.githubusercontent.com/YourUserAccount/YourProject/master/DirectoryPath/svgdemo1.svg?sanitize=true&raw=true" />
raw.githubusercontent.com:
Thanks: - https://stackoverflow.com/a/48723190/1815624 - https://github.com/potherca-blog/StackOverflow/edit/master/question.13808020.include-an-svg-hosted-on-github-in-markdown/readme.md
Upvotes: 7
Reputation: 579
There's yet another option I haven't seen mentioned. You can simply create another repository under your user or organization called "assets". Push your images to this repo and reference them from your other repos:
data:image/s3,"s3://crabby-images/e8864/e886454ad76043db055f4c73bbc50ee8e5a38123" alt="alt text"
I've done this in one of my repos and it suits me fine. I can version my README images for all of my projects independently of my code, but still keep them all in one place. No issues or branches or other easily misplaced artifacts required.
Upvotes: 3
Reputation: 419
Add image in your repository from upload file option then in README file
data:image/s3,"s3://crabby-images/51861/51861e53783186cc512868d31519804823bbaf43" alt="Alt text"
Upvotes: 1
Reputation: 1837
I have found another solution but quite different and i'll explain it
Basically, i used the tag to show the image, but i wanted to go to another page when the image was clicked and here is how i did it.
<a href="the-url-you-want-to-go-when-image-is-clicked.com" />
<img src="image-source-url-location.com" />
If you put it right next to each other, separated by a new line, i guess when you click the image, it goes to the tag which has the href to the other site you want to redirect.
Upvotes: 5
Reputation: 365
Use tables to stand out, it will give separate charm to it
Table Syntax is:
Separate each column cell by symbol |
and table header (First row) by 2nd row by ---
| col 1 | col 2 |
|------------|-------------|
| image 1 | image 2 |
output
Now just put <img src="url/relativePath">
at image 1 and image 2 if you are using two images
Note: if using multiple images just include more columns, you may use width and height attribute to make it look readable.
Example
| col 1 | col 2 |
|------------|-------------|
| <img src="https://media.wired.com/photos/5926db217034dc5f91becd6b/master/w_582,c_limit/so-logo-s.jpg" width="250">
| <img src="https://mk0jobadderjftub56m0.kinstacdn.com/wp-content/uploads/stackoverflow.com-300.jpg" width="250">
|
Spacing does not matter
Output image
helped by : adam-p
Upvotes: 15
Reputation: 15683
I need to include some images in my README File. I don't know how to do that.
I created a small wizard that allows you to create and customize simple image galleries for your GitHub repository's readme: See ReadmeGalleryCreatorForGitHub.
The wizard takes advantage of the fact that GitHub allows img tags to occur in the README.md
. Also, the wizard makes use of the popular trick of uploading images to GitHub by drag'n'dropping them in the issue area (as already mentioned in one of the answers in this thread).
Upvotes: 38
Reputation: 93
There are 2 simple way you can do this ,
1) use HTML img tag ,
2) data:image/s3,"s3://crabby-images/7c5c6/7c5c6c2d11210664f9963f40eaef441ffd7a647a" alt=""
the path would you can copy from the URL in the browser while you have opened that image. there might be an issue occur of spacing so make sure if there is any space b/w two words of path or in image name add-> %20. just like browser do.
Both of them will work , if you want to understand more you can check my github -> https://github.com/adityarawat29
Upvotes: 7