新聞中心
先上兩張效果圖

在額敏等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作按需策劃設(shè)計(jì),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計(jì),成都營銷網(wǎng)站建設(shè),外貿(mào)網(wǎng)站建設(shè),額敏網(wǎng)站建設(shè)費(fèi)用合理。
基本結(jié)構(gòu)
總結(jié)文字特效的特點(diǎn)是,每個文字獨(dú)立運(yùn)動,都符合同一個運(yùn)動規(guī)律,但每個文字之間保持一個固定的時(shí)間差。
每個字的運(yùn)動可以分成三個部分,字體大小的變化、文字位置的變化、文字顏色(透明度)的變化。
# 把每個文字與它的三個運(yùn)動結(jié)合為一個基本單位
def newTextMotion(char, posFunc, sizeFunc, colorFunc):
tm={}
tm['char']=char
tm['posFunc']= posFunc
tm['sizeFunc']= sizeFunc
tm['colorFunc']= colorFunc
return tm文字動效的展示
在任意一個時(shí)間點(diǎn)上,獲得文字的顯示效果。
# 在指定的時(shí)間,計(jì)算文字的位置、大小、顏色等 def showText(img, textMotion, time): char= textMotion['char'] pos= textMotion['posFunc'](time) size= textMotion['sizeFunc'](time) color= textMotion['colorFunc'](time) font= ImageFont.truetype(fontName, size) draw = ImageDraw.Draw(im=img) textSize= draw.textsize(text=char, font=font) tx= pos[0]- textSize[0]// 2 ty= pos[1]- textSize[1]// 2 draw.text(xy=(tx, ty), text=char, fill=color, font=font)
針對一組文字,形成一個列表,獲取起每個時(shí)間點(diǎn)的顯示圖,作為一幀
def getTextFrame(tmList, time):
textImg= Image.new('RGBA', (1280, 720))
for tm in tmList:
showText(textImg, tm, time)
return textImg具體文字運(yùn)動規(guī)律
下面看看這兩種特效的具體運(yùn)動規(guī)律。乍一看比較復(fù)雜,但拆分為三個運(yùn)動后,其實(shí)每種都比較簡單。以此為模塊,讀者可以自行制作更多的文字特效。
# 文字縮小 def makeTextShrink(char, toSize, toPos, toColor, offset, dur): def colorFunc(time): if time< offset: return (0,0,0,0) if time> offset+ dur: return toColor return toColor[:-1] + (50+ round((time-offset)/dur*200),) def sizeFunc(time): if time< offset: return toSize* 8 if time> offset+ dur: return toSize return toSize*8 - round((time-offset)/dur* toSize*7.5) def posFunc(time): if time< offset: return (0,0) if time> offset+ dur: return toPos # return (toPos[0], round((time-offset)/dur*toPos[1])) return toPos return newTextMotion(char, posFunc, sizeFunc, colorFunc) # 拋物線降落(有一個回彈效果) def makeTextParaDrop(char, toSize, toPos, toColor, offset, dur): def colorFunc(time): if time< offset: return (0,0,0,0) if time> offset+ dur: return toColor return toColor[:-1] + (50+ round((time-offset)/dur*200),) def sizeFunc(time): if time< offset: return toSize if time> offset+ dur: return toSize return toSize def posFunc(time): if time< offset: return (toPos[0], 0) if time> offset+ dur: return toPos r= 0.75 dur2= dur a= toPos[1]/(dur2* dur2* (1- 2* r)) b= -2* a* dur2* r x= (time-offset) return (toPos[0], round(a* x* x+ b*x)) # print(toPos) return newTextMotion(char, posFunc, sizeFunc, colorFunc)
整體設(shè)置與運(yùn)行
對于一行文字,每個增加特效,并依次給予一個延時(shí)。
# 一行文字,給定所有參數(shù),配置運(yùn)動函數(shù)與延時(shí) def getMotionList(text, fontSize, fontColor, startPos, fromTime, dur, func): tmList=[] inter= round(dur/ len(text)) for i in range(len(text)): char= text[i] pos= (startPos[0]+ i* fontSize+ 10, startPos[1]) color= fontColor # tm= makeTextDropMotion(char, fontSize, pos, color, 150*i) tm= func(char, fontSize, pos, color, fromTime+inter*i, dur) tmList.append(tm) return tmList
這里,將不同的文字特效函數(shù)作為參數(shù)傳入即可,有比較好的擴(kuò)展性。
最后是一個展示函數(shù),用了imageio來制作gif圖。這里注意兩個地方,第一是展示時(shí)間應(yīng)當(dāng)是單文字運(yùn)動時(shí)間的兩倍。為了確保動感,當(dāng)?shù)谝粋€文字到位時(shí),最后一個文字恰好啟動,所以時(shí)間是兩倍的關(guān)系。
第二是制作GIF的延時(shí)應(yīng)當(dāng)與計(jì)算用的延時(shí)一致,這里都是50毫秒(20fps)。
def showTextDrop(text, startPos, func):
fontSize= 50
color=(255, 255, 0, 255)
tmList= getMotionList(text, fontSize, color, startPos, 0, 1000, func)
frames=[]
outfilename='temp.gif'
for i in range(0, 2000, 50):
print(i)
img= Image.new('RGB', (640, 360))
# img= Image.open('back.png').resize((640, 360), Image.ANTIALIAS)
# img = img.convert("RGB")
textImg= getTextFrame(tmList, i)
r, g, b, a= textImg.split()
img.paste(textImg, (0,0), mask= a)
str1= 'tempAA.png'
img.save(str1)
im = imageio.imread(str1)
frames.append(im)
imageio.mimsave(outfilename, frames, 'GIF', duration=0.05)
if __name__=='__main__':
# showTextDrop('淡妝濃抹總相宜', (150,200), makeTextParaDrop)
showTextDrop('淡妝濃抹總相宜', (150,200), makeTextDropMotion)更多python知識,請關(guān)注Python視頻教程?。?/p>
標(biāo)題名稱:創(chuàng)新互聯(lián)Python教程:Python的文字特效,炫酷了!
本文地址:http://www.dlmjj.cn/article/dpghjcj.html


咨詢
建站咨詢
