AS3图像复制BitmapData.copyPixels()

2024-02-03 06:58

本文主要是介绍AS3图像复制BitmapData.copyPixels(),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

//舞台属性设置

stage.align=StageAlign.TOP_LEFT;
stage.scaleMode=StageScaleMode.NO_SCALE;
var selectBox:Sprite = new Sprite(); //生成选择框
var recordX:Number; //记录初始x坐标
var recordY:Number; //记录初始y坐标
var endX:Number; //记录结束x坐标
var endY:Number; //记录结束y坐标
var moveX:Number; //记录移动之后x坐标
var moveY:Number; //记录移动之后y坐标
var myImage:Bitmap; //显示图片的容器
var dragFlag:Boolean= false ; //用于判断选择框是否正在拖动
var clickPoint:Point; //记录开始的选择框对应的舞台坐标点
var endPoint:Point; //记录选择框绘制结束后选择框对应的舞台坐标点
initStage();
function initStage() {
     myImage= new Bitmap();
     addChild(myImage);
     bg.addEventListener(MouseEvent.MOUSE_DOWN,startDraw); //绘制选择框
     selectBox.addEventListener(MouseEvent.MOUSE_DOWN,dragSelectBox); //拖动选择框
     selectBox.addEventListener(MouseEvent.MOUSE_UP,stopDragSelectBox); //停止拖动选择框
}
function dragSelectBox(_evt:MouseEvent): void {
     _evt.currentTarget.startDrag();
     dragFlag= true ;
}
function stopDragSelectBox(_evt:MouseEvent) {
     if (dragFlag== true ) {
         createJPG(mc_image,selectBox,Math.min(selectBox.localToGlobal(clickPoint).x,selectBox.localToGlobal(endPoint).x),Math.min(selectBox.localToGlobal(clickPoint).y,selectBox.localToGlobal(endPoint).y));
         selectBox.stopDrag();
         dragFlag = false ;
     }
}
//开始绘制
function startDraw(_evt:MouseEvent): void {
     stage.addEventListener(Event.ENTER_FRAME,drawSelectBox);
     recordX = mouseX;
     recordY = mouseY;
     clickPoint = new Point(recordX,recordY);
}
//绘制选择框
function drawSelectBox(_evt:Event): void {
     selectBox.x=selectBox.y=0; //恢复坐标到原点
     selectBox.graphics.clear();
     selectBox.graphics.lineStyle(1,0x000000);
     selectBox.graphics.beginFill(0xffffff,0.7);
     selectBox.graphics.drawRect(recordX,recordY,mouseX-recordX,mouseY-recordY);
     selectBox.graphics.endFill();
     addChild(selectBox);
     stage.addEventListener(MouseEvent.MOUSE_UP,endDraw); // 鼠标在舞台上放开时的事件
}
//绘制结束
function endDraw(_evt:MouseEvent): void {
     stage.removeEventListener(Event.ENTER_FRAME,drawSelectBox);
     selectBox.stopDrag();
     dragFlag = false ;
     endX = mouseX;
     endY = mouseY;
     endPoint = new Point(endX,endY);
     createJPG(mc_image,selectBox,Math.min(recordX,endX),Math.min(recordY,endY));
     stage.removeEventListener(MouseEvent.MOUSE_UP,endDraw); //鼠标在舞台上放开时的事件
}
function createJPG(m:MovieClip,box:Sprite,originX:Number,originY:Number) {
     removeChild(myImage);
     var jpgSource:BitmapData= new BitmapData (m.width, m.height); //先把背景图转换成BitmapData
     jpgSource.draw(m);
     var rect:Rectangle = new Rectangle(originX,originY,box.width,box.height); //设置复制的区域和大小
     var pt:Point = new Point(0, 0); //复制到的对象的起始点
     var jpgOut:BitmapData= new BitmapData(box.width, box.height);
     jpgOut.copyPixels(jpgSource, rect, pt); //复制区域内容
     myImage = new Bitmap(jpgOut);
     addChild(myImage);

在Flash上点击左键拖动可以复制选中的图片内容到左上角,这个东西的具体用处,大概就是图片信息复制吧。

这篇关于AS3图像复制BitmapData.copyPixels()的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/673311

相关文章

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

禁止复制的网页怎么复制

禁止复制的网页怎么复制 文章目录 禁止复制的网页怎么复制前言准备工作操作步骤一、在浏览器菜单中找到“开发者工具”二、点击“检查元素(inspect element)”按钮三、在网页中选取需要的片段,锁定对应的元素四、复制被选中的元素五、粘贴到记事本,以`.html`为后缀命名六、打开`xxx.html`,优雅地复制 前言 在浏览网页的时候,有的网页内容无法复制。比如「360

Verybot之OpenCV应用一:安装与图像采集测试

在Verybot上安装OpenCV是很简单的,只需要执行:         sudo apt-get update         sudo apt-get install libopencv-dev         sudo apt-get install python-opencv         下面就对安装好的OpenCV进行一下测试,编写一个通过USB摄像头采

【python计算机视觉编程——7.图像搜索】

python计算机视觉编程——7.图像搜索 7.图像搜索7.1 基于内容的图像检索(CBIR)从文本挖掘中获取灵感——矢量空间模型(BOW表示模型)7.2 视觉单词**思想****特征提取**: 创建词汇7.3 图像索引7.3.1 建立数据库7.3.2 添加图像 7.4 在数据库中搜索图像7.4.1 利用索引获取获选图像7.4.2 用一幅图像进行查询7.4.3 确定对比基准并绘制结果 7.

【python计算机视觉编程——8.图像内容分类】

python计算机视觉编程——8.图像内容分类 8.图像内容分类8.1 K邻近分类法(KNN)8.1.1 一个简单的二维示例8.1.2 用稠密SIFT作为图像特征8.1.3 图像分类:手势识别 8.2贝叶斯分类器用PCA降维 8.3 支持向量机8.3.2 再论手势识别 8.4 光学字符识别8.4.2 选取特征8.4.3 多类支持向量机8.4.4 提取单元格并识别字符8.4.5 图像校正

HalconDotNet中的图像特征与提取详解

文章目录 简介一、边缘特征提取二、角点特征提取三、区域特征提取四、纹理特征提取五、形状特征提取 简介   图像特征提取是图像处理中的一个重要步骤,用于从图像中提取有意义的特征,以便进行进一步的分析和处理。HalconDotNet提供了多种图像特征提取方法,每种方法都有其特定的应用场景和优缺点。 一、边缘特征提取   边缘特征提取是图像处理中最基本的特征提取方法之一,通过检

超越IP-Adapter!阿里提出UniPortrait,可通过文本定制生成高保真的单人或多人图像。

阿里提出UniPortrait,能根据用户提供的文本描述,快速生成既忠实于原图又能灵活调整的个性化人像,用户甚至可以通过简单的句子来描述多个不同的人物,而不需要一一指定每个人的位置。这种设计大大简化了用户的操作,提升了个性化生成的效率和效果。 UniPortrait以统一的方式定制单 ID 和多 ID 图像,提供高保真身份保存、广泛的面部可编辑性、自由格式的文本描述,并且无需预先确定的布局。

Winfrom中解决图像、文字模糊的方法

1.添加清单 2.将清单中的下面内容取消注释

使用亚马逊Bedrock的Stable Diffusion XL模型实现文本到图像生成:探索AI的无限创意

引言 什么是Amazon Bedrock? Amazon Bedrock是亚马逊云服务(AWS)推出的一项旗舰服务,旨在推动生成式人工智能(AI)在各行业的广泛应用。它的核心功能是提供由顶尖AI公司(如AI21 Labs、Anthropic、Cohere、Meta、Mistral AI、Stability AI以及亚马逊自身)开发的多种基础模型(Foundation Models,简称FMs)。

node快速复制文件或文件夹,排除部分文件(node_modules)

const fs = require('fs')const path = require('path')/*** @description: 获取完整的文件路径* @param {*} url 路径* @return {*} 返回完整的文件路径*/const getPath = (url) => {return path.join(__dirname, url)}/*** @descr