简单二次封装的Golang图像处理库:图片裁剪

一.功能

  1. Go语言下的官方图像处理库
  2. 简单封装后对jpg和png图像进行缩放/裁剪的库

二.使用说明

1.首先下载

go get -v -u github.com/hunterhug/go_image

2.主要函数

按照宽度进行等比例缩放,第一参数是图像文件,第二个参数是缩放后的保存文件路径

err := ScaleF2F(filename, savepath, width)

按照宽度和高度进行等比例缩放,第一参数是图像文件,第二个参数是缩放后的保存文件路径

err = ThumbnailF2F(filename, save1path, width, height)

检测图像文件真正文件类型,并返回真实文件名,参数为图像文件位置

realfilename, err := RealImageName(savepath)

改变图像文件名,第一个参数为文件原始名字,第二个参数是文件改名后名字,第三个参数表示是否强制改名

err=ChangeImageName(savepath,realfilename,false)

三.使用示例

3.1.example.go

    package main

    import (
"fmt"
. "github.com/hunterhug/go_image/go_image"
) //将某一图片文件进行缩放后存入另外的文件中
func main() {
//打印当前文件夹位置
fmt.Printf("本文件文件夹位置:%s\n", CurDir()) //图像位置
filename := "./testdata/gopher.png" //保存位置
savepath := "./testdata/gopher400.jpg"
save1path := "./testdata/gopher400*400.png" //宽度,高度
width := 200
height := 400 //按照宽度进行等比例缩放
err := ScaleF2F(filename, savepath, width)
if err != nil {
fmt.Printf("%s\n", err.Error())
}else{
fmt.Printf("生成按宽度缩放图%s\n",savepath)
} //按照宽度和高度进行等比例缩放
err = ThumbnailF2F(filename, save1path, width, height)
if err != nil {
fmt.Printf("%s\n", err.Error())
}else{
fmt.Printf("生成按宽度高度缩放图%s\n",save1path)
} //查看图像文件的真正名字
//如 ./testdata/gopher400.jpg其实是png类型,但是命名错误,需要纠正!
realfilename, err := RealImageName(savepath)
if err != nil {
fmt.Printf("%s\n", err.Error())
} else {
fmt.Printf("真正的文件名:%s\n", realfilename)
} //文件改名,不强制性
err=ChangeImageName(savepath,realfilename,false)
if err!=nil{
fmt.Printf("文件改名失败:%s%s",realfilename,err.Error())
} //文件改名,强制性
err=ChangeImageName(savepath,realfilename,true)
if err!=nil{
fmt.Printf("文件改名失败:%s%s",realfilename,err.Error())
}else{
fmt.Println("改名成功")
}
}

3.2.结果

本文件文件夹位置:/home/silly/golang/pikapika/src/github.com/hunterhug/go_image
生成按宽度缩放图./testdata/gopher400.jpg
生成按宽度高度缩放图./testdata/gopher400*400.png
真正的文件名:./testdata/gopher400.png
文件改名失败:./testdata/gopher400.png文件已经存在

原始图片

宽度200px等比例缩放裁剪

