# -*- coding: utf-8 -*-
'''
経緯線描画 (日時指定)
Ver 1.12 2013-05-30 update
'''
from Tkinter import *
from math import *
from numpy import *
from urllib import *
from HTMLParser import HTMLParser
import datetime
'''
経緯線描画
'''
class LatLong:
def __init__(self, P,B0,L0,r,width,height,astep,dstep,bg,fc,line,fpath):
self.root = Tk()
self.P = P
self.B0 = B0
self.L0 = L0
self.r = r
self.width = width
self.height = height
self.astep = astep
self.dstep = dstep
self.backcolor = bg
self.forecolor = fc
self.lineweight = line
self.fpath = fpath
self.c0=Canvas(self.root, width=width, height=height, bg=bg)
self.c0.pack()
# Z軸回転
def rotZ(self, a, d):
L = cos(radians(d)) * cos(radians(a - self.L0))
M = cos(radians(d)) * sin(radians(a - self.L0))
N = sin(radians(d))
return array([[L], [M], [N]])
# Y軸回転
def rotY(self, LMN):
mB0 = radians(self.B0) * -1
res = array([[]])
res = append(res, [[cos(mB0), 0, -1 * sin(mB0)]], axis=1)
res = append(res, [[0, 1, 0]], axis=0)
res = append(res, [[sin(mB0), 0, cos(mB0)]], axis=0)
return dot(res, LMN)
# X軸回転
def rotX(self, LMNd):
mP = radians(self.P) * -1
res = array([[]])
res = append(res, [[1, 0, 0]], axis=1)
res = append(res, [[0, cos(mP), sin(mP)]], axis=0)
res = append(res, [[0, -1 * sin(mP), cos(mP)]], axis=0)
return dot(res, LMNd)
# XYZ計算
def calXYZ(self, a, d):
LMN = self.rotZ(a,d)
LMNd = self.rotY(LMN)
xyz = self.rotX(LMNd)
return sum(xyz[0]),sum(xyz[1]),sum(xyz[2])
# 位置補正(XYZ)
def corrPos(self, x, y, z):
x = x
y = y * self.r + self.width / 2
z = self.height / 2 - z * self.r
return x,y,z
# 緯線
def Latitude(self):
lpos=[]
for delta in range(-90,90,self.dstep):
for alpha in range(0, 361, 5):
xyz = self.calXYZ(alpha, delta)
x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
if x>=0:
lpos.append(y)
lpos.append(z)
else:
if len(lpos)>2:
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:]=[]
if len(lpos)>2:
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:]=[]
# 経線
def Longitude(self):
lpos=[]
for alpha in range(0,360,self.astep):
for delta in range(-90, 91, 5):
xyz = self.calXYZ(alpha, delta)
x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
if x>=0:
lpos.append(y)
lpos.append(z)
if len(lpos)>2:
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:]=[]
# 外周描画
def dispOuter(self):
lpos = []
for pos in range(360):
y = cos(radians(pos))
z = sin(radians(pos))
x,y,z = self.corrPos(0, y, z)
lpos.append(y)
lpos.append(z)
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:] = []
# Save PostScript
def SaveImage(self):
self.c0.postscript(file=self.fpath, width=self.width, height=self.height)
# MainLoop
def mainloop(self):
self.root.mainloop()
'''
国立天文台よりPB0L0取得
'''
class KHTMLParser(HTMLParser):
hms = "00:00:00"
getfl = False
P = None
B0 = None
L0 = None
def handle_data(self, data):
data = data.strip(" \t\r\n")
if data and self.getfl:
if self.P and self.B0 and self.L0 is None: self.L0 = float(data)
if self.P and self.B0 is None: self.B0 = float(data)
if self.P is None: self.P = float(data)
if data.strip() == self.hms: self.getfl = True
def handle_starttag(self, tag, attrs):
pass
def handle_endtag(self, tag):
pass
'''
Main
'''
if __name__=='__main__':
'''
使用方法
クラス初期化
LatLong(P,B0,L0,r,width,height,astep,dstep,backcolor,forecolor,lineweight,fpath)
'''
# PB0L0取得
params = {'year':2013,'month':05,'day':20,'hour':10,'min':30,'sec':00}
r=urlopen('http://e...content-available-to-author-only...c.jp/cgi-bin/koyomi/cande/sun_spin.cgi',urlencode(params))
mp = KHTMLParser()
mp.hms = "%02d:%02d:%02d" % (int(params['hour']), int(params['min']), int(params['sec']))
mp.feed(r.read())
# LatLong起動
latlong = LatLong(mp.P,mp.B0,mp.L0,300, 800, 800, 15, 15, "black", "green", 2.0, r"~/Desktop/ball.ps")
latlong.Latitude()
latlong.Longitude()
latlong.dispOuter()
latlong.SaveImage()
latlong.mainloop()
# -*- coding: utf-8 -*-
'''
経緯線描画 (日時指定)
Ver 1.11 2013-05-29 update
'''
from Tkinter import *
from math import *
from numpy import *
from urllib import *
from HTMLParser import HTMLParser
import datetime
'''
経緯線描画
'''
class LatLong:
def __init__(self, P,B0,L0,r,width,height,astep,dstep,bg,fc,line,fpath):
self.root = Tk()
self.P = P
self.B0 = B0
self.L0 = L0
self.r = r
self.width = width
self.height = height
self.astep = astep
self.dstep = dstep
self.backcolor = bg
self.forecolor = fc
self.lineweight = line
self.fpath = fpath
self.c0=Canvas(self.root, width=width, height=height, bg=bg)
self.c0.pack()
# Z軸回転
def rotZ(self, a, d):
L = cos(radians(d)) * cos(radians(a - self.L0))
M = cos(radians(d)) * sin(radians(a - self.L0))
N = sin(radians(d))
return array([[L], [M], [N]])
# Y軸回転
def rotY(self, LMN):
mB0 = radians(self.B0) * -1
res = array([[]])
res = append(res, [[cos(mB0), 0, -1 * sin(mB0)]], axis=1)
res = append(res, [[0, 1, 0]], axis=0)
res = append(res, [[sin(mB0), 0, cos(mB0)]], axis=0)
return dot(res, LMN)
# X軸回転
def rotX(self, LMNd):
mP = radians(self.P) * -1
res = array([[]])
res = append(res, [[1, 0, 0]], axis=1)
res = append(res, [[0, cos(mP), sin(mP)]], axis=0)
res = append(res, [[0, -1 * sin(mP), cos(mP)]], axis=0)
return dot(res, LMNd)
# XYZ計算
def calXYZ(self, a, d):
LMN = self.rotZ(a,d)
LMNd = self.rotY(LMN)
xyz = self.rotX(LMNd)
return sum(xyz[0]),sum(xyz[1]),sum(xyz[2])
# 位置補正(XYZ)
def corrPos(self, x, y, z):
x = x
y = y * self.r + self.width / 2
z = self.height / 2 - z * self.r
return x,y,z
# 緯線
def Latitude(self):
lpos=[]
for delta in range(-90,90,self.dstep):
for alpha in range(0, 361, 5):
xyz = self.calXYZ(alpha, delta)
x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
if x>=0:
lpos.append(y)
lpos.append(z)
else:
if len(lpos)>2:
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:]=[]
if len(lpos)>2:
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:]=[]
# 経線
def Longitude(self):
lpos=[]
for alpha in range(0,360,self.astep):
for delta in range(-90, 91, 5):
xyz = self.calXYZ(alpha, delta)
x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
if x>=0:
lpos.append(y)
lpos.append(z)
if len(lpos)>2:
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:]=[]
# 外周描画
def dispOuter(self):
lpos = []
for pos in range(360):
y = cos(radians(pos))
z = sin(radians(pos))
x,y,z = self.corrPos(0, y, z)
lpos.append(y)
lpos.append(z)
self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
lpos[:] = []
# Save PostScript
def SaveImage(self):
self.c0.postscript(file=self.fpath, width=self.width, height=self.height)
# MainLoop
def mainloop(self):
self.root.mainloop()
'''
国立天文台よりPB0L0取得
'''
class KHTMLParser(HTMLParser):
hms = "00:00:00"
getfl = False
P = None
B0 = None
L0 = None
def handle_data(self, data):
data = data.strip(" \t\r\n")
if data and self.getfl:
if self.P and self.B0 and self.L0 is None: self.L0 = float(data)
if self.P and self.B0 is None: self.B0 = float(data)
if self.P is None: self.P = float(data)
if data.strip() == self.hms: self.getfl = True
def handle_starttag(self, tag, attrs):
pass
def handle_endtag(self, tag):
pass
'''
Main
'''
if __name__=='__main__':
'''
使用方法
クラス初期化
LatLong(P,B0,L0,r,width,height,astep,dstep,backcolor,forecolor,lineweight,fpath)
'''
# PB0L0取得
params = {'year':2013,'month':05,'day':20,'hour':10,'min':30,'sec':00, 'tsys':2}
r=urlopen('http://e...content-available-to-author-only...c.jp/cgi-bin/koyomi/cande/sun_spin.cgi',urlencode(params))
mp = KHTMLParser()
mp.hms = "%02d:%02d:%02d" % (int(params['hour']), int(params['min']), int(params['sec']))
mp.feed(r.read())
# LatLong起動
latlong = LatLong(mp.P,mp.B0,mp.L0,300, 800, 800, 15, 15, "black", "green", 2.0, r"~/Desktop/ball.ps")
latlong.Latitude()
latlong.Longitude()
latlong.dispOuter()
latlong.SaveImage()
latlong.mainloop()
# -*- coding: utf-8 -*-
'''
経緯線描画 (日時指定)
Ver 1.12 2013-05-30 update
'''
from Tkinter import *
from math import *
from numpy import *
from urllib import *
from HTMLParser import HTMLParser
import datetime

