如何实现拖曳功能

问题引入:设一个窗体的背景,把外边一个图片文件,拖曳到窗体上,窗体上可以显示图片内容。

解决方案:

把窗体上的Form.AllowDrop属性设为true

在窗体的DragEnter事件中写入以下内容

  private void Form1_DragEnter(object sender, System.Windows.Forms.DragEventArgs e)
  {
    str=((System.Array)e.Data.GetData(DataFormats.FileDrop)).GetValue(0).ToString() ;
  } 

这样就可读出相应的文件字符串

在窗体的DragLeave事件中写入以下内容

  private void Form1_DragLeave(object sender, System.EventArgs e)
  {
   pictureBox1.Image=new Bitmap(str);
  }

当然如果不是图片文件的话,可以在读取之前判断一下,如果是图片文件夹,就可显示内容

最后有一个小问题就是在无法拖曳到图片框当中,只能拖曳到窗体之上。

我们可使用Panel来代替图片框的显示。使用Panel.BackGrandImage属性来设置背景图片

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要为 Ruby on Rails 程序加入拖曳排序功能,你可以使用 jQuery UI 的 Sortable 插件和 Rails 的 AJAX 功能实现。 首先,在你的 Rails 应用程序中安装 jQuery UI: ```ruby # Gemfile gem 'jquery-ui-rails' ``` 然后,在应用程序的 JavaScript 文件中添加以下代码: ```javascript // app/assets/javascripts/application.js //= require jquery-ui/widgets/sortable $(document).ready(function() { $('ul.sortable').sortable({ axis: 'y', update: function(event, ui) { $.ajax({ url: '/items/sort', type: 'PATCH', data: $(this).sortable('serialize'), success: function() { console.log('Items sorted'); } }); } }); }); ``` 上面的代码将为具有 `sortable` 类的 `ul` 标签添加拖曳排序功能。当用户完成排序并释放鼠标时,它将向 `/items/sort` 发送一个 PATCH 请求,其中包含排序后的项目信息。 接下来,在控制器中添加 `sort` 动作: ```ruby # app/controllers/items_controller.rb class ItemsController < ApplicationController def sort params[:item].each_with_index do |id, index| Item.where(id: id).update_all(position: index + 1) end head :ok end end ``` 上面的代码将根据传递的项目 ID 更新其位置。最后,你需要在视图中为每个项目添加位置属性: ```html <!-- app/views/items/index.html.erb --> <ul class="sortable"> <% @items.each do |item| %> <li data-id="<%= item.id %>"> <%= item.name %> <span class="position"><%= item.position %></span> </li> <% end %> </ul> ``` 这就是为 Ruby on Rails 程序添加拖曳排序功能的基本步骤。你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值