I can find 2 possible methods.
1. We can create 10 almost identical entity of "iron-ore" with different map_color parameters, which are equals map_color parameters of surface tiles (grass, dirt, sand, etc.). So while map is generated, we start findentities of "iron-ore" entity in huge radius. After that for each entity we get its tile properties and swap "iron-ore" entity to needed (with needed map_color params)
2. In autoplace settings we can restrict tiles, on which iron-ore can be generated. We can allow only one tile type (sand e.g.) and set map_color parameters of iron-ore equal to sand. So iron-ore will be invisible on sand and not generated on other surface types.
I dont like both methods, 1st is slow and non-elegant, 2nd imposes restrictions to map generation and gameplay in particular.
SO question is still opened, i'll be happy to hear any ideas