'''
経緯線描画
'''
class LatLong:
    def __init__(self, P,B0,L0,r,width,height,astep,dstep,bg,fc,line,fpath):
        self.root = Tk()
        self.P = P
        self.B0 = B0
        self.L0 = L0
        self.r = r
        self.width = width
        self.height = height
        self.astep = astep
        self.dstep = dstep
        self.backcolor = bg
        self.forecolor = fc
        self.lineweight = line
        self.fpath = fpath
        self.c0=Canvas(self.root, width=width, height=height, bg=bg)
        self.c0.pack()

    # Z軸回転
    def rotZ(self, a, d):
        L = cos(radians(d)) * cos(radians(a - self.L0))
        M = cos(radians(d)) * sin(radians(a - self.L0))
        N = sin(radians(d))
        return array([[L], [M], [N]])

    # Y軸回転
    def rotY(self, LMN):
        mB0 = radians(self.B0) * -1
        res = array([[]])
        res = append(res, [[cos(mB0), 0, -1 * sin(mB0)]], axis=1)
        res = append(res, [[0, 1, 0]], axis=0)
        res = append(res, [[sin(mB0), 0, cos(mB0)]], axis=0)
        return dot(res, LMN)
    
    # X軸回転
    def rotX(self, LMNd):
        mP = radians(self.P) * -1
        res = array([[]])
        res = append(res, [[1, 0, 0]], axis=1)
        res = append(res, [[0, cos(mP), sin(mP)]], axis=0)
        res = append(res, [[0, -1 * sin(mP), cos(mP)]], axis=0)
        return dot(res, LMNd)

    # XYZ計算
    def calXYZ(self, a, d):
        LMN = self.rotZ(a,d)
        LMNd = self.rotY(LMN)
        xyz = self.rotX(LMNd)

        return sum(xyz[0]),sum(xyz[1]),sum(xyz[2])

    # 位置補正(XYZ)
    def corrPos(self, x, y, z):
        x = x
        y = y * self.r + self.width / 2
        z = self.height / 2 - z * self.r
        return x,y,z
        
    #　緯線
    def Latitude(self):
        lpos=[]
        for delta in range(-90,90,self.dstep):
            for alpha in range(0, 361, 5):
                xyz = self.calXYZ(alpha, delta)
                x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
                if x>=0:
                    lpos.append(y)
                    lpos.append(z)
                else:
                    if len(lpos)>2:
                        self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
                    lpos[:]=[]

            if len(lpos)>2: 
                self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
            lpos[:]=[]
        
    # 経線
    def Longitude(self):
        lpos=[]
        for alpha in range(0,360,self.astep):
            for delta in range(-90, 91, 5):
                xyz = self.calXYZ(alpha, delta)
                x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
                if x>=0:
                    lpos.append(y)
                    lpos.append(z)
            if len(lpos)>2:
                self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
            lpos[:]=[]

    # 外周描画
    def dispOuter(self):
        lpos = []
        for pos in range(360):
            y = cos(radians(pos))
            z = sin(radians(pos))
            x,y,z = self.corrPos(0, y, z)

            lpos.append(y)
            lpos.append(z)
        self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
        lpos[:] = []

    # Save PostScript
    def SaveImage(self):
        self.c0.postscript(file=self.fpath, width=self.width, height=self.height)

    # MainLoop
    def mainloop(self):
        self.root.mainloop()


