婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > go語言制作一個gif動態圖

go語言制作一個gif動態圖

熱門標簽:成都呼叫中心外呼系統平臺 電銷機器人可以補救房產中介嗎 最短的地圖標注 谷歌便利店地圖標注 ?兓? 騰訊外呼系統價格 百度地圖標注搜索關鍵詞 電梯外呼訪客系統 浙江人工智能外呼管理系統

如題,關鍵不是圖怎么樣,而是說,go可以拿來實現動態圖驗證碼,加上go支持cgi、fcgi,完全可以做個exe拿去增補現有的服務器么。

ball.go

package main
import (
  "github.com/hydra13142/cube"
  "github.com/hydra13142/geom"
  "github.com/hydra13142/paint"
  "image"
  "image/color/palette"
  "image/gif"
  "math"
  "os"
)
var (
  pln *cube.Plain
  unx cube.Vector
  uny cube.Vector
)
const (
  H = 18
  W = 36
)
func init() {
  pln, _ = cube.NewPlain(cube.Point{}, cube.Vector{4, 4, 3})
  uny = cube.FromTo(cube.Point{}, pln.VerticalPoint(cube.Point{0, 0, 10})).Unit()
  unx = cube.OuterProduct(uny, cube.Vector{4, 4, 3}).Unit()
}
func main() {
  var x [H + 1][W]cube.Point
  var y [H + 1][W]geom.Point
  dz := math.Pi / H
  dxy := math.Pi * 2 / W
  for i := 0; i = H; i++ {
    az := float64(i)*dz - math.Pi/2
    r := 140 * math.Cos(az)
    z := 140 * math.Sin(az)
    for j := 0; j  W; j++ {
      axy := float64(j) * dxy
      x[i][j] = cube.Point{math.Cos(axy) * r, math.Sin(axy) * r, z}
    }
  }
  pics := make([]*image.Paletted, 0, 20)
  img := paint.Image{
    FR: paint.Green,
    BG: paint.White,
  }
  stp := dxy / 20
  delay := make([]int, 0, 20)
  for t := 0; t  20; t++ {
    img.Image = image.NewPaletted(image.Rect(0, 0, 300, 300), palette.Plan9)
    for i := 0; i = H; i++ {
      for j := 0; j  W; j++ {
        ox := cube.FromTo(cube.Point{}, x[i][j])
        y[i][j] = geom.Point{cube.InnerProduct(ox, unx), cube.InnerProduct(ox, uny)}
        a, b := x[i][j].X, x[i][j].Y
        x[i][j].X = a*math.Cos(stp) - b*math.Sin(stp)
        x[i][j].Y = b*math.Cos(stp) + a*math.Sin(stp)
      }
    }
    for i := 0; i  H; i++ {
      for j := 0; j  W; j++ {
        img.Line(
          150+int(y[i][j].X),
          150-int(y[i][j].Y),
          150+int(y[i][(j+1)%W].X),
          150-int(y[i][(j+1)%W].Y),
        )
        img.Line(
          150+int(y[i][j].X),
          150-int(y[i][j].Y),
          150+int(y[i+1][j].X),
          150-int(y[i+1][j].Y),
        )
      }
    }
    pics = append(pics, img.Image.(*image.Paletted))
    delay = append(delay, 5)
  }
  file, _ := os.Create("ball.gif")
  defer file.Close()
  gif.EncodeAll(file, gif.GIF{
    Image:   pics,
    Delay:   delay,
    LoopCount: 5 * len(delay),
  })
}

woniu.go

