<div class="image">
  <div class="arrow arrow-top" data-text="640px"><span></span><span></span></div>
  <div class="arrow arrow-side arrow-left" data-text="300px"><span></span><span></span></div>
    <img src="https://placeimg.com/640/300/girl" alt="img">
  <div class="arrow arrow-bottom" data-text="640px"><span></span><span></span></div>
  <div class="arrow arrow-side arrow-right" data-text="300px"><span></span><span></span></div>
</div>
body {
  margin: 40px;
}

.image {
  position: relative;
  height: 300px;
  width: 640px;
}

.image:hover .arrow {
  opacity: 0;
}

.arrow {
  width: 95%;
  height: 1px;
  background-color: #FFF;
  position: relative;
  transition: all 0.5s;
}

.arrow:before {
  content: ' ' attr(data-text) ' ';
  position: absolute;
  color: #FFF;
  font-family: sans-serif;
  font-size: 12px;
}

.arrow.arrow-top:before {
  top: 10px;
  left: 50%;
}

.arrow.arrow-bottom:before {
  left: 50%;
  bottom: 10px;
}

.arrow-bottom {
  bottom: 25px;
  left: 50%;
  transform: translateX(-50%);
}

.arrow-top {
  top: 25px;
  left: 50%;
  transform: translateX(-50%);
}

.arrow span:first-child:after {
  content: "";
  position: absolute;
  top: -5px;
  left: 0;
  display: block;
  width: 0; 
  height: 0; 
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent; 
  border-right: 10px solid #FFF; 
}

.arrow span:first-child:before {
  content: "";
  position: absolute;
  top: -5px;
  left: 0;
  display: block;
  width: 1px; 
  height: 12px;
  background-color: #FFF;
}

.arrow span:last-child:after {
  content: "";
  position: absolute;
  top: -5px;
  right: 0;
  display: block;
  width: 0; 
  height: 0; 
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent; 
  border-left: 10px solid #FFF; 
}

.arrow span:last-child:before {
  content: "";
  position: absolute;
  top: -5px;
  right: 0;
  display: block;
  width: 1px; 
  height: 12px;
  background-color: #FFF;
}


.arrow.arrow-side {
  height: 60%;
  width: 1px;
  background-color: #FFF;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.arrow.arrow-side:before {
  content: ' ' attr(data-text) ' ';
  position: absolute;
  color: #FFF;
  font-family: sans-serif;
  font-size: 12px;
  top: 50%;
}

.arrow.arrow-side.arrow-left {
  left: 20px;
}

.arrow.arrow-side.arrow-left:before {
  left: 0px;
  transform: translateY(-50%) rotate(90deg);
}

.arrow.arrow-side.arrow-right {
  right: 20px;
}

.arrow.arrow-side.arrow-right:before {
  right: 0px;
  transform: translateY(-50%) rotate(-90deg);
}

.arrow.arrow-side span:first-child:after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: -5px;
  top: auto;
  display: block;
  width: 0; 
  height: 0; 
  border-top: 10px solid #FFF;
  border-left: 6px solid transparent; 
  border-right: 6px solid transparent; 
}

.arrow.arrow-side span:first-child:before {
  content: "";
  position: absolute;
  bottom: -3px;
  left: -5px;
  top: auto;
  display: block;
  width: 12px; 
  height: 1px;
  background-color: #FFF;
}

.arrow.arrow-side span:last-child:after {
  content: "";
  position: absolute;
  bottom: auto;
  left: -5px;
  top: -12px;
  display: block;
  width: 0; 
  height: 0; 
  border-bottom: 10px solid #FFF;
  border-left: 6px solid transparent; 
  border-right: 6px solid transparent; 
}

.arrow.arrow-side span:last-child:before {
  content: "";
  position: absolute;
  top: -6px;
  left: -5px;
  bottom: auto;
  display: block;
  width: 12px; 
  height: 1px;
  background-color: #FFF;
}

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.