'''
国立天文台よりPB0L0取得
'''
class KHTMLParser(HTMLParser):
    hms = "00:00:00"
    getfl = False
    P = None
    B0 = None
    L0 = None
    
    def handle_data(self, data):
        data = data.strip("  \t\r\n")

        if data and self.getfl:
            if self.P and self.B0 and self.L0 is None: self.L0 = float(data)
            if self.P and self.B0 is None: self.B0 = float(data)
            if self.P is None: self.P = float(data)
            
        if data.strip() == self.hms: self.getfl = True

    def handle_starttag(self, tag, attrs):
        pass

    def handle_endtag(self, tag):
        pass


'''
Main
'''
if __name__=='__main__':
    '''
    使用方法

    クラス初期化
    LatLong(P,B0,L0,r,width,height,astep,dstep,backcolor,forecolor,lineweight,fpath)
    '''
    # PB0L0取得
    params = {'year':2013,'month':05,'day':20,'hour':10,'min':30,'sec':00}

    r=urlopen('http://e...content-available-to-author-only...c.jp/cgi-bin/koyomi/cande/sun_spin.cgi',urlencode(params))
    mp = KHTMLParser()
    mp.hms = "%02d:%02d:%02d" % (int(params['hour']), int(params['min']), int(params['sec']))
    mp.feed(r.read())

    # LatLong起動
    latlong = LatLong(mp.P,mp.B0,mp.L0,300, 800, 800, 15, 15, "black", "green", 2.0, r"~/Desktop/ball.ps")
    
    latlong.Latitude()
    latlong.Longitude()
    latlong.dispOuter()
    latlong.SaveImage()
    latlong.mainloop()
