- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用fabricjs 。使用asp.net mvc3。我想在图像上作为组绘制文本和矩形。文本和矩形可以多次添加。添加组后,我想保存该图像,准确性很重要。
我有两个选择。第一个选择是使用canvas.toJSON()。这种方法我必须使用 C# 图形类创建对象,这是痛苦且不准确的。其次是将 Canvas 导出为准确的 Base64。
这是给出异常的代码:
function SaveResultImage() {
canvas.deactivateAll().renderAll();
var base64String = canvas.toDataURL("image/jpg");// this line gives exception
if (!fabric.Canvas.supports('toDataURL')) {
alert('This browser doesn\'t provide means to serialize canvas to an image');
} else {
console.log(base64String);
// save image posting base64String using ajax// this is working fine
}
}
exception: VM1226 fabric.min.js:4 Uncaught DOMException: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.(…)
最佳答案
似乎您的图像来源有问题,我使用了 cross origin image provided by WikiMedia 。当您从 Fabric 中的 URL 加载图像时,添加 { crossOrigin: 'Anonymous' }
.
查看下面更新后的代码片段:
alert('click apply to add text and rectangle');
$(document).ready(function() {
});
function createCustomComments() {
try {
var selText = $('#txtCustomComments').val();
var color = new fabric.Color(colorPicker.val()).toRgb();
var fontSize = fontPicker.val();
commentText = new fabric.IText(selText, {
fontSize: fontSize,
hasControls: false,
hasBorders: true,
originX: 'center',
backgroundColor: 'rgba(0,0,0,0)',
borderColor: color,
//opacity: 0.6,
fill: color,
fontFamily: "helvetica"
});
var commentRectange = new fabric.Rect({
originX: 'center',
top: 30,
width: 300,
height: 200,
fill: 'rgba(0,0,0,0)',
stroke: color,
strokeWidth: 4
});
var group = new fabric.Group([commentText, commentRectange], {
left: 100,
top: 150
});
canvas.add(group);
canvas.bringForward(group);
} catch (exception) {
console.log(exception);
}
}
$('#btnApplyComments').on('click', function() {
createCustomComments();
});
$('#btnSave').on('click', function() {
SaveResultImage();
});
$('#getjson').on('click', function() {
getfabricJsonToText();
});
var commentRectange, commentText;
var canvas = new fabric.Canvas('wmcCanvas', {
selection: true
});
var colorPicker = $('#btnColor');
var fontPicker = $('#bntfontsize');
var image = new Image();
var imageComp;
image.crossOrigin = "Anonymous";
image.onload = function() {
// the url is sub domain the image below is dummy
imageComp = fabric.Image.fromURL('https://upload.wikimedia.org/wikipedia/commons/0/0e/American_Black_Bear_%283405475634%29.jpg', function(img) {
var oImg = img.set({
angle: 0,
cornersize: 10,
hoverCursor: "default",
lockMovementX: true,
lockMovementY: true,
lockRotation: true,
hasRotatingPoint: true,
hasControls: false,
hasBorders: false,
lockScalingFlip: true,
lockScalingX: true,
lockScalingY: true,
lockSkewingX: true,
lockSkewingY: true,
height: image.naturalHeight,
width: image.naturalWidth
});
canvas.add(oImg);
canvas.moveTo(oImg, window.objectIndex);
}, { crossOrigin: 'Anonymous' });
canvas.setHeight(image.naturalHeight);
canvas.setWidth(image.naturalWidth);
};
image.src = "https://upload.wikimedia.org/wikipedia/commons/0/0e/American_Black_Bear_%283405475634%29.jpg";
function SaveResultImage() {
canvas.deactivateAll().renderAll();
var base64String = canvas.toDataURL("image/jpg");
//var base64String = canvas.toSVG();
//base64String = base64String.replace(/^data:image\/(png|jpg);base64,/, "");
if (!fabric.Canvas.supports('toDataURL')) {
alert('This browser doesn\'t provide means to serialize canvas to an image');
} else {
console.debug(base64String);
// save image
}
}
.wmc_main {
width: 420px;
background: #F7F7F7;
height: 75px;
margin: 0 auto;
padding: 10px 20px;
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: center;
-webkit-justify-content: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
-webkit-flex-wrap: wrap;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
border-bottom: 5px solid #e3e3e3;
padding-bottom: 8px;
}
.wmc_main span {
color: #585858;
}
.main-dropdown form {
width: 244px;
float: left;
}
.main-dropdown form select.pls-select {
height: 30px;
width: 230px;
border: 1px solid #dadada;
color: #6b6b6b;
padding: 0 10px;
}
.showhideCustomComment {
width: 100%;
float: left;
}
.comment-dropdown input.pls-select-comments {
height: 27px;
width: 210px;
border: 1px solid #dadada;
padding: 0 10px;
color: #6b6b6b;
}
.comment-dropdown.showhideCustomComment {
width: 100%;
padding-bottom: 10px;
}
.showhideCustomComment span {
width: 126px !important;
}
.comment-apply-btn {
height: 30px;
padding: 0 5px 0 5px;
background: #05b5ef;
border: none;
color: #fff;
line-height: 30px;
margin-left: 0px;
margin-top: 2px;
}
.wmc_main .main-dropdown span,
.wmc_main .comment-dropdown span {
width: 126px;
float: left;
line-height: 30px;
color: #05b5ef;
}
.wmc_main .main-dropdown {
margin-bottom: 8px;
width: 100%;
float: left;
}
.wmc_main .color-picker {
width: 182px;
float: left;
}
.color-picker span {
float: left;
line-height: 26px;
width: 126px;
}
.color-box {
width: 16px;
height: 14px;
background: #ff0c0c;
border: 6px solid #ebebeb;
float: left;
}
.comment-dropdown {
/* width: 100px; margin-bottom: 8px; padding-top: 8px; */
width: 105px;
float: left;
padding-top: 0;
}
input.wmc-font-size {
width: 32px;
padding: 0 0 0 4px;
height: 24px;
border: 1px solid #ebebeb;
}
input.wmc-font-color {
width: 28px;
height: 24px;
border: 1px solid #ebebeb;
padding: 3px;
}
.main-font-size {
margin: 0 8px 0 0;
width: 125px;
float: left;
display: block;
}
.font-setting {
width: 100%;
float: left;
/* padding: 0 0 0 36px;*/
}
.main-font-size span {
line-height: 26px;
float: left;
margin-right: 5px;
width: 68px;
}
.show-setting {
width: 92%;
float: left;
margin-bottom: 10px;
}
.show-setting span {
color: #575757;
}
.show-setting span img {
padding-left: 10px;
}
.color-picker span {
color: #575757;
}
.setting-btn:hover {
background: #77b800;
}
.setting-btn {
background: #8fd400 none repeat scroll 0 0;
border: 0 none;
color: #fff;
font-size: 14px;
font-weight: bold;
height: 35px;
margin-left: 2px;
padding: 0;
text-transform: uppercase;
width: 130px;
}
.share-post-history .dialogshare {
width: 228px;
}
.canvas-container {
margin-top: 30px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://rawgit.com/kangax/fabric.js/master/dist/fabric.js"></script>
<div class="wmc_main" style="display: flex;">
<div class="main-dropdown">
<span>Select comments:</span>
<input id="txtCustomComments" name="Comment" value="dummy text" placeholder="Custom comments here" class="pls-select-comments" type="text">
<button name="btn-apply" id="btnApplyComments" value="apply" class="comment-apply-btn">
Apply</button>
</div>
<div class="font-setting">
<div class="color-picker">
<span>Font Color:</span>
<input id="btnColor" class="wmc-font-color" name="favcolor" value="#FF0000" type="color">
</div>
<div class="main-font-size">
<span>Font Size:</span>
<input id="bntfontsize" class="wmc-font-size" min="6" max="72" step="2" value="20" type="number">
</div>
<div class="comment-dropdown">
<span></span>
<input id="btnSave" value="Save" class="comment-apply-btn" type="button">
<input value="Reset" onclick="reset()" class="comment-apply-btn" type="button">
</div>
</div>
<canvas id="wmcCanvas">Your browser does not support the canvas element.</canvas>
</div>
你的 fork fiddle
关于javascript - 在 C# 和 Fabric.js 中添加对象并保存图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40888121/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!