`
notrace123
  • 浏览: 8597 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
最近访客 更多访客>>
社区版块
存档分类
最新评论

rails crop attachment_fu

阅读更多
  def update
@face = Face.find_by_user_id(session[:user_id],:conditions => "parent_id is null" )
    respond_to do |format|
      if @face.update_attributes(params[:face])

#        flash[:notice] = 'Face was successfully updated.'
#        format.html { redirect_to(edit_user_path(@face.user,:web_name => "face")) }
        format.html { redirect_to(:controller => "houses", :action => "show", :id => session[:house_id] ) }
        format.xml  { headk }
      else
        format.html { render :action => "edit" }
        format.xml  { renderml => @face.errors, :status => :unprocessable_entity }
      end
    end
  end



  def update_attributes(att)
#    path = "/home/sunchi/work/demo/swfupload-rails-authentication/public/assets/0000/0050/1521572725770.jpg"
    path = File.expand_path(RAILS_ROOT)+"/public"+self.public_filename(:big)
bash_path = File.expand_path(RAILS_ROOT)+"/public"+self.public_filename
#    scaled_img = Magick::ImageList.new(self.path)
#    orig_img = Magick::ImageList.new(self.path(:original))
    scaled_img = Magick::ImageList.new(path)    # 缩略图
    orig_img = Magick::ImageList.new(bash_path) # 原图
    scale = orig_img.columns.to_f / scaled_img.columns # 按照缩略图于原图缩放比例 进行裁剪

    args = [ att[:x1], att[:y1], att[:width], att[:height] ]
    args = args.collect { |a| a.to_i * scale }

    orig_img.crop!(*args)
#    orig_img.write(self.path(:original))
    orig_img.write(bash_path)

#    self.reprocess!
    self.save!
    super(att)
  end


<div class="fam_h_m">
<div class="head_bg">
<div class="font003 head_line">上传头像</div>
<div style="margin-top: 10px;">
<% form_for @face, :method => :put do |f| -%>
<table cellspacing="0" cellpadding="0" border="0" width="100%">
  <tbody><tr>

    <td width="280">

   <input type="hidden" name="face[x1]" id="x1" /> 
   <input type="hidden" name="face[y1]" id="y1" /> 
   <input type="hidden" name="face[width]" id="width" /> 
   <input type="hidden" name="face[height]" id="height" /> 
<p> 
<div style="width:280px;height:325px;"><%= image_tag(crop_face.public_filename(:big), :style => 'max-height: 325px; max-width: 280px;', :id => "photo")%></div>
  </p> 





<div style="float: left; height: 20px; line-height: 20px;"></div>

</td>
    <td valign="top">
<div class="head_c">
  <p>
   </p><div style="height: 40px; line-height: 40px;"><div style="float: left; margin-top: 10px;"></div> </div>
    <br>

    <div style="width: 100%;"></div>
   
    <p><br>
        <br>
        <br>

        <br>
        <span>预览</span>    

 
    </p><p> <div id="preview" style="margin-left:40px;overflow:hidden;position:relative;  "><span><%= image_tag('yulan.png', :style => "z-index:10001;width:100px;height:100px;")%></span></div></p>
   <br /> 
<div style="margin-top: 30px; margin-left: 40px;">

<!-- <a class="button white" type="submit" id="face_submit" >保存</a>  -->
    <%= f.submit("保存", :class=> "button white" , :style => "background:-moz-linear-gradient(center top , #FFFFFF, #EDEDED) repeat scroll 0 0 transparent;") %>
</div>
</div>
</td>

  </tr>
</tbody></table>
<% end %>
</div>



</div>
</div>



<script type="text/javascript"> 
   function onEndCrop( coords, dimensions ) { 
     $( 'x1' ).value = coords.x1; 
     $( 'y1' ).value = coords.y1; 
      
     $( 'width' ).value = dimensions.width; 
     $( 'height' ).value = dimensions.height; 
   } 
   Event.observe( window, 'load',function() { 
     new Cropper.ImgWithPreview('photo',{ 
       minWidth: 118, 
       minHeight: 115, 
       ratioDim: { x:100, y: 100 }, 
       displayOnInit: true, 
       onEndCrop: onEndCrop, 
       previewWrap: 'preview' 
     }); 
   });
</script>
分享到:
评论

相关推荐

    rails_semantic_logger, Rails 语义记录器用语义记录器替换 Rails 缺省记录器.zip

    rails_semantic_logger, Rails 语义记录器用语义记录器替换 Rails 缺省记录器 Rails 语义记录器 语义记录器用语义记录器替代 Rails 缺省记录器。http://github.com/rocketjob/rails_semantic_logger文档有关完整文档...

    rails_apps_composer, 一个 gem,为 Rails 启动应用程序创建 Rails 应用程序模板.zip

    rails_apps_composer, 一个 gem,为 Rails 启动应用程序创建 Rails 应用程序模板 Rails 应用编辑器 Rails 应用程序编辑器 gem 安装一个 命令行 工具来从"食谱"的Collection 组装 Rails 应用程序。"你可以使用 rails_...

    inspinia admin - v2.5 Rails_Full_Version

    "inspinia admin - v2.5 Rails_Full_Version" 是一个基于Rails框架构建的后台管理系统的完整版本。这个系统采用流行的Inspinia Admin模板,提供了丰富的功能和自定义选项,旨在帮助开发者快速构建高效、现代且用户...

    InspiniaAdmin 2.6.1 Rails_Full_Version

    在Rails_Full_Version压缩包中,包含了完整的源代码和必要的资源文件,开发者可以通过解压并导入到Rails项目中,按照官方文档进行配置和定制。同时,这个版本可能还包含了升级记录、更改日志和可能的bug修复,以保证...

    agile_web_development_with_rails_3rd_edition.9994652073.pdf

    《敏捷Web开发与Rails》第三版是一本深入探讨Ruby on Rails框架在敏捷软件开发方法论下的应用指南。本书由多位知名作者共同编写,包括Sam Ruby、Dave Thomas、David Heinemeier Hansson等,他们都是在Ruby社区内享有...

    rails_best_practices:Rails项目的代码度量工具

    rails_best_practices rails_best_practices是用于检查Rails代码质量的代码度量工具。 它支持以下ORM / ODM: 活动记录 蒙古型 mongomapper 以及以下模板引擎: erb 哈姆 减肥 拉布尔 rails_best_practices...

    inspinia admin - v2.5 Rails_Seed_Project

    本文将详细探讨其在Rails框架下的种子项目(Rails_Seed_Project),旨在帮助开发者更好地理解和运用这一强大的工具。 首先,我们来了解一下“Inspinia Admin”。这是一款基于Bootstrap 3构建的响应式后台模板,提供...

    InspiniaAdmin 2.5 Rails_Seed_Project

    InspiniaAdmin 2.5 Rails_Seed_Project是一款基于Bootstrap框架的高级管理模板,专为Ruby on Rails开发者设计,旨在加速Web应用程序的开发过程。这个项目作为种子启动器,提供了完整的后台管理界面,包括丰富的UI...

    Rails_3_Cheat_Sheets.pdf

    Rails_3_Cheat_Sheets.pdf

    InspiniaAdmin 2.5 Rails_full_version

    InspiniaAdmin 2.5 Rails_full_version

    rails_admin_acts_as_list:rails_admin插件以对记录进行排序

    介绍插件,用于对记录进行排序(使用 gem)安装要启用rails_admin_acts_as_list,请将以下内容添加到您的Gemfile : gem 'rails_admin_acts_as_list'gem 'rails_admin' 重要提示: rails_admin_acts_as_list之前必须...

    RestFul_Rails_Dev_pdf_v_0.1.zip

    本资料“RestFul_Rails_Dev_pdf_v_0.1.zip”包含了《RESTful Rails Development》的翻译版,将深入探讨如何在Rails中实现RESTful的设计模式。 首先,RESTful设计的核心概念是资源(Resources)。在Rails中,资源...

    inspinia_admin_v2.5_Rails_Full_Version

    该模板包含的文件列表“inspinia_admin_v2.5_Rails_Full_Version”很可能包括以下组成部分: 1. **静态资源**:CSS样式文件、JavaScript脚本和图像资源。这些文件用于构建用户界面,包括响应式布局、图表、表单元素...

    rails_email_preview, 在 Rails 中,预览和编辑应用程序邮件程序模板.zip

    rails_email_preview, 在 Rails 中,预览和编辑应用程序邮件程序模板 Rails 电子邮件预览 使用这里 Rails 引擎在浏览器中预览电子邮件。 兼容 Rails 4.2 。电子邮件审阅: 所有电子邮件预览的列表: 代表有两个主题...

    rails上传文件_paperclip

    path: ':rails_root/public/system/:class/:attachment/:id_partition/:style/:filename', url: '/system/:class/:attachment/:id_partition/:style/:filename' } ``` 2. **模型设置** 在你想要处理文件上传的...

    rails_tutorial_4th_edition_gemfiles, Ruby on Rails 教程 4th 版的Gemfiles.zip

    rails_tutorial_4th_edition_gemfiles, Ruby on Rails 教程 4th 版的Gemfiles Ruby on Rails 教程 4th 版 Gemfiles这些是最新版本的Gemfiles 在 Rails 教程 ruby Tutorial/Michael/ ( 4th 米。) 。 因为这里的文件更...

    rails_admin_image_manager:RailsAdmin和CKEditor的图像管理器

    gem 'rails_admin_image_manager' 跑步 $ bundle install 安装RailsAdmin_ImageManager $ rails generate rails_admin_image_manager:install 将上传文件路径添加到您的.gitignore文件中 /public/rails_admin_...

    rails_admin_content_builder:使用rails_admin创建内容的简单方法

    gem 'rails_admin_content_builder' 运行生成器并进行迁移 rails g rails_admin_content_builder rake db:migrate 在app / assets / application.scss中添加样式 * = require rails_admin_content_builder 用法 ...

Global site tag (gtag.js) - Google Analytics