# -*- coding: utf-8 -*-
'''
経緯線描画 (日時指定)
Ver 1.11 2013-05-29 update
'''
from Tkinter import *
from math import *
from numpy import *
from urllib import *
from HTMLParser import HTMLParser
import datetime

'''
経緯線描画
'''
class LatLong:
    def __init__(self, P,B0,L0,r,width,height,astep,dstep,bg,fc,line,fpath):
        self.root = Tk()
        self.P = P
        self.B0 = B0
        self.L0 = L0
        self.r = r
        self.width = width
        self.height = height
        self.astep = astep
        self.dstep = dstep
        self.backcolor = bg
        self.forecolor = fc
        self.lineweight = line
        self.fpath = fpath
        self.c0=Canvas(self.root, width=width, height=height, bg=bg)
        self.c0.pack()

    # Z軸回転
    def rotZ(self, a, d):
        L = cos(radians(d)) * cos(radians(a - self.L0))
        M = cos(radians(d)) * sin(radians(a - self.L0))
        N = sin(radians(d))
        return array([[L], [M], [N]])

    # Y軸回転
    def rotY(self, LMN):
        mB0 = radians(self.B0) * -1
        res = array([[]])
        res = append(res, [[cos(mB0), 0, -1 * sin(mB0)]], axis=1)
        res = append(res, [[0, 1, 0]], axis=0)
        res = append(res, [[sin(mB0), 0, cos(mB0)]], axis=0)
        return dot(res, LMN)
    
    # X軸回転
    def rotX(self, LMNd):
        mP = radians(self.P) * -1
        res = array([[]])
        res = append(res, [[1, 0, 0]], axis=1)
        res = append(res, [[0, cos(mP), sin(mP)]], axis=0)
        res = append(res, [[0, -1 * sin(mP), cos(mP)]], axis=0)
        return dot(res, LMNd)

    # XYZ計算
    def calXYZ(self, a, d):
        LMN = self.rotZ(a,d)
        LMNd = self.rotY(LMN)
        xyz = self.rotX(LMNd)

        return sum(xyz[0]),sum(xyz[1]),sum(xyz[2])

    # 位置補正(XYZ)
    def corrPos(self, x, y, z):
        x = x
        y = y * self.r + self.width / 2
        z = self.height / 2 - z * self.r
        return x,y,z
        
    #　緯線
    def Latitude(self):
        lpos=[]
        for delta in range(-90,90,self.dstep):
            for alpha in range(0, 361, 5):
                xyz = self.calXYZ(alpha, delta)
                x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
                if x>=0:
                    lpos.append(y)
                    lpos.append(z)
                else:
                    if len(lpos)>2:
                        self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
                    lpos[:]=[]

            if len(lpos)>2: 
                self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
            lpos[:]=[]
        
    # 経線
    def Longitude(self):
        lpos=[]
        for alpha in range(0,360,self.astep):
            for delta in range(-90, 91, 5):
                xyz = self.calXYZ(alpha, delta)
                x,y,z = self.corrPos(xyz[0], xyz[1], xyz[2])
                if x>=0:
                    lpos.append(y)
                    lpos.append(z)
            if len(lpos)>2:
                self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
            lpos[:]=[]

    # 外周描画
    def dispOuter(self):
        lpos = []
        for pos in range(360):
            y = cos(radians(pos))
            z = sin(radians(pos))
            x,y,z = self.corrPos(0, y, z)

            lpos.append(y)
            lpos.append(z)
        self.c0.create_line(lpos,fill=self.forecolor,width=self.lineweight,smooth=True)
        lpos[:] = []

    # Save PostScript
    def SaveImage(self):
        self.c0.postscript(file=self.fpath, width=self.width, height=self.height)

    # MainLoop
    def mainloop(self):
        self.root.mainloop()