简单二次封装的Golang图像处理库:图片裁剪的更多相关文章

  1. 对百度WebUploader的二次封装,精简前端代码之图片预览上传(两句代码搞定上传)

    前言 本篇文章上一篇: 对百度WebUploader开源上传控件的二次封装,精简前端代码(两句代码搞定上传) 此篇是在上面的基础上扩展出来专门上传图片的控件封装. 首先我们看看效果: 正文 使用方式同 ...

  2. Volley的简单二次封装

    新建一个application package com.honghe.myvolley.app; import com.android.volley.RequestQueue; import com. ...

  3. axios 简单二次封装

    import axios from 'axios' import { Message } from 'element-ui'; // 设置baseURL //axios.defaults.baseUR ...

  4. 毕加索的艺术——Picasso,一个强大的Android图片下载缓存库,OkHttpUtils的使用,二次封装PicassoUtils实现微信精选

    毕加索的艺术--Picasso,一个强大的Android图片下载缓存库,OkHttpUtils的使用,二次封装PicassoUtils实现微信精选 官网: http://square.github.i ...

  5. Glide二次封装库的使用

    更多代码可以查询本人GitHub:欢迎阅读,star点起来. Glide二次封装库源码 前言 为什么选择Glide? Glide 轻量级 速度快 可以根据所需加载图片的大小自动适配所需分辨率的图 支持 ...

  6. 图像处理库GPUImage简单使用

    一.介绍 GPUImage是一个基于OpenGL ES 2.0的开源的图像处理库,作者是Brad Larson.GPUImage将OpenGL ES封装为简洁的Objective-C或Swift接口, ...

  7. Vue:对axios进行简单的二次封装

    主要做3点: 1.配置一个请求地址前缀 2.请求拦截(在请求发出去之前拦截),给所有的请求都带上 token 3.拦截响应,遇到 token 不合法则报错 // 对 axios 的二次封装 impor ...

  8. golang mongodb 驱动二次封装

    mongodb 官方的go驱动包 go.mongodb.org/mongo-driver 使用起来比较繁琐,最近对其进行了二次封装 github地址:https://github.com/w3liu/ ...

  9. OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据

    OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据 我们这片博文就来聊聊这个反响很不错的OkHttp了,标题是我恶搞的,本篇将着重详细的 ...

随机推荐

  1. RK3399 删除开机锁屏界面

    CPU:RK3399 系统:Android 7.1 删除开机锁屏界面 diff --git a/frameworks/base/packages/SettingsProvider/res/values ...

  2. Fiddler自动响应AutoResponder正则匹配

    AutoResponder-Add-Rule Editor 两个文本框,先说第一个: Mathes: 前缀为“EXACT:”表示完全匹配(大小写敏感) 无前缀表示基本搜索,表示搜索到字符串就匹配 前缀 ...

  3. OpenJudge计算概论-找出第k大的数

    /*================================================ 找出第k大的数 总时间限制: 1000ms 内存限制: 1000kB 描述 用户输入N和K,然后接 ...

  4. 知乎千万级高性能长连接网关 https://zhuanlan.zhihu.com/p/66807833

    知乎千万级高性能长连接网关揭秘 9 天前 · 来自专栏 知乎技术专栏 实时的响应总是让人兴奋的,就如你在微信里看到对方正在输入,如你在王者峡谷里一呼百应,如你们在直播弹幕里不约而同的 666,它们的背 ...

  5. SpringBoot缓存技术

    一.SpringBoot整合Ehhcache 添加maven依赖 <dependency> <groupId>org.springframework.boot</grou ...

  6. React 高阶组件浅析

    高阶组件的这种写法的诞生来自于社区的实践,目的是解决一些交叉问题(Cross-Cutting Concerns).而最早时候 React 官方给出的解决方案是使用 mixin .而 React 也在官 ...

  7. 为什么vue-cli创建的build文件下没有dev-server.js文件

    在新版本的Vue开发中,通过vue-cli创建的build文件夹下面已经没有了旧版本中的dev-server.js文件新版本的vue已将dev-server.js与webpack.dev.conf.j ...

  8. iOS笔试题01

    1. #import 跟#include.@class有什么区别?#import<> 跟 #import”"又什么区别? 1> #import和#include都能完整地包 ...

  9. Redis集群部署与维护

    Redis集群部署与维护 目录: 一. 集群架构 二. 集群部署 1. 创建redis-cluster目录 2. 编译redis 3. 编辑redis配置文件 4. 配置redis集群 5. redi ...

  10. layer弹出层,结合art-template实现弹出编辑

    模板 <!-- 模板 --> <script id="render-tpl" type="text/html"> <div cla ...