- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们的应用程序具有在便笺簿上绘制签名的功能。我们正在使用由 szimek 创建的签名板并使用 Ionic AngularJS 框架。
此人点击一个按钮,系统打开一个模态屏幕,然后显示签名板。用户可以清除和保存图像。当他保存并再次打开签名板(通过按下按钮)时,会显示之前绘制的图像,用户可以向其中添加内容。
我们遇到的问题是在 Android 设备上。当用户绘制图像并返回到签名 View 时,它会显示之前绘制的图像,但当用户清除它时它不会消失。它确实“清除”了它,因为在保存它之后,它保存了一个空图像。它几乎就像它显示缓存的图像一样。我们希望屏幕在按下“清除”按钮后清除任何图像。
在删除 Canvas 的过程中,Android 无法正确执行某些操作。在每个其他测试设备(iPad、桌面上的浏览器)中,它似乎工作正常。
这一切都始于 orderView.html。在那里我分配了一个点击事件来打开带有签名板的模态屏幕:
<ion-item ng-click="openModal('app/components/order/signature/signaturepadView.html', $event)">
<div class="signature padding" ng-switch="_signatureImage || '_undefined_'">
<img ng-switch-when="_undefined_" ng-src="assets/img/signature_placeholder.png" alt="" />
<img ng-switch-default ng-src="{{_signatureImage}}" alt="" />
</div>
</ion-item>
ionic 模态代码:
// Ionic Modal
$ionicModal.fromTemplateUrl('modal', {
scope: $scope,
animation: 'slide-in-up'
}).then(function (modal) {
$scope.modal = modal;
});
$scope.openModal = function (include, $event) {
$event.stopPropagation();
$scope.include = include;
$scope.modal.show();
};
$scope.closeModal = function () {
$scope.modal.hide();
$scope._signatureImage = OrderService.getSignatureImage();
};
// Cleanup the modal when we're done with it!
$scope.$on('$destroy', function () {
$scope.modal.remove();
});
这是 signatureView.html 文件中的代码。
<ion-modal-view class="modal" ng-controller="SignatureCtrl">
<ion-pane>
<ion-header-bar class='bar-stable'>
<h1 class='title'> Signature </h1>
<ion-header-buttons side="left">
<button class="button signature-back-button" ng-click="closeModal()"><i class="icon ion-ios-arrow-back"></i> Back</button>
</ion-header-buttons>
</ion-header-bar>
<ion-content class='has-header' scroll='false'>
<canvas id='signatureCanvas'></canvas>
<div class='button-bar'>
<a class='button button-positive' ng-click='clearCanvas()'>Clear</a>
<a class='button button-balanced' ng-click='saveCanvas(); closeModal()'>Save</a>
</div>
<br>
</ion-content>
</ion-pane>
</ion-modal-view>
该函数正在 signatureController.js 中处理:
angular.module('directory.signatureController', [])
.controller('SignatureCtrl', function ($scope, OrderService) {
var canvas = document.getElementById('signatureCanvas');
resizeCanvas();
var signaturePad = new SignaturePad(canvas);
signaturePad.backgroundColor = "white";
signaturePad.minWidth = 2;
signaturePad.maxWidth = 4.5;
$scope.clearCanvas = function () {
signaturePad.clear();
}
$scope.saveCanvas = function () {
var sigImg = signaturePad.toDataURL();
$scope.signature = sigImg;
OrderService.setSignatureImage(sigImg);
}
function resizeCanvas() {
var ratio = window.devicePixelRatio || 1;
canvas.width = window.innerWidth; //document.width is obsolete
canvas.height = window.innerHeight - 96; //document.height is obsolete
};
});
从这里我建议在 signature_pad.js 中查找代码。我认为问题出在 clear 函数中,因此我可以链接到签名文件中的 clear 函数。 For the full code here a link to his github.
SignaturePad.prototype.clear = function () {
var ctx = this._ctx,
canvas = this._canvas;
ctx.fillStyle = this.backgroundColor;
ctx.clearRect(0, 0, canvas.width, canvas.height);
ctx.fillRect(0, 0, canvas.width, canvas.height);
this._reset();
};
请帮助我们,如果这个问题的格式太模糊或需要详细说明,请告诉我,我会进行编辑。
最佳答案
在之前的所有测试中
signaturePad.backgroundColor = "white";
不需要。我们添加了它,之后没有测试这是否是解决方案。经过今天早上的简短测试后,设置 SignaturePad 背景颜色似乎可以解决此问题。
所以我们的问题的答案已经在我们的代码中了。考虑一下这个问题因此解决了。
关于javascript - Canvas SignaturePad 无法在 Mobile Phonegap 应用程序 (Android) 上清除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29922621/
我有一个网站,我正在通过学校参加比赛,但我在清除 float 元素方面遇到了问题。 该网站托管在 http://www.serbinprinting.com/corey/development/
我有一个清除按钮,需要使用 JQuery 函数清除该按钮单击时的 TextBox 值(输入的)。 最佳答案 您只需将单击事件附加到按钮即可将输入元素的值设置为空。 $("#clearButton").
我们已经创建了一个保存到 CoreData 然后同步到 CloudKit 的 iOS 应用程序。在测试中,我们还没有找到一种方法来清除应用程序 iCloud 容器中的数据(用于用户私有(private
这是一个普遍的问题,也是我突然想到并且似乎有道理的问题。我看到很多人使用清除div 并且知道这有时不受欢迎,因为它是额外的标记。我最近开始使用 因为它接缝代表了它的实际用途。 当然都引用了:.clea
我有两个单选按钮。如果我检查第一个单选按钮下面的数据将填充在组合框中。之后我将检查另一个单选按钮,我想清除组合框值。 EmployeeTypes _ET = new EmployeeTypes(
我一直在玩 Canvas ,我正在尝试制作一个可以移动和跳跃的正方形,移动部分已经完成,但是跳跃部分有一个问题:每次跳跃时它都会跳得更快 here's a jsfiddle 这是代码: ///////
我该如何在 Dart 上做到这一点? 抓取tbody元素后,我想在其上调用empty(),但这似乎不存在: var el = query('#search_results_tbody'); el.em
我需要创建一个二维模拟,但是在设置新的“框架”时,旧的“框架”不会被清除。 我希望一些圆圈在竞技场中移动,并且每个循环都应删除旧圆圈并生成新圆圈。一切正常,但旧的没有被清除并且仍然可见,这就是我需要改
无论我使用set statusline将状态行更改为什么,我的状态行都不会改变。看起来像 ".vimrc" 39L, 578C
在 WPF 应用程序中,我有一个 ListView 绑定(bind)到我的 ViewModel 上的一个 ObservableCollection。 在应用程序运行期间,我需要删除并重新加载集合中的所
我有一个大型程序,一个带有图形的文本扭曲游戏。在我的代码中的某处,我使用 kbhit() 我执行此代码来清除我的输入缓冲区: while ((c = getchar()) != '\n' && c !
我正在将所有网站的页面加载到主索引页面中,并通过将 href 分成段并在主域名后使用 .hash 函数添加段来更新 URL 显示,如下所示: $('a').click(function(event)
我有一个带有 的表单和 2 控件来保存和重置表单。我正在触发 使用 javascript __doPostBack()函数并在其中传递一个值 __EVENTARGUMENT如果面板应该重置。 我的代
我目前有一堆 UIViewController,每个都是在前一个之上呈现的模式 ViewController。我的问题是我不需要一堆 UIViewController,我只需要最后一个。因此,当出现新
我在一个类中有一些属性方法,我想在某个时候清除这个属性的缓存。 示例: class Test(): def __init__(self): pass @property
在此Test Link我试图将标题和主站点导航安装到博客脚本的顶部。 我清除:两者;在主要网站脚本上工作,但现在把所有东西都扔到了一边。尝试了无数次 fixex 都没有成功!提前感谢 Ant 指点解决
我似乎无法正确清除布局。看this 我无法阻止左栏中的元素向下推右栏中的元素。谁能帮忙? Screenshot with some pointy arrows (死链接) 最佳答案 问题标记/样式似
我希望能够在某个类 (sprite-empos) 之后清除 '' 中的内容,想知道是否有不添加任何新类或不使用 js 的方法(我在下面尝试过不工作)? 为了明确它是“985”,我想在某个视口(view
我想清除ptr_array boost::ptr_array a; ... a.clear(); // missing 如何清理 ptr 容器? 最佳答案 它应该表现得像一个数组,您不能在 C++
这是我使用多 map 制作的一个简单的事件系统;当我使用 CEvents::Add(..) 方法时,它应该插入并进入多重映射。问题是,当我触发这些事件时, multimap 似乎是空的。我确定我没有调
我是一名优秀的程序员,十分优秀!