package main
import (
  "github.com/hydra13142/cube"
  "github.com/hydra13142/geom"
  "github.com/hydra13142/paint"
  "image"
  "image/color/palette"
  "image/gif"
  "math"
  "os"
)
var (
  pln   *cube.Plain
  unx, uny cube.Vector
)
const (
  H = 18
  W = 96
)
func init() {
  pln, _ = cube.NewPlain(cube.Point{}, cube.Vector{2, 2, 1})
  uny = cube.FromTo(cube.Point{}, pln.VerticalPoint(cube.Point{0, 0, 10})).Unit()
  unx = cube.OuterProduct(uny, cube.Vector{2, 2, 1}).Unit()
}
func main() {
  var x [H + 1][W]cube.Point
  var y [H + 1][W]geom.Point
  dz := math.Pi / H
  dxy := math.Pi * 4 / W
  for i := 0; i = H; i++ {
    az := float64(i)*dz - math.Pi/2
    r := 300 * math.Cos(az)
    z := 100 * math.Sin(az)
    for j := 0; j  W; j++ {
      axy := float64(j) * dxy
      R := float64(j) * r / W
      x[i][j] = cube.Point{math.Cos(axy) * R, math.Sin(axy) * R, z}
    }
  }
  pics := make([]*image.Paletted, 0, 20)
  img := paint.Image{
    FR: paint.Green,
    BG: paint.White,
  }
  stp := math.Pi / W
  delay := make([]int, 0, 2*W)
  for t := 0; t  2*W; t++ {
    img.Image = image.NewPaletted(image.Rect(0, 0, 600, 300), palette.Plan9)
    for i := 0; i = H; i++ {
      for j := 0; j  W; j++ {
        ox := cube.FromTo(cube.Point{}, x[i][j])
        y[i][j] = geom.Point{cube.InnerProduct(ox, unx), cube.InnerProduct(ox, uny)}
        a, b := x[i][j].X, x[i][j].Y
        x[i][j].X = a*math.Cos(stp) - b*math.Sin(stp)
        x[i][j].Y = b*math.Cos(stp) + a*math.Sin(stp)
      }
    }
    img.Line(
      300+int(y[0][0].X),
      150-int(y[0][0].Y),
      300+int(y[H][0].X),
      150-int(y[H][0].Y),
    )
    for i := 0; i  H; i++ {
      for j := 1; j  W; j++ {
        img.Line(
          300+int(y[i][j].X),
          150-int(y[i][j].Y),
          300+int(y[i][j-1].X),
          150-int(y[i][j-1].Y),
        )
        img.Line(
          300+int(y[i][j].X),
          150-int(y[i][j].Y),
          300+int(y[i+1][j].X),
          150-int(y[i+1][j].Y),
        )
      }
    }
    pics = append(pics, img.Image.(*image.Paletted))
    delay = append(delay, 5)
  }
  file, _ := os.Create("woniu.gif")
  defer file.Close()
  gif.EncodeAll(file, gif.GIF{
    Image:   pics,
    Delay:   delay,
    LoopCount: 5 * len(delay),
  })
}

rotate.go

package main
import (
  "github.com/hydra13142/cube"
  "github.com/hydra13142/geom"
  "github.com/hydra13142/paint"
  "image"
  "image/color/palette"
  "image/gif"
  "math"
  "os"
)
var (
  pln   *cube.Plain
  unx, uny cube.Vector
)
const (
  H = 9
  W = 36
)
func init() {
  pln, _ = cube.NewPlain(cube.Point{}, cube.Vector{4, 4, 3})
  uny = cube.FromTo(cube.Point{}, pln.VerticalPoint(cube.Point{0, 0, 10})).Unit()
  unx = cube.OuterProduct(uny, cube.Vector{4, 4, 3}).Unit()
}
func main() {
  var x [H*W + 1]cube.Point
  var y [H*W + 1]geom.Point
  dxy := (math.Pi * 2) / W
  dz := math.Pi / H
  for i := 0; i = H*W; i++ {
    az := float64(i)*dz/W - math.Pi/2
    r := 140 * math.Cos(az)
    z := 140 * math.Sin(az) 
    axy := float64(i) * dxy
    x[i] = cube.Point{math.Cos(axy) * r, math.Sin(axy) * r, z}
  }
  pics := make([]*image.Paletted, 0, 20)
  img := paint.Image{
    FR: paint.Green,
    BG: paint.White,
  }
  stp := math.Pi * 2 / (W * 3)
  delay := make([]int, 0, 3*W)
  for t := 0; t  3*W; t++ {
    img.Image = image.NewPaletted(image.Rect(0, 0, 300, 300), palette.Plan9)
    for i := 0; i = H*W; i++ {
      ox := cube.FromTo(cube.Point{}, x[i])
      y[i] = geom.Point{cube.InnerProduct(ox, unx), cube.InnerProduct(ox, uny)}
      a, b := x[i].X, x[i].Z
      x[i].X = a*math.Cos(stp) - b*math.Sin(stp)
      x[i].Z = b*math.Cos(stp) + a*math.Sin(stp)
    }
    img.Line(
      150+int(y[0].X),
      150-int(y[0].Y),
      150+int(y[H*W].X),
      150-int(y[H*W].Y),
    )
    for i := 0; i  H*W; i++ {
      img.Line(
        150+int(y[i].X),
        150-int(y[i].Y),
        150+int(y[i+1].X),
        150-int(y[i+1].Y),
      )
    }
    pics = append(pics, img.Image.(*image.Paletted))
    delay = append(delay, 8)
  }
  file, _ := os.Create("rotate.gif")
  defer file.Close()
  gif.EncodeAll(file, gif.GIF{
    Image:   pics,
    Delay:   delay,
    LoopCount: 5 * len(delay),
  })
}

