commit b03790f796bb3a3a78e71d00e60f0c35e99455e2
Author: Rzy <465386466@qq.com>
Date: Thu Jun 12 16:06:02 2025 +0800
first
diff --git a/.idea/.gitignore b/.idea/.gitignore
new file mode 100644
index 0000000..35410ca
--- /dev/null
+++ b/.idea/.gitignore
@@ -0,0 +1,8 @@
+# 默认忽略的文件
+/shelf/
+/workspace.xml
+# 基于编辑器的 HTTP 客户端请求
+/httpRequests/
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
diff --git a/.idea/makePpt.iml b/.idea/makePpt.iml
new file mode 100644
index 0000000..5e764c4
--- /dev/null
+++ b/.idea/makePpt.iml
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
new file mode 100644
index 0000000..a80b5c7
--- /dev/null
+++ b/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/a.md b/a.md
new file mode 100644
index 0000000..da70c26
--- /dev/null
+++ b/a.md
@@ -0,0 +1,3 @@
+```json
+{"outline":{"sections":[{"contents":[{"items":[{"items":["三级章节内容"],"title":"三级章节标题"}],"subtitle":"二级章节副标题","title":"二级章节标题"}],"subtitle":"章节副标题","title":"章节标题"}],"subtitle":"ppt副标题","title":"ppt标题"}}
+```
diff --git a/coze.go b/coze.go
new file mode 100644
index 0000000..b4904d8
--- /dev/null
+++ b/coze.go
@@ -0,0 +1,134 @@
+package main
+
+import (
+ "context"
+ "encoding/json"
+ "fmt"
+ "github.com/coze-dev/coze-go"
+ "net/http"
+ "time"
+)
+
+var (
+ token = "pat_3Qryy0Dgo1nA0eZ9CoTlC4GDQECphJcD7ZVWF5iSQ1qXMahca8xeWU08NFv9i8XY"
+ api = "https://api.coze.cn"
+)
+
+type OutlineResp struct {
+ Sections []struct {
+ Contents []struct {
+ Items []struct {
+ Items []string `json:"items"`
+ Title string `json:"title"`
+ } `json:"items"`
+ Subtitle string `json:"subtitle"`
+ Title string `json:"title"`
+ } `json:"contents"`
+ Subtitle string `json:"subtitle"`
+ Title string `json:"title"`
+ } `json:"sections"`
+ Subtitle string `json:"subtitle"`
+ Title string `json:"title"`
+}
+
+type ThemeResp struct {
+ Data []struct {
+ ID int `json:"id"`
+ Keywords string `json:"keywords"`
+ Thumbnail string `json:"thumbnail"`
+ Title string `json:"title"`
+ Type string `json:"type"`
+ } `json:"data"`
+}
+
+type PptResp struct {
+ FileUrl string `json:"file_url"`
+}
+
+func WorkflowOutline(ctx context.Context, keyword string) (resData OutlineResp, err error) {
+
+ workflowId := "7514159115984617524"
+ auth := coze.NewTokenAuth(token)
+ // Init the Coze client through the access_token.
+ cozeCli := coze.NewCozeAPI(auth, coze.WithBaseURL(api), coze.WithHttpClient(&http.Client{
+ Timeout: time.Second * 5000,
+ }))
+
+ // if your workflow need input params, you can send them by map
+ data := map[string]interface{}{
+ "keyword": keyword,
+ }
+
+ req := &coze.RunWorkflowsReq{
+ WorkflowID: workflowId,
+ Parameters: data,
+ IsAsync: false,
+ }
+
+ resp, err := cozeCli.Workflows.Runs.Create(ctx, req)
+
+ if err != nil {
+ return
+ }
+ json.Unmarshal([]byte(resp.Data), &resData)
+ return
+}
+
+func WorkflowTheme(ctx context.Context, keyword string) (res ThemeResp, err error) {
+
+ workflowId := "7514593043828539407"
+ auth := coze.NewTokenAuth(token)
+ // Init the Coze client through the access_token.
+ cozeCli := coze.NewCozeAPI(auth, coze.WithBaseURL(api), coze.WithHttpClient(&http.Client{
+ Timeout: time.Second * 5000,
+ }))
+
+ // if your workflow need input params, you can send them by map
+ data := map[string]interface{}{
+ "keyword": keyword,
+ }
+
+ req := &coze.RunWorkflowsReq{
+ WorkflowID: workflowId,
+ Parameters: data,
+ IsAsync: false,
+ }
+
+ resp, err := cozeCli.Workflows.Runs.Create(ctx, req)
+ fmt.Println(resp, req)
+ if err != nil {
+ return
+ }
+ err = json.Unmarshal([]byte(resp.Data), &res)
+ return
+}
+
+func WorkflowPpt(ctx context.Context, outline string, themeId int) (res PptResp, err error) {
+
+ workflowId := "7514654025384951820"
+ auth := coze.NewTokenAuth(token)
+ // Init the Coze client through the access_token.
+ cozeCli := coze.NewCozeAPI(auth, coze.WithBaseURL(api), coze.WithHttpClient(&http.Client{
+ Timeout: time.Second * 5000,
+ }))
+
+ // if your workflow need input params, you can send them by map
+ data := map[string]interface{}{
+ "outline": outline,
+ "themeId": themeId,
+ }
+
+ req := &coze.RunWorkflowsReq{
+ WorkflowID: workflowId,
+ Parameters: data,
+ IsAsync: false,
+ }
+ fmt.Println(themeId)
+ resp, err := cozeCli.Workflows.Runs.Create(ctx, req)
+ fmt.Println(resp, err)
+ if err != nil {
+ return
+ }
+ err = json.Unmarshal([]byte(resp.Data), &res)
+ return
+}
diff --git a/coze_test.go b/coze_test.go
new file mode 100644
index 0000000..b267dd5
--- /dev/null
+++ b/coze_test.go
@@ -0,0 +1,10 @@
+package main
+
+import (
+ "context"
+ "testing"
+)
+
+func TestFlowApi(t *testing.T) {
+ Workflow(context.Background(), "手搓核弹")
+}
diff --git a/go.mod b/go.mod
new file mode 100644
index 0000000..b5cc243
--- /dev/null
+++ b/go.mod
@@ -0,0 +1,42 @@
+module makePpt
+
+go 1.24.3
+
+require fyne.io/fyne/v2 v2.6.1
+
+require (
+ fyne.io/systray v1.11.0 // indirect
+ github.com/BurntSushi/toml v1.4.0 // indirect
+ github.com/coze-dev/coze-go v0.0.0-20250604025746-0d3b62f445d2 // indirect
+ github.com/davecgh/go-spew v1.1.1 // indirect
+ github.com/fredbi/uri v1.1.0 // indirect
+ github.com/fsnotify/fsnotify v1.7.0 // indirect
+ github.com/fyne-io/gl-js v0.1.0 // indirect
+ github.com/fyne-io/glfw-js v0.2.0 // indirect
+ github.com/fyne-io/image v0.1.1 // indirect
+ github.com/fyne-io/oksvg v0.1.0 // indirect
+ github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 // indirect
+ github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240506104042-037f3cc74f2a // indirect
+ github.com/go-text/render v0.2.0 // indirect
+ github.com/go-text/typesetting v0.2.1 // indirect
+ github.com/godbus/dbus/v5 v5.1.0 // indirect
+ github.com/golang-jwt/jwt v3.2.2+incompatible // indirect
+ github.com/hack-pad/go-indexeddb v0.3.2 // indirect
+ github.com/hack-pad/safejs v0.1.0 // indirect
+ github.com/jeandeaual/go-locale v0.0.0-20241217141322-fcc2cadd6f08 // indirect
+ github.com/jsummers/gobmp v0.0.0-20230614200233-a9de23ed2e25 // indirect
+ github.com/kr/text v0.2.0 // indirect
+ github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646 // indirect
+ github.com/nicksnyder/go-i18n/v2 v2.5.1 // indirect
+ github.com/pmezard/go-difflib v1.0.0 // indirect
+ github.com/rymdport/portal v0.4.1 // indirect
+ github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c // indirect
+ github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef // indirect
+ github.com/stretchr/testify v1.10.0 // indirect
+ github.com/yuin/goldmark v1.7.8 // indirect
+ golang.org/x/image v0.24.0 // indirect
+ golang.org/x/net v0.35.0 // indirect
+ golang.org/x/sys v0.30.0 // indirect
+ golang.org/x/text v0.22.0 // indirect
+ gopkg.in/yaml.v3 v3.0.1 // indirect
+)
diff --git a/go.sum b/go.sum
new file mode 100644
index 0000000..b4718a1
--- /dev/null
+++ b/go.sum
@@ -0,0 +1,84 @@
+fyne.io/fyne/v2 v2.6.1 h1:kjPJD4/rBS9m2nHJp+npPSuaK79yj6ObMTuzR6VQ1Is=
+fyne.io/fyne/v2 v2.6.1/go.mod h1:YZt7SksjvrSNJCwbWFV32WON3mE1Sr7L41D29qMZ/lU=
+fyne.io/systray v1.11.0 h1:D9HISlxSkx+jHSniMBR6fCFOUjk1x/OOOJLa9lJYAKg=
+fyne.io/systray v1.11.0/go.mod h1:RVwqP9nYMo7h5zViCBHri2FgjXF7H2cub7MAq4NSoLs=
+github.com/BurntSushi/toml v1.4.0 h1:kuoIxZQy2WRRk1pttg9asf+WVv6tWQuBNVmK8+nqPr0=
+github.com/BurntSushi/toml v1.4.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho=
+github.com/coze-dev/coze-go v0.0.0-20250604025746-0d3b62f445d2 h1:2OyH/CtCYSL8qzOS4dxpLWymNF6sZ5yVOsZl54mthG8=
+github.com/coze-dev/coze-go v0.0.0-20250604025746-0d3b62f445d2/go.mod h1:kQAGkjYgJXNCmXDgb32ukpGvkNjM1Z4qHegTu8Eyjb0=
+github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E=
+github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
+github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/felixge/fgprof v0.9.3 h1:VvyZxILNuCiUCSXtPtYmmtGvb65nqXh2QFWc0Wpf2/g=
+github.com/felixge/fgprof v0.9.3/go.mod h1:RdbpDgzqYVh/T9fPELJyV7EYJuHB55UTEULNun8eiPw=
+github.com/fredbi/uri v1.1.0 h1:OqLpTXtyRg9ABReqvDGdJPqZUxs8cyBDOMXBbskCaB8=
+github.com/fredbi/uri v1.1.0/go.mod h1:aYTUoAXBOq7BLfVJ8GnKmfcuURosB1xyHDIfWeC/iW4=
+github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA=
+github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM=
+github.com/fyne-io/gl-js v0.1.0 h1:8luJzNs0ntEAJo+8x8kfUOXujUlP8gB3QMOxO2mUdpM=
+github.com/fyne-io/gl-js v0.1.0/go.mod h1:ZcepK8vmOYLu96JoxbCKJy2ybr+g1pTnaBDdl7c3ajI=
+github.com/fyne-io/glfw-js v0.2.0 h1:8GUZtN2aCoTPNqgRDxK5+kn9OURINhBEBc7M4O1KrmM=
+github.com/fyne-io/glfw-js v0.2.0/go.mod h1:Ri6te7rdZtBgBpxLW19uBpp3Dl6K9K/bRaYdJ22G8Jk=
+github.com/fyne-io/image v0.1.1 h1:WH0z4H7qfvNUw5l4p3bC1q70sa5+YWVt6HCj7y4VNyA=
+github.com/fyne-io/image v0.1.1/go.mod h1:xrfYBh6yspc+KjkgdZU/ifUC9sPA5Iv7WYUBzQKK7JM=
+github.com/fyne-io/oksvg v0.1.0 h1:7EUKk3HV3Y2E+qypp3nWqMXD7mum0hCw2KEGhI1fnBw=
+github.com/fyne-io/oksvg v0.1.0/go.mod h1:dJ9oEkPiWhnTFNCmRgEze+YNprJF7YRbpjgpWS4kzoI=
+github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 h1:5BVwOaUSBTlVZowGO6VZGw2H/zl9nrd3eCZfYV+NfQA=
+github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
+github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240506104042-037f3cc74f2a h1:vxnBhFDDT+xzxf1jTJKMKZw3H0swfWk9RpWbBbDK5+0=
+github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240506104042-037f3cc74f2a/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
+github.com/go-text/render v0.2.0 h1:LBYoTmp5jYiJ4NPqDc2pz17MLmA3wHw1dZSVGcOdeAc=
+github.com/go-text/render v0.2.0/go.mod h1:CkiqfukRGKJA5vZZISkjSYrcdtgKQWRa2HIzvwNN5SU=
+github.com/go-text/typesetting v0.2.1 h1:x0jMOGyO3d1qFAPI0j4GSsh7M0Q3Ypjzr4+CEVg82V8=
+github.com/go-text/typesetting v0.2.1/go.mod h1:mTOxEwasOFpAMBjEQDhdWRckoLLeI/+qrQeBCTGEt6M=
+github.com/go-text/typesetting-utils v0.0.0-20241103174707-87a29e9e6066 h1:qCuYC+94v2xrb1PoS4NIDe7DGYtLnU2wWiQe9a1B1c0=
+github.com/go-text/typesetting-utils v0.0.0-20241103174707-87a29e9e6066/go.mod h1:DDxDdQEnB70R8owOx3LVpEFvpMK9eeH1o2r0yZhFI9o=
+github.com/godbus/dbus/v5 v5.1.0 h1:4KLkAxT3aOY8Li4FRJe/KvhoNFFxo0m6fNuFUO8QJUk=
+github.com/godbus/dbus/v5 v5.1.0/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
+github.com/golang-jwt/jwt v3.2.2+incompatible h1:IfV12K8xAKAnZqdXVzCZ+TOjboZ2keLg81eXfW3O+oY=
+github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I=
+github.com/google/pprof v0.0.0-20211214055906-6f57359322fd h1:1FjCyPC+syAzJ5/2S8fqdZK1R22vvA0J7JZKcuOIQ7Y=
+github.com/google/pprof v0.0.0-20211214055906-6f57359322fd/go.mod h1:KgnwoLYCZ8IQu3XUZ8Nc/bM9CCZFOyjUNOSygVozoDg=
+github.com/hack-pad/go-indexeddb v0.3.2 h1:DTqeJJYc1usa45Q5r52t01KhvlSN02+Oq+tQbSBI91A=
+github.com/hack-pad/go-indexeddb v0.3.2/go.mod h1:QvfTevpDVlkfomY498LhstjwbPW6QC4VC/lxYb0Kom0=
+github.com/hack-pad/safejs v0.1.0 h1:qPS6vjreAqh2amUqj4WNG1zIw7qlRQJ9K10eDKMCnE8=
+github.com/hack-pad/safejs v0.1.0/go.mod h1:HdS+bKF1NrE72VoXZeWzxFOVQVUSqZJAG0xNCnb+Tio=
+github.com/jeandeaual/go-locale v0.0.0-20241217141322-fcc2cadd6f08 h1:wMeVzrPO3mfHIWLZtDcSaGAe2I4PW9B/P5nMkRSwCAc=
+github.com/jeandeaual/go-locale v0.0.0-20241217141322-fcc2cadd6f08/go.mod h1:ZDXo8KHryOWSIqnsb/CiDq7hQUYryCgdVnxbj8tDG7o=
+github.com/jsummers/gobmp v0.0.0-20230614200233-a9de23ed2e25 h1:YLvr1eE6cdCqjOe972w/cYF+FjW34v27+9Vo5106B4M=
+github.com/jsummers/gobmp v0.0.0-20230614200233-a9de23ed2e25/go.mod h1:kLgvv7o6UM+0QSf0QjAse3wReFDsb9qbZJdfexWlrQw=
+github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
+github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
+github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646 h1:zYyBkD/k9seD2A7fsi6Oo2LfFZAehjjQMERAvZLEDnQ=
+github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646/go.mod h1:jpp1/29i3P1S/RLdc7JQKbRpFeM1dOBd8T9ki5s+AY8=
+github.com/nicksnyder/go-i18n/v2 v2.5.1 h1:IxtPxYsR9Gp60cGXjfuR/llTqV8aYMsC472zD0D1vHk=
+github.com/nicksnyder/go-i18n/v2 v2.5.1/go.mod h1:DrhgsSDZxoAfvVrBVLXoxZn/pN5TXqaDbq7ju94viiQ=
+github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs=
+github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno=
+github.com/pkg/profile v1.7.0 h1:hnbDkaNWPCLMO9wGLdBFTIZvzDrDfBM2072E1S9gJkA=
+github.com/pkg/profile v1.7.0/go.mod h1:8Uer0jas47ZQMJ7VD+OHknK4YDY07LPUC6dEvqDjvNo=
+github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
+github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/rymdport/portal v0.4.1 h1:2dnZhjf5uEaeDjeF/yBIeeRo6pNI2QAKm7kq1w/kbnA=
+github.com/rymdport/portal v0.4.1/go.mod h1:kFF4jslnJ8pD5uCi17brj/ODlfIidOxlgUDTO5ncnC4=
+github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c h1:km8GpoQut05eY3GiYWEedbTT0qnSxrCjsVbb7yKY1KE=
+github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c/go.mod h1:cNQ3dwVJtS5Hmnjxy6AgTPd0Inb3pW05ftPSX7NZO7Q=
+github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef h1:Ch6Q+AZUxDBCVqdkI8FSpFyZDtCVBc2VmejdNrm5rRQ=
+github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef/go.mod h1:nXTWP6+gD5+LUJ8krVhhoeHjvHTutPxMYl5SvkcnJNE=
+github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
+github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
+github.com/yuin/goldmark v1.7.8 h1:iERMLn0/QJeHFhxSt3p6PeN9mGnvIKSpG9YYorDMnic=
+github.com/yuin/goldmark v1.7.8/go.mod h1:uzxRWxtg69N339t3louHJ7+O03ezfj6PlliRlaOzY1E=
+golang.org/x/image v0.24.0 h1:AN7zRgVsbvmTfNyqIbbOraYL8mSwcKncEj8ofjgzcMQ=
+golang.org/x/image v0.24.0/go.mod h1:4b/ITuLfqYq1hqZcjofwctIhi7sZh2WaCjvsBNjjya8=
+golang.org/x/net v0.35.0 h1:T5GQRQb2y08kTAByq9L4/bz8cipCdA8FbRTXewonqY8=
+golang.org/x/net v0.35.0/go.mod h1:EglIi67kWsHKlRzzVMUD93VMSWGFOMSZgxFjparz1Qk=
+golang.org/x/sys v0.30.0 h1:QjkSwP/36a20jFYWkSue1YwXzLmsV5Gfq7Eiy72C1uc=
+golang.org/x/sys v0.30.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
+golang.org/x/text v0.22.0 h1:bofq7m3/HAFvbF51jz3Q9wLg3jkvSPuiZu/pD1XwgtM=
+golang.org/x/text v0.22.0/go.mod h1:YRoo4H8PVmsu+E3Ou7cqLVH8oXWIHVoX0jqUWALQhfY=
+gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f h1:BLraFXnmrev5lT+xlilqcH8XK9/i0At2xKjWk4p6zsU=
+gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
+gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
diff --git a/icon.png b/icon.png
new file mode 100644
index 0000000..5fe9211
Binary files /dev/null and b/icon.png differ
diff --git a/img/1.png b/img/1.png
new file mode 100644
index 0000000..c7d4283
Binary files /dev/null and b/img/1.png differ
diff --git a/main.go b/main.go
new file mode 100644
index 0000000..67c4385
--- /dev/null
+++ b/main.go
@@ -0,0 +1,55 @@
+package main
+
+import (
+ "context"
+ "fyne.io/fyne/v2"
+ "fyne.io/fyne/v2/app"
+
+ "fyne.io/fyne/v2/container"
+ "fyne.io/fyne/v2/theme"
+ "fyne.io/fyne/v2/widget"
+)
+
+type themeObj struct {
+ id int
+}
+
+func main() {
+ var (
+ content []fyne.CanvasObject
+ theme themeObj
+ )
+ myWindow, myApp := InitApp()
+ ctx := context.Background()
+ keyword := widget.NewEntry()
+ keyword.SetPlaceHolder("请输入主题,eg:核弹的手搓过程")
+ //大纲
+ outLine, input := ModuleOutline(ctx, keyword, myApp)
+ //主题
+ themes := ModuleTheme(ctx, keyword, &theme)
+ //生成ppt
+ ppt := ModulePpt(ctx, input, &theme, keyword)
+ //添加到窗口
+
+ content = append(content, keyword)
+ content = append(content, outLine...)
+ content = append(content, themes...)
+ content = append(content, ppt...)
+ myWindow.SetContent(container.NewVBox(
+ content...,
+ ),
+ )
+ //// 显示并运行窗口
+ myWindow.ShowAndRun()
+
+}
+
+func InitApp() (fyne.Window, fyne.App) {
+ myApp := app.New()
+ myApp.Settings().SetTheme(theme.DefaultTheme())
+ // 创建一个窗口
+ myWindow := myApp.NewWindow("蓝色兄弟ppt创建测试版")
+ myWindow.Resize(fyne.NewSize(800, 500))
+ myWindow.CenterOnScreen()
+ return myWindow, myApp
+}
diff --git a/module.go b/module.go
new file mode 100644
index 0000000..b7ecf24
--- /dev/null
+++ b/module.go
@@ -0,0 +1,181 @@
+package main
+
+import (
+ "context"
+ "encoding/json"
+ "fmt"
+ "fyne.io/fyne/v2"
+ "fyne.io/fyne/v2/canvas"
+ "fyne.io/fyne/v2/widget"
+)
+
+type themeList struct {
+ Id int
+ url string
+}
+
+func ModuleOutline(ctx context.Context, keyword *widget.Entry, app fyne.App) (object []fyne.CanvasObject, preview *widget.Entry) {
+ preview = widget.NewMultiLineEntry()
+ label := widget.NewLabel("")
+ label.Hide()
+
+ errLabel := widget.NewLabel("")
+ errLabel.Hide()
+ keywordButton := widget.NewButton("生成大纲", nil)
+ keywordButton.OnTapped = func() {
+ label.Hide()
+ if keyword.Text == "" {
+ label.SetText("请输入主题")
+ label.Show()
+ return
+ }
+ keywordButton.SetText("大纲生成中...生成需要40-90秒,请耐心等待")
+ keywordButton.Disable()
+ go func() {
+ pptInfo, err := WorkflowOutline(ctx, keyword.Text)
+ if err != nil {
+ errLabel.SetText(fmt.Sprintf("生成失败:%s", err.Error()))
+ errLabel.Show()
+ }
+
+ formattedJSON, _ := json.MarshalIndent(pptInfo, "", " ")
+ fyne.Do(func() {
+ preview.SetText("")
+ preview.SetText(string(formattedJSON))
+ preview.SetMinRowsVisible(20)
+ preview.Show()
+
+ keywordButton.SetText("生成大纲")
+ keywordButton.Enable()
+ })
+ }()
+ }
+ return []fyne.CanvasObject{keyword, label, keywordButton, errLabel, preview}, preview
+}
+
+func ModuleTheme(ctx context.Context, keyword *widget.Entry, themeObj *themeObj) []fyne.CanvasObject {
+ var (
+ selectBox = widget.NewSelect(nil, nil)
+ img = canvas.NewImageFromFile("./img/1.png")
+ )
+ img.SetMinSize(fyne.NewSize(200, 200))
+ img.FillMode = canvas.ImageFillContain
+ img.Hide()
+ errLabel := widget.NewLabel("")
+ errLabel.Hide()
+ themeButton := widget.NewButton("生成主题", nil)
+ themeButton.OnTapped = func() {
+ errLabel.Hide()
+ if keyword.Text == "" {
+ errLabel.SetText("请输入主题")
+ errLabel.Show()
+ return
+ }
+ themeButton.SetText("主题生成中...")
+ themeButton.Disable()
+ themes, err := WorkflowTheme(ctx, keyword.Text)
+ fmt.Println(themes)
+ fmt.Println(err)
+ if err != nil || len(themes.Data) == 0 {
+ errLabel.SetText(fmt.Sprintf("生成失败:%v", err))
+ errLabel.Show()
+ themeButton.SetText("生成主题")
+ themeButton.Enable()
+ return
+ }
+ var (
+ themeMap = make(map[string]themeList, len(themes.Data))
+ themeNameSlice = make([]string, len(themes.Data))
+ )
+ if len(themes.Data) == 0 {
+ return
+ }
+
+ for k, theme := range themes.Data {
+ themeMap[theme.Title] = themeList{
+ Id: theme.ID,
+ url: theme.Thumbnail,
+ }
+ fmt.Println(theme.Title)
+ themeNameSlice[k] = theme.Title
+ }
+
+ selectBox.ClearSelected()
+ selectBox.SetOptions(themeNameSlice)
+ selectBox.SetSelectedIndex(0)
+ img.File = GetImg(themes.Data[0].Thumbnail)
+ themeObj.id = themes.Data[0].ID
+ img.Refresh()
+ img.Show()
+ selectBox.OnChanged = func(value string) {
+ themeObj.id = themeMap[value].Id
+ img.File = GetImg(themeMap[value].url)
+ fmt.Println(themeObj.id, img.File)
+ img.Refresh()
+ img.Show()
+ }
+ selectBox.Refresh()
+ selectBox.Show()
+ themeButton.SetText("生成主题")
+ themeButton.Enable()
+ }
+
+ return []fyne.CanvasObject{themeButton, errLabel, img, selectBox}
+
+}
+
+func ModulePpt(ctx context.Context, sectionInput *widget.Entry, themeObj *themeObj, keyword *widget.Entry) []fyne.CanvasObject {
+ hyperlink := widget.NewHyperlink("点击查看ppt", nil)
+ hyperlink.Hide()
+
+ errLabel := widget.NewLabel("")
+ errLabel.Hide()
+ createButton := widget.NewButton("生成ppt", nil)
+ createButton.OnTapped = func() {
+ if sectionInput.Text == "" {
+ errLabel.SetText("请输入大纲")
+ errLabel.Show()
+ return
+ }
+ if themeObj.id == 0 {
+ errLabel.SetText("请选择主题")
+ errLabel.Show()
+ return
+ }
+ createButton.SetText("ppt生成中...")
+ createButton.Disable()
+ go func() {
+ ppt, err := WorkflowPpt(ctx, sectionInput.Text, themeObj.id)
+
+ if err != nil {
+ errLabel.SetText(fmt.Sprintf("生成失败:%s", err.Error()))
+ errLabel.Show()
+ return
+ }
+ fileUrl := ppt.FileUrl
+ //fileUrl := "https://lf-bot-studio-plugin-resource.coze.cn/obj/bot-studio-platform-plugin-tos/artist/image/a37e601ca0f64de8844279a138210c5e.ppt"
+
+ file := DownloadPpt(fileUrl, keyword.Text)
+ fmt.Println(fileUrl)
+ fmt.Println("文件地址:" + file)
+ fyne.Do(func() {
+ errLabel.SetText("ppt生成成功")
+ hyperlink.SetURLFromString(file)
+ hyperlink.Refresh()
+ hyperlink.Show()
+ createButton.SetText("生成ppt")
+ createButton.Enable()
+ })
+ }()
+
+ }
+ return []fyne.CanvasObject{createButton, errLabel, hyperlink}
+
+}
+func Eg() string {
+ return "\n================================================================================\n\n## 1. 核弹的基础知识\n##### 🌈核弹的起源、分类及其基本原理\n\n---\n\n## 1.1 核能的发现与发展\n##### 从核裂变到核聚变的历史进程\n\n🌟**核裂变的发现**: 揭示核裂变原理及其对科学界的影响,奠定核能利用的基础。\n\n🌟**早期核能研究**: 回顾二战期间核能开发的关键事件与技术突破,推动历史进程。\n\n🌟**核聚变的研究**: 探讨核聚变理论发展及其实验进展,展望其未来潜力与挑战。\n\n🌟**核技术的演变**: 总结从核裂变到核聚变的技术进步,分析其对社会的深远意义。\n\n---\n\n## 1.2 核弹的类型与特点\n##### 原子弹、氢弹及中子弹的区别与应用场景\n\n🌟**原子弹原理**: 介绍原子弹的基本工作原理及裂变反应过程,分析其在军事中的应用特点。\n\n🌟**氢弹构造**: 阐述氢弹的聚变反应机制,探讨其威力远超原子弹的原因及战略意义。\n\n🌟**中子弹特性**: 解释中子弹的设计理念,强调其高辐射低爆炸的特点及其特殊用途。\n\n🌟**各类型对比**: 对比原子弹、氢弹和中子弹在技术实现和杀伤效果上的主要差异。\n\n🌟**应用场景分析**: 分析三种核弹在不同作战环境下的适用性及可能带来的后果。\n\n🌟**发展趋势展望**: 探讨未来核弹技术发展方向及国际社会对其使用的限制与管控。\n\n---\n\n## 1.3 核弹的工作原理\n##### 裂变反应与聚变反应的核心机制\n\n🌟**裂变反应基础**: 介绍原子核裂变过程及链式反应形成原理。\n\n🌟**聚变反应机制**: 解析轻核聚变条件及其释放能量的核心过程。\n\n🌟**反应触发方式**: 探讨如何通过引爆装置启动核反应过程。\n\n🌟**材料与临界质量**: 分析核材料特性及达到链式反应所需的临界条件。\n\n🌟**能量释放过程**: 描述核反应中能量的转化与释放的具体步骤。\n\n🌟**反应控制技术**: 研究在实验条件下对核反应速率的控制方法。\n\n🌟**反应产物分析**: 总结核反应后生成物的种类及其放射性特征。\n\n🌟**安全防护措施**: 讨论核反应过程中防止辐射泄漏的技术手段。\n\n---\n\n## 1.4 核弹的历史背景\n##### 第二次世界大战期间核武器的研发历程\n\n🌟**二战核研发开端**: 描述二战期间核武器研发的起因与初期探索。\n\n🌟**曼哈顿计划详情**: 介绍美国曼哈顿计划的核心内容及关键进展。\n\n🌟**核武时代序幕**: 总结二战后核武器对国际局势的影响及后续发展。\n\n---\n\n## 1.5 核武器对全球的影响\n##### 冷战时期核威慑与现代国际关系\n\n🌟**冷战核威慑**: 冷战期间核武器如何形成相互确保摧毁的威慑态势。\n\n🌟**核军备竞赛**: 各大国在冷战时期的核武器研发与部署竞争及其后果。\n\n🌟**现代核战略**: 当前国际关系中核武器的角色与影响,包括核裁军努力。\n\n🌟**全球安全挑战**: 核武器对全球安全的持续威胁及国际合作应对措施。\n\n\n================================================================================\n\n## 2. 模拟核弹的设计与构建\n##### 🌈理解核弹设计的关键要素\n\n---\n\n## 2.1 核材料的选择与制备\n##### 铀-235和钚-239的提取与纯化技术\n\n🌟**铀-235提取技术**: 介绍铀-235的提取方法,包括气体扩散和离心法。\n\n🌟**钚-239制备工艺**: 讲解钚-239的生产流程,涉及反应堆中铀-238的转化。\n\n🌟**材料纯化步骤**: 描述核材料纯化的关键步骤,确保高纯度标准。\n\n🌟**安全处理措施**: 强调在核材料制备过程中必须遵循的安全规范。\n\n🌟**质量控制体系**: 阐述质量检测与控制方法,保证材料符合设计要求。\n\n---\n\n## 2.2 核装置的核心结构\n##### 触发器、反射层及引爆系统的功能\n\n🌟**触发器设计**: 揭示触发器的工作原理及其在核装置中的关键作用,确保精准引爆。\n\n🌟**反射层功能**: 分析反射层如何提高核反应效率,减少中子流失,增强爆炸威力。\n\n🌟**引爆系统组成**: 详解引爆系统的结构与功能,确保各部件协同工作以实现可靠引爆。\n\n---\n\n## 2.3 核爆炸的触发机制\n##### 中子源的作用与临界质量的计算\n\n🌟**中子源功能解析**: 解释中子源在核爆炸触发中的关键作用及类型选择。\n\n🌟**临界质量计算方法**: 探讨如何精确计算不同材料的临界质量以确保链式反应。\n\n🌟**触发机制设计原理**: 分析触发机制的设计原则及其对核爆炸效率的影响。\n\n---\n\n## 2.4 核弹的安全性设计\n##### 如何防止意外引爆与误用风险\n\n🌟**防护机制**: 设计多重防护确保核弹不会因意外触发引爆。\n\n🌟**授权系统**: 建立严格授权流程避免核弹被未经授权使用。\n\n🌟**环境监测**: 通过环境感应技术防止非正常条件下启动核弹。\n\n🌟**故障检测**: 实施实时故障检测减少因技术问题导致的误用风险。\n\n---\n\n## 2.5 核试验的模拟过程\n##### 数字化仿真与理论验证的重要性\n\n🌟**仿真模型构建**: 探讨数字化仿真在核试验中的应用,建立精确的物理模型。\n\n🌟**数据分析与验证**: 利用理论计算验证仿真结果,确保数据准确性与可靠性。\n\n🌟**爆炸过程模拟**: 模拟核弹爆炸全过程,分析能量释放与冲击波传播特性。\n\n🌟**环境影响评估**: 数字化仿真预测核试验对环境的影响,提供决策依据。\n\n🌟**技术优化改进**: 通过仿真结果反馈,不断优化设计提高核弹性能。\n\n\n================================================================================\n\n## 3. 核弹的技术挑战与科学突破\n##### 🌈克服核武器研发中的技术难题\n\n---\n\n## 3.1 材料科学的进展\n##### 新型核材料的研究与应用\n\n🌟**新型核材料研究**: 探讨用于核弹的新型核材料特性及其潜在应用价值。\n\n🌟**材料稳定性提升**: 分析如何通过技术手段提高核材料在极端条件下的稳定性。\n\n🌟**应用技术突破**: 介绍新型核材料在实际应用中的技术突破与创新点。\n\n🌟**材料安全性改进**: 概述提升核材料安全性的方法及其对核技术发展的影响。\n\n---\n\n## 3.2 工程设计的复杂性\n##### 多学科协作解决核装置设计问题\n\n🌟**多学科协作**: 各领域专家共同解决核装置设计中的复杂问题,确保技术可行性。\n\n🌟**设计优化**: 通过模拟与实验不断改进设计方案,提升性能与安全性。\n\n🌟**材料选择**: 精选适合极端条件的材料,保障核装置稳定运行与长效使用。\n\n---\n\n## 3.3 计算机建模与仿真\n##### 高性能计算在核武器研究中的作用\n\n🌟**高性能计算基础**: 探讨高性能计算在核武器研究中的核心作用,包括其对复杂物理过程的模拟能力。\n\n🌟**核爆仿真技术**: 介绍计算机建模如何重现核爆炸过程,提升对核反应机制的理解和预测能力。\n\n🌟**数据处理与分析**: 分析海量数据处理方法,优化计算资源利用,提高仿真的精确度和效率。\n\n🌟**模型验证与优化**: 研究模型验证流程,确保仿真结果的可靠性,并通过持续优化改进计算方法。\n\n---\n\n## 3.4 精确引爆技术的发展\n##### 微电子技术与核弹控制系统的结合\n\n🌟**微电子技术应用**: 探讨微电子技术在核弹控制系统中的关键作用与实现方式。\n\n🌟**控制系统设计**: 分析核弹精确引爆技术中控制系统的结构与功能优化方法。\n\n🌟**数据传输安全**: 研究微电子技术支持下核弹控制系统中的数据传输加密与防护。\n\n🌟**实时监测技术**: 介绍微电子技术如何助力核弹引爆过程中的实时监测与反馈调整。\n\n---\n\n## 3.5 核废料的处理与管理\n##### 核武器生产后的环境影响与解决方案\n\n🌟**核废料的环境影响**: 分析核武器生产对环境造成的长期污染及生态破坏。\n\n🌟**废料处理技术发展**: 探讨当前核废料处理技术的进步与未来发展方向。\n\n🌟**安全储存解决方案**: 介绍核废料安全储存的方法及其面临的挑战与风险。\n\n🌟**国际管理标准**: 概述全球核废料管理的标准与合作机制以减少环境危害。\n\n🌟**可持续管理策略**: 提出实现核废料可持续管理的政策建议与技术创新。\n\n\n================================================================================\n\n## 4. 核武器的伦理与法律问题\n##### 🌈探讨核武器使用与和平发展的平衡\n\n---\n\n## 4.1 核武器的人道主义争议\n##### 核战争对人类社会的毁灭性后果\n\n🌟**毁灭性后果**: 核战争将导致大规模死亡与生态灾难,威胁全人类生存。\n\n🌟**人道主义影响**: 核武器使用造成无辜平民的巨大痛苦与长期健康损害。\n\n🌟**国际法约束**: 当前国际法对核武器使用的限制及其在人道主义争议中的作用。\n\n🌟**和平解决方案**: 推动全球无核化以避免核战争带来的毁灭性人道主义后果。\n\n---\n\n## 4.2 国际条约与核不扩散机制\n##### 《不扩散核武器条约》的意义与执行\n\n🌟**条约背景**: 介绍《不扩散核武器条约》诞生的历史背景与国际形势。\n\n🌟**核心内容**: 概述条约的主要条款及其对核不扩散机制的贡献。\n\n🌟**执行挑战**: 分析条约在执行过程中面临的困难与争议问题。\n\n🌟**未来展望**: 探讨如何加强条约效力以应对新的国际安全威胁。\n\n---\n\n## 4.3 核军备竞赛的历史教训\n##### 冷战时期的军备竞赛对全球安全的影响\n\n🌟**冷战背景**: 冷战时期美苏核军备竞赛的起因与过程。\n\n🌟**安全影响**: 核武器扩张对全球安全局势的深远威胁。\n\n🌟**古巴危机**: 古巴导弹危机揭示核战争边缘的危险性。\n\n🌟**裁军努力**: 国际社会为缓解核竞赛所作的努力与协议。\n\n🌟**历史反思**: 核军备竞赛的历史教训对当今世界的启示。\n\n---\n\n## 4.4 和平利用核能的可能性\n##### 核技术在医疗、能源等领域的应用前景\n\n🌟**核能在医疗的应用**: 探讨核技术在癌症治疗和医学成像中的应用前景。\n\n🌟**核能发电的优势**: 分析核能作为清洁能源在缓解能源危机中的作用。\n\n🌟**核技术在农业的潜力**: 介绍核技术提高农作物产量和品质的可能应用。\n\n🌟**核废料的安全处理**: 研究如何通过技术创新减少核能利用带来的环境风险。\n\n🌟**国际合作与监管**: 探讨和平利用核能所需的国际合作与法律框架。\n\n🌟**公众认知与接受度**: 分析如何提升公众对核能和平利用的信任和支持。\n\n---\n\n## 4.5 全球无核化的未来展望\n##### 国际社会如何推动核裁军与和平发展\n\n🌟**核裁军进程**: 探讨国际社会推动核裁军的具体措施与历史进程。\n\n🌟**和平利用核能**: 分析如何在无核化背景下促进核能的和平与发展应用。\n\n🌟**未来展望**: 展望全球无核化的可能性及其对世界和平的深远影响。\n\n\n================================================================================\n\n## 5. 科幻视角下的核武器\n##### 🌈文学与影视作品中的核武器想象\n\n---\n\n## 5.1 核战争题材的经典作品\n##### 《末日之战》与《核子惊爆》的文学价值\n\n🌟**末日之战解析**: 探讨《末日之战》中核战争的描写及其对人类社会的影响。\n\n🌟**核子惊爆主题**: 分析《核子惊爆》如何展现核武器威胁与人性挣扎。\n\n🌟**文学价值探讨**: 深入挖掘两部作品在文学史上的地位及独特贡献。\n\n🌟**社会反思意义**: 揭示经典作品对核战争的警示作用及推动和平的价值。\n\n🌟**创作背景研究**: 回顾作者创作动机与时代背景,理解作品深层含义。\n\n---\n\n## 5.2 核武器在科幻电影中的表现\n##### 《星球大战》与《红色警戒》中的科技幻想\n\n🌟**星球大战的幻想**: 探讨《星球大战》中核武器般的超级武器,展现其对宇宙战争的影响与科技想象。\n\n🌟**红色警戒的技术**: 分析《红色警戒》中核弹技术的应用,展示未来战争中科技与策略的结合。\n\n🌟**科幻中的现实思考**: 从科幻作品反思核武器的潜在威胁及人类对科技力量的依赖与恐惧。\n\n---\n\n## 5.3 核灾难的文化反思\n##### 核武器对人类文明的警示意义\n\n🌟**核爆后的世界**: 描绘核灾难对地球环境与人类社会的毁灭性影响。\n\n🌟**科幻作品中的反思**: 探讨科幻小说和电影中对核武器使用的深刻警示意义。\n\n🌟**文化艺术的表达**: 分析文化艺术如何通过核主题传达对和平的渴望与追求。\n\n🌟**历史教训的总结**: 回顾历史上的核事件,总结其对人类文明发展的深远启示。\n\n🌟**和平主义的兴起**: 讨论核武器威胁下全球和平主义思潮的兴起及其影响。\n\n🌟**未来可能性展望**: 展望避免核灾难的技术与政策发展方向,强调国际合作的重要性。\n\n---\n\n## 5.4 虚构核武器的技术可能性\n##### 科幻设定中的科学依据与合理性\n\n🌟**科学依据分析**: 探讨科幻设定中核武器的技术原理与现实科学的联系。\n\n🌟**技术可行性评估**: 分析虚构核武器在当前科技水平下的实现可能性与挑战。\n\n🌟**合理性探讨**: 研究科幻作品中核武器设计是否符合物理规律与逻辑。\n\n---\n\n## 5.5 未来核武器的形态预测\n##### 下一代核武器可能的发展方向\n\n🌟**智能化核武器**: 探讨人工智能在核武器中的应用,提升精准度与自主决策能力。\n\n🌟**可控小型核弹**: 分析未来小型化核弹头趋势,实现高威力低附带损伤。\n\n🌟**定向能核装置**: 研究定向能技术结合核反应,开发新型高效能武器系统。\n\n🌟**量子加密防护**: 探索量子技术保障核武通讯安全,防止未经授权使用。\n\n🌟**太空部署核威慑**: 讨论未来太空核武器化可能性及其对全球战略平衡的影响。\n\n🌟**环保型核材料**: 预测使用更清洁核燃料减少长期辐射污染的潜在发展方向。\n"
+}
+
+func Eg2() string {
+ return "\n================================================================================\n\n## 1. 核弹的基础知识\n##### 🌈核弹的起源、"
+}
diff --git a/ppt/2025中国足球-1749709451.pptx b/ppt/2025中国足球-1749709451.pptx
new file mode 100644
index 0000000..6654ad7
Binary files /dev/null and b/ppt/2025中国足球-1749709451.pptx differ
diff --git a/theme.go b/theme.go
new file mode 100644
index 0000000..3761ea6
--- /dev/null
+++ b/theme.go
@@ -0,0 +1,32 @@
+package main
+
+import (
+ "fyne.io/fyne/v2"
+ "fyne.io/fyne/v2/theme"
+ "image/color"
+)
+
+type myTheme struct{}
+
+func (t myTheme) Color(name fyne.ThemeColorName, variant fyne.ThemeVariant) color.Color {
+ //TODO implement me
+ return color.RGBA{0, 128, 255, 255}
+}
+
+func (t myTheme) Font(style fyne.TextStyle) fyne.Resource {
+ //TODO implement me
+ return theme.DefaultTextFont()
+}
+
+func (t myTheme) Icon(name fyne.ThemeIconName) fyne.Resource {
+ //TODO implement me
+ return theme.DefaultTextFont()
+}
+
+func (t myTheme) Size(name fyne.ThemeSizeName) float32 {
+ //TODO implement me
+ return 0
+}
+
+func (myTheme) BackgroundColor() color.Color { return color.RGBA{0, 128, 255, 255} }
+func (myTheme) ButtonColor() color.Color { return color.RGBA{0, 255, 128, 255} }
diff --git a/tools.go b/tools.go
new file mode 100644
index 0000000..892513d
--- /dev/null
+++ b/tools.go
@@ -0,0 +1,56 @@
+package main
+
+import (
+ "fmt"
+ "io"
+ "net/http"
+ "os"
+ "path/filepath"
+ "strings"
+ "time"
+)
+
+func GetImg(url string) string {
+ path, _ := os.Getwd()
+ imgPath := fmt.Sprintf("%s/%s", path, "img")
+ dir := filepath.Dir(imgPath)
+ if _, err := os.Stat(dir); os.IsNotExist(err) {
+ os.MkdirAll(dir, 0755)
+ }
+ urlSlice := strings.Split(url, "/")
+ fileName := fmt.Sprintf("%s/%s", imgPath, urlSlice[len(urlSlice)-1])
+ _, err := os.Stat(fileName)
+ if os.IsNotExist(err) {
+ DownloadFile(url, fileName)
+ }
+ return fileName
+
+}
+
+func DownloadFile(url string, fileName string) {
+ resp, _ := http.Get(url)
+
+ defer resp.Body.Close()
+ out, _ := os.Create(fileName)
+ io.Copy(out, resp.Body)
+ defer out.Close()
+}
+
+func DownloadPpt(url string, fileName string) (file string) {
+ path, _ := os.Getwd()
+ pptPath := fmt.Sprintf("%s/%s", path, "ppt")
+ dir := filepath.Dir(pptPath)
+ fmt.Println(pptPath)
+ if _, err := os.Stat(dir); os.IsNotExist(err) {
+ e := os.MkdirAll(dir, 0755)
+ fmt.Println(e)
+ }
+ fileName = fmt.Sprintf("%s-%d", fileName, time.Now().Unix())
+ file = fmt.Sprintf("%s/%s.%s", pptPath, fileName, "pptx")
+ resp, _ := http.Get(url)
+ defer resp.Body.Close()
+ out, _ := os.Create(file)
+ io.Copy(out, resp.Body)
+ defer out.Close()
+ return
+}