How can I effectively hide imageless products on collection page?

I wanted to hide the products from the collection page which are not have any media/images. I tried to add a condition in for loop for that and products are hidden but it remains the blank space for those products in the collection. By debugging the code I get informed that it is because the object passed in paginate tag.

This is the image of the collection section before I added the code for hiding the product. And this is after image

Any quick help will be grateful