import os
import urllib.parse
import urllib.request

import numpy as np
import requests
import urllib3

'''
data_1:
    pitch_list = np.linspace(-80,80,10).astype(int) #-90,90
    heading_list = np.linspace(0,360,10).astype(int)[:-1] #0,360
    location1_list = np.linspace(22.303069148652774,22.30338599159437, 10)
    location2_list = np.linspace(114.16801133735089, 114.17598832825882, 10)
'''

def collect(path):
    if not os.path.exists(path):
        os.makedirs(path)
    # size=600x300&location=40.8,-74.0000&heading=50&pitch=0&radius=100&return_error_code=true&key=AIzaSyBHK1aa_9f5PgJllYjvlhXAgN3Mj28Z_ik
    # https://maps.googleapis.com/maps/api/streetview/metadata?size=600x300&location=78.648401,14.194336&fov=90&heading=235&pitch=10&key=YOUR_API_KEY&signature=YOUR_SIGNATURE
    key = 'AIzaSyBHK1aa_9f5PgJllYjvlhXAgN3Mj28Z_ik'
    size = '600x300'
    return_error_code = 'true'
    radius = 100
    fov = 90
    #pitch_list = np.linspace(-80,80,10).astype(int) #-90,90
    pitch_list=np.linspace(0,1,1)
    #heading_list = np.linspace(0,360,40).astype(int)[:-1] #0,360
    heading_list = np.linspace(0,360,361).astype(int)[:-1]
    #location1_list = np.linspace(22.303069148652774,22.30338599159437, 10)
    location1_list = np.linspace(40.8,41.8,1)
    #location2_list = np.linspace(114.16801133735089, 114.17598832825882, 10)
    location2_list = np.linspace(-74.0,-73,1)

    print(heading_list)
    
    cnt = 0
    cnt_suc = 0
    for pitch in pitch_list:
        for heading in heading_list:
            for loc1 in location1_list:
                loc1 = ('%.7f' % loc1)
                for loc2 in location2_list:
                    #print(pitch)
                    loc2 = ('%.7f'%loc2)
                    url = 'https://maps.googleapis.com/maps/api/streetview?' \
                          +'size=' + size \
                          +'&location=' + str(loc1) + ',' + str(loc2) \
                          + '&heading=' + str(heading) \
                          +'&pitch=' + str(pitch) \
                          +'&radius=' + str(radius) \
                          +'&fov=' + str(fov) \
                          +'&return_error_code=' + return_error_code\
                          +'&key=' + key

                    url_meta = 'https://maps.googleapis.com/maps/api/streetview/metadata?' \
                          + 'size=' + size \
                          + '&location=' + str(loc1) + ',' + str(loc2) \
                          + '&heading=' + str(heading) \
                          + '&pitch=' + str(pitch) \
                          + '&radius=' + str(radius) \
                          + '&fov=' + str(fov) \
                          + '&key=' + key
                    save_name = path + str(loc1) + '_' + str(loc2) + '_' + str(heading) + '_' + str(pitch) + '.jpg'
                    cnt += 1
                    if not os.path.exists(save_name):
                        meta_rep = urllib.request.urlopen(url_meta)
                        if meta_rep.msg == 'OK':
                            rep = urllib.request.urlopen(url)
                            f = open(save_name, 'wb')
                            f.write(rep.read())
                            f.close()
                            cnt_suc += 1
                            print('cnt=', cnt, 'suc', cnt_suc)
                    else:
                        cnt_suc += 1
                        print('cnt=',cnt,'suc',cnt_suc,'exist')

if __name__ == '__main__':

    collect('iuput_data/street_view/theta')