首页 > 编程 > Golang > 正文

go语言制作一个gif动态图

2020-04-01 19:15:05
字体:
来源:转载
供稿:网友

这篇文章主要介绍了go制作一个gif动态图的相关资料,需要的朋友可以参考下

如题,关键不是图怎么样,而是说,go可以拿来实现动态图验证码,加上go支持cgi、fcgi,完全可以做个exe拿去增补现有的服务器么。

ball.go

 

  1. package main 
  2. import ( 
  3. "github.com/hydra13142/cube" 
  4. "github.com/hydra13142/geom" 
  5. "github.com/hydra13142/paint" 
  6. "image" 
  7. "image/color/palette" 
  8. "image/gif" 
  9. "math" 
  10. "os" 
  11. var ( 
  12. pln *cube.Plain 
  13. unx cube.Vector 
  14. uny cube.Vector 
  15. const ( 
  16. H = 18 
  17. W = 36 
  18. func init() { 
  19. pln, _ = cube.NewPlain(cube.Point{}, cube.Vector{4, 4, 3}) 
  20. uny = cube.FromTo(cube.Point{}, pln.VerticalPoint(cube.Point{0, 0, 10})).Unit() 
  21. unx = cube.OuterProduct(uny, cube.Vector{4, 4, 3}).Unit() 
  22. func main() { 
  23. var x [H + 1][W]cube.Point 
  24. var y [H + 1][W]geom.Point 
  25. dz := math.Pi / H 
  26. dxy := math.Pi * 2 / W 
  27. for i := 0; i <= H; i++ { 
  28. az := float64(i)*dz - math.Pi/2 
  29. r := 140 * math.Cos(az) 
  30. z := 140 * math.Sin(az) 
  31. for j := 0; j < W; j++ { 
  32. axy := float64(j) * dxy 
  33. x[i][j] = cube.Point{math.Cos(axy) * r, math.Sin(axy) * r, z} 
  34. pics := make([]*image.Paletted, 0, 20) 
  35. img := paint.Image{ 
  36. FR: paint.Green, 
  37. BG: paint.White, 
  38. stp := dxy / 20 
  39. delay := make([]int, 0, 20) 
  40. for t := 0; t < 20; t++ { 
  41. img.Image = image.NewPaletted(image.Rect(0, 0, 300, 300), palette.Plan9) 
  42. for i := 0; i <= H; i++ { 
  43. for j := 0; j < W; j++ { 
  44. ox := cube.FromTo(cube.Point{}, x[i][j]) 
  45. y[i][j] = geom.Point{cube.InnerProduct(ox, unx), cube.InnerProduct(ox, uny)} 
  46. a, b := x[i][j].X, x[i][j].Y 
  47. x[i][j].X = a*math.Cos(stp) - b*math.Sin(stp) 
  48. x[i][j].Y = b*math.Cos(stp) + a*math.Sin(stp) 
  49. for i := 0; i < H; i++ { 
  50. for j := 0; j < W; j++ { 
  51. img.Line( 
  52. 150+int(y[i][j].X), 
  53. 150-int(y[i][j].Y), 
  54. 150+int(y[i][(j+1)%W].X), 
  55. 150-int(y[i][(j+1)%W].Y), 
  56. img.Line( 
  57. 150+int(y[i][j].X), 
  58. 150-int(y[i][j].Y), 
  59. 150+int(y[i+1][j].X), 
  60. 150-int(y[i+1][j].Y), 
  61. pics = append(pics, img.Image.(*image.Paletted)) 
  62. delay = append(delay, 5) 
  63. file, _ := os.Create("ball.gif"
  64. defer file.Close() 
  65. gif.EncodeAll(file, &gif.GIF{ 
  66. Image: pics, 
  67. Delay: delay, 
  68. LoopCount: 5 * len(delay), 
  69. }) 

woniu.go

 

 
  1. package main 
  2. import ( 
  3. "github.com/hydra13142/cube" 
  4. "github.com/hydra13142/geom" 
  5. "github.com/hydra13142/paint" 
  6. "image" 
  7. "image/color/palette" 
  8. "image/gif" 
  9. "math" 
  10. "os" 
  11. var ( 
  12. pln *cube.Plain 
  13. unx, uny cube.Vector 
  14. const ( 
  15. H = 18 
  16. W = 96 
  17. func init() { 
  18. pln, _ = cube.NewPlain(cube.Point{}, cube.Vector{2, 2, 1}) 
  19. uny = cube.FromTo(cube.Point{}, pln.VerticalPoint(cube.Point{0, 0, 10})).Unit() 
  20. unx = cube.OuterProduct(uny, cube.Vector{2, 2, 1}).Unit() 
  21. func main() { 
  22. var x [H + 1][W]cube.Point 
  23. var y [H + 1][W]geom.Point 
  24. dz := math.Pi / H 
  25. dxy := math.Pi * 4 / W 
  26. for i := 0; i <= H; i++ { 
  27. az := float64(i)*dz - math.Pi/2 
  28. r := 300 * math.Cos(az) 
  29. z := 100 * math.Sin(az) 
  30. for j := 0; j < W; j++ { 
  31. axy := float64(j) * dxy 
  32. R := float64(j) * r / W 
  33. x[i][j] = cube.Point{math.Cos(axy) * R, math.Sin(axy) * R, z} 
  34. pics := make([]*image.Paletted, 0, 20) 
  35. img := paint.Image{ 
  36. FR: paint.Green, 
  37. BG: paint.White, 
  38. stp := math.Pi / W 
  39. delay := make([]int, 0, 2*W) 
  40. for t := 0; t < 2*W; t++ { 
  41. img.Image = image.NewPaletted(image.Rect(0, 0, 600, 300), palette.Plan9) 
  42. for i := 0; i <= H; i++ { 
  43. for j := 0; j < W; j++ { 
  44. ox := cube.FromTo(cube.Point{}, x[i][j]) 
  45. y[i][j] = geom.Point{cube.InnerProduct(ox, unx), cube.InnerProduct(ox, uny)} 
  46. a, b := x[i][j].X, x[i][j].Y 
  47. x[i][j].X = a*math.Cos(stp) - b*math.Sin(stp) 
  48. x[i][j].Y = b*math.Cos(stp) + a*math.Sin(stp) 
  49. img.Line( 
  50. 300+int(y[0][0].X), 
  51. 150-int(y[0][0].Y), 
  52. 300+int(y[H][0].X), 
  53. 150-int(y[H][0].Y), 
  54. for i := 0; i < H; i++ { 
  55. for j := 1; j < W; j++ { 
  56. img.Line( 
  57. 300+int(y[i][j].X), 
  58. 150-int(y[i][j].Y), 
  59. 300+int(y[i][j-1].X), 
  60. 150-int(y[i][j-1].Y), 
  61. img.Line( 
  62. 300+int(y[i][j].X), 
  63. 150-int(y[i][j].Y), 
  64. 300+int(y[i+1][j].X), 
  65. 150-int(y[i+1][j].Y), 
  66. pics = append(pics, img.Image.(*image.Paletted)) 
  67. delay = append(delay, 5) 
  68. file, _ := os.Create("woniu.gif"
  69. defer file.Close() 
  70. gif.EncodeAll(file, &gif.GIF{ 
  71. Image: pics, 
  72. Delay: delay, 
  73. LoopCount: 5 * len(delay), 
  74. }) 

rotate.go

 

 
  1. package main 
  2. import ( 
  3. "github.com/hydra13142/cube" 
  4. "github.com/hydra13142/geom" 
  5. "github.com/hydra13142/paint" 
  6. "image" 
  7. "image/color/palette" 
  8. "image/gif" 
  9. "math" 
  10. "os" 
  11. var ( 
  12. pln *cube.Plain 
  13. unx, uny cube.Vector 
  14. const ( 
  15. H = 9 
  16. W = 36 
  17. func init() { 
  18. pln, _ = cube.NewPlain(cube.Point{}, cube.Vector{4, 4, 3}) 
  19. uny = cube.FromTo(cube.Point{}, pln.VerticalPoint(cube.Point{0, 0, 10})).Unit() 
  20. unx = cube.OuterProduct(uny, cube.Vector{4, 4, 3}).Unit() 
  21. func main() { 
  22. var x [H*W + 1]cube.Point 
  23. var y [H*W + 1]geom.Point 
  24. dxy := (math.Pi * 2) / W 
  25. dz := math.Pi / H 
  26. for i := 0; i <= H*W; i++ { 
  27. az := float64(i)*dz/W - math.Pi/2 
  28. r := 140 * math.Cos(az) 
  29. z := 140 * math.Sin(az)  
  30. axy := float64(i) * dxy 
  31. x[i] = cube.Point{math.Cos(axy) * r, math.Sin(axy) * r, z} 
  32. pics := make([]*image.Paletted, 0, 20) 
  33. img := paint.Image{ 
  34. FR: paint.Green, 
  35. BG: paint.White, 
  36. stp := math.Pi * 2 / (W * 3) 
  37. delay := make([]int, 0, 3*W) 
  38. for t := 0; t < 3*W; t++ { 
  39. img.Image = image.NewPaletted(image.Rect(0, 0, 300, 300), palette.Plan9) 
  40. for i := 0; i <= H*W; i++ { 
  41. ox := cube.FromTo(cube.Point{}, x[i]) 
  42. y[i] = geom.Point{cube.InnerProduct(ox, unx), cube.InnerProduct(ox, uny)} 
  43. a, b := x[i].X, x[i].Z 
  44. x[i].X = a*math.Cos(stp) - b*math.Sin(stp) 
  45. x[i].Z = b*math.Cos(stp) + a*math.Sin(stp) 
  46. img.Line( 
  47. 150+int(y[0].X), 
  48. 150-int(y[0].Y), 
  49. 150+int(y[H*W].X), 
  50. 150-int(y[H*W].Y), 
  51. for i := 0; i < H*W; i++ { 
  52. img.Line( 
  53. 150+int(y[i].X), 
  54. 150-int(y[i].Y), 
  55. 150+int(y[i+1].X), 
  56. 150-int(y[i+1].Y), 
  57. pics = append(pics, img.Image.(*image.Paletted)) 
  58. delay = append(delay, 8) 
  59. file, _ := os.Create("rotate.gif"
  60. defer file.Close() 
  61. gif.EncodeAll(file, &gif.GIF{ 
  62. Image: pics, 
  63. Delay: delay, 
  64. LoopCount: 5 * len(delay), 
  65. }) 

以上就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表