以上就是本文的全部內容了,希望大家能夠喜歡。

您可能感興趣的文章:
  • Android下錄制App操作生成Gif動態圖的全過程
  • PHP判斷一個gif圖片是否為動態圖片的方法
  • java實現gif動畫效果(java顯示動態圖片)
  • 淺析IOS中播放gif動態圖的方法
  • Matlab制作視頻并轉換成gif動態圖的兩種方法

標簽:七臺河 盤錦 宜昌 上海 雅安 眉山 邢臺 紹興

巨人網絡通訊聲明:本文標題《go語言制作一個gif動態圖》,本文關鍵詞  語言,制作,一個,gif,動態,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《go語言制作一個gif動態圖》相關的同類信息!
  • 本頁收集關于go語言制作一個gif動態圖的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    麻豆精品在线视频| 一本大道久久a久久精二百| 国产精品伦理一区二区| 国产日韩v精品一区二区| 久久久夜色精品亚洲| 欧美人与z0zoxxxx视频| 欧美一区二区日韩| 欧美精品一区二区在线播放| 精品日韩欧美在线| 中文字幕在线观看一区二区| 久久久久久毛片| 又紧又大又爽精品一区二区| 久久综合狠狠综合| 中文字幕一区二区不卡| 亚洲激情五月婷婷| 日韩电影在线看| 一区二区三区四区蜜桃| 天天色天天操综合| 国产a区久久久| 在线影院国内精品| 精品国产青草久久久久福利| 国产无人区一区二区三区| 亚洲日本一区二区| 蜜臀av一区二区| 丁香激情综合五月| 91精品在线一区二区| 欧美国产禁国产网站cc| 亚洲人成影院在线观看| 色综合天天综合在线视频| 亚洲高清视频中文字幕| 日韩国产欧美一区二区三区| 91小视频免费看| 亚洲视频一区在线观看| 日韩av中文字幕一区二区| 在线精品视频免费观看| 亚洲一区二三区| 久久久国产精品午夜一区ai换脸| 99久久国产综合精品色伊| 久久狠狠亚洲综合| 亚洲一区二区视频| 亚洲男同性恋视频| 久久只精品国产| 欧美日本在线一区| 欧美日韩在线精品一区二区三区激情 | 一区二区久久久久久| 国产日韩高清在线| 欧美激情一区二区三区四区| 91精品国产乱| 日韩视频在线你懂得| 欧美一区二区三区视频| 欧美放荡的少妇| 欧美不卡在线视频| 精品国产网站在线观看| xvideos.蜜桃一区二区| 国产精品美女久久久久久久久久久| 欧美xxxx在线观看| 中文子幕无线码一区tr| 国产精品免费人成网站| 亚洲激情自拍视频| 精品一区二区免费视频| 成人黄色片在线观看| 在线观看一区二区视频| 日韩精品一级中文字幕精品视频免费观看 | 久久综合九色综合97婷婷| 亚洲免费伊人电影| 日韩美女久久久| 亚洲成人在线观看视频| 一区二区高清免费观看影视大全| 亚洲免费av高清| 亚洲1区2区3区4区| 国产电影一区在线| 欧美性大战久久| 国产拍揄自揄精品视频麻豆| 中文字幕一区av| 蜜乳av一区二区| 97se亚洲国产综合自在线观| 北条麻妃国产九九精品视频| 久久久精品国产免费观看同学| 欧美性猛交一区二区三区精品| 欧美va在线播放| 国产精品色婷婷| 精彩视频一区二区| 欧美日韩精品一区二区三区四区 | 国产在线播放一区三区四| 波多野结衣欧美| 26uuu久久天堂性欧美| 国产视频一区二区三区在线观看| 99国产精品久久| 日韩一区二区免费在线电影 | 91亚洲国产成人精品一区二区三 | 国产成人av电影在线| 成人短视频下载| 日韩精品一区二区三区在线 | 精品国产不卡一区二区三区| 99久久99精品久久久久久| 成人app软件下载大全免费| 久久av老司机精品网站导航| 欧美精品 日韩| 亚洲欧美综合色| 国产91综合网| 久久久精品免费网站| 中文字幕在线观看一区| 99精品视频在线观看| 欧美激情在线免费观看| 99这里都是精品| 久久精品欧美一区二区三区麻豆| 天天综合网天天综合色| 欧美日韩视频在线观看一区二区三区 | 视频在线观看91| 亚洲一二三四久久| av亚洲精华国产精华精华| 色哟哟在线观看一区二区三区| 欧美本精品男人aⅴ天堂| 奇米四色…亚洲| 欧美成人精品高清在线播放| 亚洲精选视频在线| 99re热视频这里只精品| 欧美高清dvd| 美女精品自拍一二三四| 一区二区三区鲁丝不卡| 日本欧美加勒比视频| 成人一级视频在线观看| 一区二区三区中文字幕在线观看| 国产欧美一区二区精品忘忧草| 久久99精品国产.久久久久久| 色噜噜狠狠色综合欧洲selulu| 久久婷婷一区二区三区| 日本女优在线视频一区二区| 天天综合网天天综合色| 欧美成人a在线| 国产不卡在线一区| 亚洲美腿欧美偷拍| 国产精品视频第一区| 国产麻豆精品在线| 精品国产91洋老外米糕| 在线播放日韩导航| 色综合欧美在线| 91女人视频在线观看| 91久久国产综合久久| 欧美日韩在线观看一区二区| 正在播放亚洲一区| 亚洲国产成人午夜在线一区| 国产精品动漫网站| 日韩一区欧美二区| 国产一区二区三区蝌蚪| 97aⅴ精品视频一二三区| 国内精品国产三级国产a久久| 亚洲欧洲成人自拍| 国产呦萝稀缺另类资源| 久久精品国产99久久6| 爽好多水快深点欧美视频| 久久99精品久久久| 激情深爱一区二区| 日日嗨av一区二区三区四区| 免费不卡在线视频| 国产乱码精品1区2区3区| 捆绑调教美女网站视频一区| 日韩精品欧美精品| 国产伦精品一区二区三区视频青涩| 国产一区二区久久| 色天天综合久久久久综合片| 欧美色男人天堂| 久久伊人中文字幕| www久久精品| 亚洲午夜精品久久久久久久久| 亚洲国产精品久久一线不卡| 日本午夜精品一区二区三区电影| 国产资源精品在线观看| 色综合天天综合色综合av| 日韩亚洲国产中文字幕欧美| 久久精品综合网| 麻豆精品新av中文字幕| 国产一区二区美女| 欧美一区二区免费| 国产精品麻豆久久久| 亚洲欧洲综合另类在线| 麻豆91在线播放免费| 精品无码三级在线观看视频| 欧美午夜精品久久久| 国产精品午夜在线观看| 在线观看91精品国产麻豆| 亚洲免费视频成人| 波多野结衣中文一区| 欧美性做爰猛烈叫床潮| 亚洲网友自拍偷拍| 久久婷婷一区二区三区| 亚洲成人免费在线观看| 欧美日韩一区三区四区| 亚洲成人久久影院| 色综合天天狠狠| 亚洲精品一区二区精华| 成人免费看视频| 欧美电影免费观看高清完整版| 亚洲色图色小说| 色8久久精品久久久久久蜜| 麻豆成人av在线| 日韩欧美国产一区二区三区| 天天综合日日夜夜精品| 欧美日韩视频在线一区二区 | 丁香婷婷综合五月|