'''
国立天文台よりPB0L0取得
'''
class KHTMLParser(HTMLParser):
    hms = "00:00:00"
    getfl = False
    P = None
    B0 = None
    L0 = None
    
    def handle_data(self, data):
        data = data.strip("  \t\r\n")

        if data and self.getfl:
            if self.P and self.B0 and self.L0 is None: self.L0 = float(data)
            if self.P and self.B0 is None: self.B0 = float(data)
            if self.P is None: self.P = float(data)
            
        if data.strip() == self.hms: self.getfl = True

    def handle_starttag(self, tag, attrs):
        pass

    def handle_endtag(self, tag):
        pass


'''
Main
'''
if __name__=='__main__':
    '''
    使用方法

    クラス初期化
    LatLong(P,B0,L0,r,width,height,astep,dstep,backcolor,forecolor,lineweight,fpath)
    '''
    # PB0L0取得
    params = {'year':2013,'month':05,'day':20,'hour':10,'min':30,'sec':00, 'tsys':2}

    r=urlopen('http://e...content-available-to-author-only...c.jp/cgi-bin/koyomi/cande/sun_spin.cgi',urlencode(params))
    mp = KHTMLParser()
    mp.hms = "%02d:%02d:%02d" % (int(params['hour']), int(params['min']), int(params['sec']))
    mp.feed(r.read())

    # LatLong起動
    latlong = LatLong(mp.P,mp.B0,mp.L0,300, 800, 800, 15, 15, "black", "green", 2.0, r"~/Desktop/ball.ps")
    
    latlong.Latitude()
    latlong.Longitude()
    latlong.dispOuter()
    latlong.SaveImage()
    latlong.mainloop()
