Django imgareaselect手动剪切头像实现方法

发表于 5年以前  | 总阅读数:991 次

本文实例讲述了Django imgareaselect手动剪切头像的方法。分享给大家供大家参考。具体如下:

index.html:


    <!DOCTYPE html> 
    <html> 
    <head> 
    <meta charset="UTF-8"> 
    <title>上传图片</title> 
    </head> 
    <body> 
    <form action="." method="post" enctype="multipart/form-data">{% csrf_token %} 
      <table border="0"> 
        {{form.as_table}} 
        <tr> 
          <td></td> 
          <td><input type="submit" value="上传"/></td> 
        </tr> 
      </table> 
    </form> 
    </body> 
    </html> 

show.html:


    <!DOCTYPE html> 
    <html> 
    <head> 
    <meta charset="UTF-8"> 
    <title>HTML5的标题</title> 
    <style> 
    ul {width:80%;padding:5px;} 
    li{list-style:none;float:left;padding:5px;margin:5px;background-color:#ccc;} 
    .info{color:green;} 
    </style> 
    </head> 
    <body> 
      <p><a href="{%url headhat_index%}">继续上传头像</a></p> 
      {% if messages %} 
        {% for message in messages %} 
          <p{% if message.tags %} class="{{ message.tags }}"{% endif %}>{{ message }}</p> 
        {% endfor %} 
      {% endif %} 
    <ul> 
      {%for p in photos%} 
      <li><img src="{{path}}{{p.photo_name}}" alt="big"/><br/> 
        <img src="{{path}}{{p.photo_thumb}}" alt="thumb"/> <a href="{%url headhat_cut p.id%}">继续剪切</a>   
      </li> 
      {%endfor%} 
    </ul> 
    </body> 
    </html> 

cut.html:


    <!DOCTYPE html> 
    <html> 
    <head> 
    <meta charset="UTF-8"> 
    <title>剪切</title> 
    <link rel="stylesheet" type="text/css" href="/static/jquery.imgareaselect-0.9.3/css/imgareaselect-default.css" /> 
    <style rel="stylesheet" type="text/css" > 
    .area { 
    background:none repeat scroll 0 0 #EEEEFF; 
    border:2px solid #DDDDEE; 
    padding:0.6em 0.6em 1em 0.6em; 
    width:85%; 
    display:block; 
    margin-bottom:1em; 
    } 
    div.frame { 
    background:none repeat scroll 0 0 #FFFFFF; 
    border:2px solid #DDDDDD; 
    padding:0.4em; 
    } 
    .info{color:green;} 
    </style> 
    <script type="text/javascript" src="js/jquery.min.js"></script>
    <script type="text/javascript" src="js/jquery.imgareaselect.min.js"></script>
    <script type="text/javascript"> 
    function preview(img, selection) { 
      if (!selection.width || !selection.height) 
        return; 
      var scaleX = 100 / selection.width; 
      var scaleY = 100 / selection.height; 
      $('#preview img').css({ 
        width: Math.round(scaleX * 300), 
        height: Math.round(scaleY * 300), 
        marginLeft: -Math.round(scaleX * selection.x1), 
        marginTop: -Math.round(scaleY * selection.y1) 
      }); 
      $('#id_x1').val(selection.x1); 
      $('#id_y1').val(selection.y1); 
      $('#id_x2').val(selection.x2); 
      $('#id_y2').val(selection.y2); 
      $('#id_w').val(selection.width); 
      $('#id_h').val(selection.height); 
    } 
    $(function (){ 
      $('#id_x1').val(100); 
      $('#id_y1').val(100); 
      $('#id_x2').val(200); 
      $('#id_y2').val(200); 
      $('#id_w').val(100); 
      $('#id_h').val(100); 
      $('#photo').imgAreaSelect({ aspectRatio: '1:1', handles: true, 
                fadeSpeed: 200, minHeight:100,minWidth:100,onSelectChange: preview, 
                x1: 100, y1: 100, x2: 200, y2: 200 
      }); 
    });  
    </script> 
    </head> 
    <body> 
    <h3>头像剪切 <a href="{%url headhat_index%}"><b>返回</b></a> </h3> 
    {% if messages %} 
      {% for message in messages %} 
      <p{% if message.tags %} class="{{ message.tags }}"{% endif %}>{{ message }}</p> 
      {% endfor %} 
      {% endif %} 
    <div class="area"> 
    <div style="float: left; width: 45%;"> 
      <p class="instructions">点击原图 选择剪切区域</p> 
      <div style="margin: 0pt 0.3em; width: 300px; height: 300px;" class="frame"> 
        <img src="{{vir_path}}" id="photo" alt="30"/> 
      </div> 
    </div> 
    <div style="float: left; width: 40%; padding-top:50px;"> 
      <p style="font-size: 110%; font-weight: bold; padding-left: 0.1em;">预览选择区域</p> 
      <div style="margin: 0pt 1em; width: 100px; height: 100px;" class="frame"> 
        <div style="width: 100px; height: 100px; overflow: hidden;" id="preview"> 
          <img style="width: 244px; height: 244px; margin-left: -71px; margin-top: -54px;" src="{{vir_path}}" alt="300"/> 
        </div> 
      </div> 
      <form action="" method="POST">{% csrf_token %} 
      <table style="margin-top: 1em;"> 
      <thead> 
      <tr> 
      <th style="font-size: 110%; font-weight: bold; text-align: left; padding-left: 0.1em;" colspan="2"> 
      剪切坐标 
      </th> 
      <th style="font-size: 110%; font-weight: bold; text-align: left; padding-left: 0.1em;" colspan="2"> 
      剪切尺寸 
      </th> 
      </tr> 
      </thead> 
      <tbody> 
      <tr> 
      <td style="width: 10%;"><b>X<sub>1</sub>:</b></td> 
      <td style="width: 30%;">{{form.x1}}</td> 
      <td style="width: 20%;"><b>宽度:</b></td> 
      <td>{{form.w}}</td> 
      </tr> 
      <tr> 
      <td><b>Y<sub>1</sub>:</b></td> 
      <td>{{form.y1}}</td> 
      <td><b>高度:</b></td> 
      <td>{{form.h}}</td> 
      </tr> 
      <tr> 
      <td><b>X<sub>2</sub>:</b></td> 
      <td>{{form.x2}}</td> 
      <td></td> 
      <td></td> 
      </tr> 
      <tr> 
      <td><b>Y<sub>2</sub>:</b></td> 
      <td>{{form.y2}}</td> 
      <td></td> 
      <td><input type="submit" value="保存"/></td> 
      </tr> 
      </tbody> 
      </table> 
      </form> 
    </div> 
    <div style="clear:left;"></div> 
    </div> 
    </body> 
    </html> 

forms.py:


    #coding=utf-8 
    from django import forms 
    class PhotoForm(forms.Form): 
      photo_name = forms.ImageField(label=u"头像") 
    class HatHeadCutForm(forms.Form): 
      x1=forms.IntegerField(widget=forms.TextInput(attrs={'size': 4,})) 
      y1=forms.IntegerField(widget=forms.TextInput(attrs={'size': 4,})) 
      x2=forms.IntegerField(widget=forms.TextInput(attrs={'size': 4,}))
      y2=forms.IntegerField(widget=forms.TextInput(attrs={'size': 4,})) 
      w=forms.IntegerField(widget=forms.TextInput(attrs={'size': 4,})) 
      h=forms.IntegerField(widget=forms.TextInput(attrs={'size': 4,})) 

models.py:


    #coding=utf-8 
    from django.db import models 
    class Photo(models.Model): 
      photo_name=models.CharField(u"图片路径",max_length=255) 
      photo_thumb=models.CharField(u"图片缩略图",max_length=255) 

views.py:


    #coding=utf-8 
    from django.core.urlresolvers import reverse 
    from django.shortcuts import render_to_response, get_object_or_404 
    from django.http import HttpResponse,HttpResponseRedirect 
    from django.template import RequestContext 
    from django.contrib import messages 
    import os,uuid,ImageFile,Image 
    from PhotoCut.headhat.forms import PhotoForm,HatHeadCutForm 
    from PhotoCut.headhat.models import Photo 
    from PhotoCut.settings import MEDIA_ROOT,HEADHAT_ABS_PATH,HEADHAT_VIR_PATH 
    def index(request,templates="headhat/index.html"): 
      template_var={} 
      form=PhotoForm() 
      if request.method=="POST": 
        form = PhotoForm(request.POST.copy(),request.FILES) 
        if form.is_valid(): 
          file=request.FILES.get("photo_name",None) 
          if file: 
            p=ImageFile.Parser() 
            for c in file.chunks(): 
              p.feed(c) 
            img=p.close() 
            if img.mode != 'RGBA': 
              img = img.convert('RGBA') 
            if img.size[0]>img.size[1]: 
              offset=int(img.size[0]-img.size[1])/2 
              img=img.crop((offset,0,int(img.size[0]-offset),img.size[1])) 
            else: 
              offset=int(img.size[1]-img.size[0])/2 
              img=img.crop((0,offset,img.size[0],(img.size[1]-offset))) 
            img.thumbnail((300, 300)) 
            file_name="%s.jpg"%str(uuid.uuid1()) 
            img.save(os.path.join(HEADHAT_ABS_PATH,file_name),"JPEG",quality=100) 
            messages.info(request,u"上传成功!") 
            p=Photo.objects.create(photo_name=file_name) 
            p.save() 
            return HttpResponseRedirect(reverse("headhat_cut",kwargs={"id":p.id})) 
      template_var["form"]=form 
      return render_to_response(templates,template_var,context_instance=RequestContext(request)) 
    def cut(request,id,templates="headhat/cut.html"): 
      template_var={} 
      p=get_object_or_404(Photo,pk=int(id)) 
      if not p.photo_name: 
        messages.info(request,u"请先上传图片!") 
        return HttpResponseRedirect(reverse("headhat_index")) 
      template_var["vir_path"]=os.path.join(HEADHAT_VIR_PATH,p.photo_name)
      form=HatHeadCutForm() 
      if request.method=='POST': 
        form=HatHeadCutForm(request.POST) 
        if form.is_valid():       
          try: 
            img=Image.open(os.path.join(HEADHAT_ABS_PATH,p.photo_name))         
          except IOError: 
            messages.info(request,u"读取文件错误!")
          data=form.cleaned_data 
          img=img.crop((data["x1"],data["y1"],data["x2"],data["y2"]))
          img.thumbnail((50, 50)) 
          file_name="%s_%s"%(os.path.splitext(p.photo_name)[0],"_50_50.jpg")       
          img.save(os.path.join(HEADHAT_ABS_PATH,file_name),"JPEG",quality=100)
          p.photo_thumb=file_name 
          p.save() 
          messages.info(request,u"剪切成功!") 
          return HttpResponseRedirect(reverse("headhat_show")) 
        else: 
          messages.info(request,u"请剪切后 再保存!") 
      template_var["form"]=form 
      return render_to_response(templates,template_var,context_instance=RequestContext(request)) 
    def show(request,templates="headhat/show.html"): 
      template_var={} 
      photos=Photo.objects.all() 
      template_var["path"]=HEADHAT_VIR_PATH 
      template_var["photos"]=photos 
      return render_to_response(templates,template_var,context_instance=RequestContext(request)) 

希望本文所述对大家的Python程序设计有所帮助。

 相关推荐

刘强东夫妇:“移民美国”传言被驳斥

京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。

发布于:1年以前  |  808次阅读  |  详细内容 »

博主曝三大运营商,将集体采购百万台华为Mate60系列

日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。

发布于:1年以前  |  770次阅读  |  详细内容 »

ASML CEO警告:出口管制不是可行做法,不要“逼迫中国大陆创新”

据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。

发布于:1年以前  |  756次阅读  |  详细内容 »

抖音中长视频App青桃更名抖音精选,字节再发力对抗B站

今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。

发布于:1年以前  |  648次阅读  |  详细内容 »

威马CDO:中国每百户家庭仅17户有车

日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。

发布于:1年以前  |  589次阅读  |  详细内容 »

研究发现维生素 C 等抗氧化剂会刺激癌症生长和转移

近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。

发布于:1年以前  |  449次阅读  |  详细内容 »

苹果据称正引入3D打印技术,用以生产智能手表的钢质底盘

据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。

发布于:1年以前  |  446次阅读  |  详细内容 »

千万级抖音网红秀才账号被封禁

9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...

发布于:1年以前  |  445次阅读  |  详细内容 »

亚马逊股东起诉公司和贝索斯,称其在购买卫星发射服务时忽视了 SpaceX

9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。

发布于:1年以前  |  444次阅读  |  详细内容 »

苹果上线AppsbyApple网站,以推广自家应用程序

据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。

发布于:1年以前  |  442次阅读  |  详细内容 »

特斯拉美国降价引发投资者不满:“这是短期麻醉剂”

特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。

发布于:1年以前  |  441次阅读  |  详细内容 »

光刻机巨头阿斯麦:拿到许可,继续对华出口

据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。

发布于:1年以前  |  437次阅读  |  详细内容 »

马斯克与库克首次隔空合作:为苹果提供卫星服务

近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。

发布于:1年以前  |  430次阅读  |  详细内容 »

𝕏(推特)调整隐私政策,可拿用户发布的信息训练 AI 模型

据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。

发布于:1年以前  |  428次阅读  |  详细内容 »

荣耀CEO谈华为手机回归:替老同事们高兴,对行业也是好事

9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI操控无人机能力超越人类冠军

《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI生成的蘑菇科普书存在可致命错误

近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。

发布于:1年以前  |  420次阅读  |  详细内容 »

社交媒体平台𝕏计划收集用户生物识别数据与工作教育经历

社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”

发布于:1年以前  |  411次阅读  |  详细内容 »

国产扫地机器人热销欧洲,国产割草机器人抢占欧洲草坪

2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。

发布于:1年以前  |  406次阅读  |  详细内容 »

罗永浩吐槽iPhone15和14不会有区别,除了序列号变了

罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。

发布于:1年以前  |  398次阅读  |  详细内容 »
 相关文章
Android插件化方案 5年以前  |  237154次阅读
vscode超好用的代码书签插件Bookmarks 1年以前  |  7940次阅读
 目录