校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 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動態圖的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩免费视频线观看| 久久久久久久免费视频了| 国产电影精品久久禁18| 亚洲国产精品综合小说图片区| 久久久一区二区三区| 精品视频一区二区不卡| 国产成人免费视频| 美女www一区二区| 亚洲18色成人| 曰韩精品一区二区| 综合久久久久久久| 亚洲国产激情av| 精品国产青草久久久久福利| 欧美在线色视频| 91论坛在线播放| 国产91丝袜在线播放九色| 精品一区二区三区在线观看 | 色8久久精品久久久久久蜜| 激情综合网天天干| 男人的j进女人的j一区| 亚洲国产精品天堂| 一区二区三区国产精品| 国产精品对白交换视频| 国产精品久久三区| 欧美激情综合五月色丁香| 久久老女人爱爱| 国产调教视频一区| 久久亚洲二区三区| 日韩午夜在线影院| 欧美一卡2卡3卡4卡| 4hu四虎永久在线影院成人| 欧美精选一区二区| 欧美另类高清zo欧美| 欧美日韩一区小说| 欧美日本一道本| 91 com成人网| 欧美精品v日韩精品v韩国精品v| 欧美吞精做爰啪啪高潮| 欧美猛男男办公室激情| 欧美一区二区三区电影| 日韩久久久久久| 日韩一卡二卡三卡四卡| 欧美一级日韩不卡播放免费| 日韩精品中文字幕一区二区三区 | 日本一区二区三区高清不卡| 欧美精品一区二区三区蜜桃| 欧美成人精精品一区二区频| 精品99一区二区三区| 久久久久国产免费免费 | 亚洲国产aⅴ天堂久久| 亚洲高清免费一级二级三级| 香蕉久久夜色精品国产使用方法| 日韩精品一级中文字幕精品视频免费观看| 午夜精品视频在线观看| 麻豆精品视频在线观看免费| 国产专区综合网| eeuss国产一区二区三区| 日本久久一区二区三区| 欧美精品丝袜中出| 欧美大片在线观看| 欧美国产精品中文字幕| 樱花影视一区二区| 日韩精品一二区| 捆绑紧缚一区二区三区视频| 国产精品一区二区x88av| 99r国产精品| 在线播放视频一区| 久久久青草青青国产亚洲免观| 中文字幕一区二区不卡| 丝袜脚交一区二区| 国产成人在线电影| 一本大道久久a久久综合婷婷| 欧美日韩黄色影视| 久久久精品国产免大香伊| 国产精品国产三级国产aⅴ原创| 亚洲成人你懂的| 国产不卡在线视频| 欧美日韩一本到| 久久伊99综合婷婷久久伊| 亚洲精品免费电影| 国产最新精品免费| 精品视频在线免费观看| 国产亚洲成年网址在线观看| 亚洲乱码国产乱码精品精98午夜| 日本美女一区二区三区| 91小视频免费观看| wwww国产精品欧美| 亚洲福利一区二区三区| 国产精品 欧美精品| 3atv一区二区三区| 亚洲女人****多毛耸耸8| 久久精品国产亚洲高清剧情介绍| 91美女蜜桃在线| 久久久久久一级片| 午夜精品久久久久久久99樱桃| 成人午夜视频免费看| 制服.丝袜.亚洲.中文.综合| 亚洲欧洲av在线| 国产一区三区三区| 欧美精品在线一区二区三区| 亚洲男同性恋视频| 成人一级黄色片| 精品成人一区二区三区| 日韩专区在线视频| 欧洲一区二区av| 国产精品女同互慰在线看| 麻豆精品国产91久久久久久| 欧美日韩另类国产亚洲欧美一级| 日韩一区欧美小说| 国产xxx精品视频大全| 精品国产乱码久久久久久免费 | 久久99精品久久久久久动态图 | 日韩三级精品电影久久久| 亚洲图片自拍偷拍| 99久久婷婷国产综合精品电影| 久久久亚洲午夜电影| 精品中文字幕一区二区| 91麻豆精品久久久久蜜臀| 亚洲五码中文字幕| 欧洲亚洲国产日韩| 亚洲中国最大av网站| 色老汉av一区二区三区| 日韩理论片网站| 97久久超碰国产精品| 1区2区3区精品视频| caoporen国产精品视频| 综合色天天鬼久久鬼色| k8久久久一区二区三区| 国产精品免费观看视频| 成人av资源在线| 中文字幕一区二区不卡| 97精品电影院| 亚洲最新视频在线观看| 在线视频你懂得一区二区三区| 一区二区三区高清| 欧美日韩免费电影| 日韩高清一区在线| 欧美一区二区在线观看| 麻豆专区一区二区三区四区五区| 欧美一级片免费看| 精品一区二区日韩| 国产亚洲美州欧州综合国| 国产精品99精品久久免费| 欧美激情在线一区二区三区| 成人黄色综合网站| 亚洲欧美日韩国产综合| 精品视频1区2区| 日本亚洲最大的色成网站www| 91麻豆精品国产91久久久久久 | 欧美天堂一区二区三区| 五月天一区二区三区| 欧美mv日韩mv| 丰满白嫩尤物一区二区| 亚洲国产高清aⅴ视频| 成人久久18免费网站麻豆| 亚洲精品国产一区二区三区四区在线 | 欧美日韩三级一区二区| 日韩精品国产精品| 欧美激情在线一区二区三区| 99久久精品国产导航| 亚洲一区二区三区爽爽爽爽爽| 91精品久久久久久久91蜜桃| 国产一区二区视频在线| 中文字幕在线一区| 欧美日韩久久不卡| 国产在线不卡一区| 一区二区三区在线视频播放 | 久久午夜电影网| 97国产精品videossex| 日韩中文字幕av电影| 国产日韩欧美不卡在线| 在线观看日韩精品| 国内精品视频一区二区三区八戒| 国产精品国产精品国产专区不蜜| 欧美日韩一级二级三级| 国产精品99久久久久久似苏梦涵| 亚洲美女屁股眼交3| www欧美成人18+| 欧美综合在线视频| 精品一区二区三区香蕉蜜桃| 亚洲欧美偷拍卡通变态| 精品国产一区二区三区av性色| 97国产一区二区| 韩国中文字幕2020精品| 亚洲一区二区视频| 日本一区二区三区国色天香| 欧美人伦禁忌dvd放荡欲情| 国产a久久麻豆| 青草国产精品久久久久久| 亚洲天堂av一区| 精品国产一区二区在线观看| 欧美亚洲尤物久久| 国产69精品久久777的优势| 视频一区二区三区入口| 中文字幕在线观看一区| 久久久噜噜噜久久人人看| 欧美挠脚心视频网站| 99久久精品国产毛片| 国产一区二区三区在线观看精品| 亚洲成人精品在线观看|