- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一张大尺寸的图片。为了节省内存,所以我不想一次加载整个图片,所以我将图像分成 9 张图片,如 3X3 数组
036
147
258
我可以将较小的图像片段从一个图像滚动到相邻图像,例如从 (1,1) 到 (1,2)(1,3),或从 (1,1) 到 (2,1) (3,1),但我无法将它从 (1,1) 滚动到 (2,2) 或 (3,3)。
看来我只能左右或上下滚动图片,但不能沿对角线滚动。
如果我沿对角线滚动,那么所有图像看起来都乱七八糟,如下所示:
360
471
582
如何沿对角线滚动和/或在滚动时跳过部分?
这是我的代码:
.h
CGPoint first;
IBOutlet UIScrollView *scr;
NSMutableArray *ary;
int x_total;
int y_total;
BOOL move;
BOOL inside;
IBOutlet UIView *mapview;
int x_begin;
int y_begin;
int x_times;
int y_times;
剪切图片
move = NO;
inside = NO;
x_times = 0;
y_total = 0;
ary = [NSMutableArray new];
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
UIImageView *img = [[UIImageView alloc] initWithImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_%d_%d.jpg", i ,j]]];
[img setFrame:CGRectMake((i-1) *64, (j-1)*64, 64, 64)];
[mapview addSubview:img];
[ary addObject:img];
}
}
x_begin = 64*2;
y_begin = 64*2;
x_total = 0;
y_total = 0;
以及控制手指触摸和移动的方法
- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{
NSLog(@"touchesBegan");
//Set Animation
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:1];
[UIView setAnimationBeginsFromCurrentState:YES];
//Trigger start
//UITouch *touch = [touches anyObject];
NSSet *teaches = [event allTouches];
for (UITouch *myTouch in teaches){
//first = [myTouch previousLocationInView:self.view];
CGPoint currentTouchPosition = [myTouch previousLocationInView:mapview];
//first = [myTouch previousLocationInView:mapview];
NSLog(@"currentTouchPosition x is %f",currentTouchPosition.x);
NSLog(@"currentTouchPosition y is %f",currentTouchPosition.y);
NSLog(@"mapview.frame.origin.x is %d",mapview.frame.origin.x);
NSLog(@"mapview.frame.origin.y is %d",mapview.frame.origin.y);
if ((currentTouchPosition.x > 0 && currentTouchPosition.x < 64) && (currentTouchPosition.y > 0 && currentTouchPosition.y < 64)) {
first = currentTouchPosition;
inside = YES;
}else {
first.x = 0;
first.y = 0;
inside = NO;
}
}
[UIView commitAnimations];
}
触摸移动
- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event{
//Touch Trigger
NSSet *teaches = [event allTouches];
for (UITouch *myTouch in teaches){
CGPoint currentTouchPosition = [myTouch previousLocationInView:mapview];
NSLog(@"currentTouchPosition.x is %d ",currentTouchPosition.x);
if (inside) {
if ((currentTouchPosition.x > 0 && currentTouchPosition.x < 64) && (currentTouchPosition.y > 0 && currentTouchPosition.y < 64)) {
int x = first.x-currentTouchPosition.x;
int y = first.y-currentTouchPosition.y;
x_total += x;
y_total += y;
NSLog(@"x_total is %d",x_total);
NSLog(@"y_total is %d",y_total);
NSArray *arr = [mapview subviews];
NSEnumerator *enumerator = [arr objectEnumerator];
id anObject;
UIImageView *tmpimg;
while (anObject = [enumerator nextObject]) {
if([anObject isMemberOfClass:[UIImageView class]]) {
tmpimg = (UIImageView *)anObject;
if (x < 0) {
[tmpimg setFrame:CGRectMake(tmpimg.frame.origin.x-x, tmpimg.frame.origin.y, tmpimg.frame.size.width, tmpimg.frame.size.height)];
}else {
[tmpimg setFrame:CGRectMake(tmpimg.frame.origin.x-x, tmpimg.frame.origin.y, tmpimg.frame.size.width, tmpimg.frame.size.height)];
}
if (y < 0) {
[tmpimg setFrame:CGRectMake(tmpimg.frame.origin.x, tmpimg.frame.origin.y-y, tmpimg.frame.size.width, tmpimg.frame.size.height)];
}else {
[tmpimg setFrame:CGRectMake(tmpimg.frame.origin.x, tmpimg.frame.origin.y-y, tmpimg.frame.size.width, tmpimg.frame.size.height)];
}
}
}
if (y_times == 0) {
if (y_total >= 64/2) {
y_times ++;
for (int i = 0; i < 3; i++) {
int g;
if (i == 0) {
g = 0;
}else if (i == 1) {
g = 3;
}else if (i == 2) {
g = 6;
}
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:g];
[[ary objectAtIndex:g] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_%d_3.jpg" ,i]]];
[[ary objectAtIndex:g] setFrame:CGRectMake(tmpimg.frame.origin.x, tmpimg.frame.origin.y+(64+64*2), 64, 64)];
tmpimg = nil;
}
y_total= 0;
}
if (x_times == 0) {
if (x_total >= 64/2) {
x_times ++;
for (int i = 0; i < 3; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_3_%d.jpg" ,i]]];
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x+(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}else if (x_times == 1) {
if (x_total >= 64) {
x_times ++;
for (int i = 3; i < 6; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_4_%d.jpg" ,i-3]]];
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x+(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}else if (x_total <= -64/2) {
x_times --;
for (int i = 0; i < 3; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_0_%d.jpg" ,i]]];
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x-(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}else if (x_times == 2) {
if (x_total >= 64) {
x_times ++;
for (int i = 6; i < 9; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_5_%d.jpg" ,i-6]]];
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x+(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}else if (x_total <= -64/2) {
x_times --;
for (int i = 3; i < 6; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_1_%d.jpg" ,i-3]]];
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x-(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}else if (x_times == 3) {
if (x_total <= -64/2) {
x_times --;
for (int i = 6; i < 9; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_2_%d.jpg" ,i-6]]];
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x-(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}
}
if (y_times == 1) {
if (y_total <= -64/2) {
y_times --;
for (int i = 0; i < 3; i++) {
int g;
if (i == 0) {
g = 0;
}else if (i == 1) {
g = 3;
}else if (i == 2) {
g = 6;
}
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:g];
[[ary objectAtIndex:g] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_%d_0.jpg" ,i]]];
[[ary objectAtIndex:g] setFrame:CGRectMake(tmpimg.frame.origin.x, tmpimg.frame.origin.y-(64+64*2), 64, 64)];
tmpimg = nil;
}
y_total= 0;
}
if (x_times == 0) {
if (x_total >= 64/2) {
x_times ++;
for (int i = 0; i < 3; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
if (i == 0) {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_3_%d.jpg" ,i+3]]];
}else {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_3_%d.jpg" ,i]]];
}
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x+(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}else if (x_times == 1) {
if (x_total >= 64) {
x_times ++;
for (int i = 3; i < 6; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
if (i == 3) {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_4_%d.jpg" ,i]]];
}else {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_4_%d.jpg" ,i-3]]];
}
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x+(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}else if (x_total <= -64/2) {
x_times --;
for (int i = 0; i < 3; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
if (i == 0) {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_0_%d.jpg" ,i+3]]];
}else {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_0_%d.jpg" ,i]]];
}
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x-(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}else if (x_times == 2) {
if (x_total >= 64) {
x_times ++;
for (int i = 6; i < 9; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
if (i == 3) {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_5_%d.jpg" ,i-3]]];
}else {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_5_%d.jpg" ,i-6]]];
}
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x+(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}else if (x_total <= -64/2) {
x_times --;
for (int i = 3; i < 6; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
if (i == 3) {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_1_%d.jpg" ,i]]];
}else {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_1_%d.jpg" ,i-3]]];
}
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x-(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}else if (x_times == 3) {
if (x_total <= -64/2) {
x_times --;
for (int i = 6; i < 9; i++) {
UIImageView *tmpimg;
tmpimg = [ary objectAtIndex:i];
if (i == 3) {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_2_%d.jpg" ,i-3]]];
}else {
[[ary objectAtIndex:i] setImage:[UIImage imageNamed:[NSString stringWithFormat:@"map14_2_%d.jpg" ,i-6]]];
}
[[ary objectAtIndex:i] setFrame:CGRectMake(tmpimg.frame.origin.x-(64+64*2), tmpimg.frame.origin.y, 64, 64)];
tmpimg = nil;
}
x_total= 0;
}
}
}
first.x = currentTouchPosition.x;
first.y = currentTouchPosition.y;
arr=nil;
}else {
first.x = 0;
first.y = 0;
inside = NO;
}
}else {
if ((currentTouchPosition.x > 0 && currentTouchPosition.x < 64) && (currentTouchPosition.y > 0 && currentTouchPosition.y < 64)) {
first = currentTouchPosition;
inside = YES;
}else {
first.x = 0;
first.y = 0;
inside = NO;
}
}
}
}
最佳答案
这听起来有点像您要重新发明轮子。
您是否研究过 UIScrollView?
特别是,有示例代码(我相信是 ImageSuite),它专门展示了如何将较大的图像切 block 成图 block ,然后仅根据需要将它们放置在允许向任何方向滚动的 ScrollView 中。
例如,MKMapView (Maps.app) 就是这样工作的。
关于苹果手机 SDK :Can't diagonal scrolling in a image array?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4278256/
我对这个错误很困惑: Cannot implicitly convert type 'System.Func [c:\Program Files (x86)\Reference Assemblies\
考虑这段代码: pub trait Hello { fn hello(&self); } impl Hello for Any { fn hello(&self) {
问题很简单。是否可以构造这样一个类型 T,对于它下面的两个变量声明会产生不同的结果? T t1 = {}; T t2{}; 我已经研究 cppreference 和标准一个多小时了,我了解以下内容:
Intellij idea 给我这个错误:“Compare (T, T) in Comparator cannot be applied to (T, T)” 对于以下代码: public class
任何人都可以告诉我 : n\t\t\t\t\n\t\t\t 在以下来自和 dwr 服务的响应中的含义和用途是什么. \r\n\t\t\t \r\n\t\t\t
让 T 成为一个 C++ 类。 下面三个指令在行为上有什么区别吗? T a; T a(); T a = T(); T 为不带参数的构造函数提供了显式定义这一事实是否对问题有任何改变? 后续问题:如果
Rust中的智能指针是什么 智能指针(smart pointers)是一类数据结构,是拥有数据所有权和额外功能的指针。是指针的进一步发展 指针(pointer)是一个包含内存地
比如我有一个 vector vector > v={{true,1},{true,2},{false,3},{false,4},{false,5},{true,6},{false,7},{true,8
我有一个来自 .xls 电子表格的数据框,我打印了 print(df.columns.values) 列,输出包含一个名为:Poll Responses\n\t\t\t\t\t。 我查看了 Excel
This question already has answers here: What are good reasons for choosing invariance in an API like
指针类型作为类型前缀与在类型前加斜杠作为后缀有什么区别。斜线到底是什么意思? 最佳答案 语法 T/~ 和 T/& 基本上已被弃用(我什至不确定编译器是否仍然接受它)。在向新向量方案过渡的初始阶段,[T
我正在尝试找到一种方法来获取模板参数的基类。 考虑以下类: template class Foo { public: Foo(){}; ~Foo(){};
这是一个让我感到困惑的小问题。我不知道如何描述它,所以只看下面的代码: struct B { B() {} B(B&) { std::cout ::value #include
为什么有 T::T(T&) 而 T::T(const T&) 更适合 copy ? (大概是用来实现move语义的???) 原始描述(被melpomene证明是错误的): 在C++11中,支持了一种新
在 Java 7 中使用 eclipse 4.2 并尝试实现 List 接口(interface)的以下方法时,我收到了警告。 public T[] toArray(T[] a) { ret
假设有三个函数: def foo[T](a:T, b:T): T = a def test1 = foo(1, "2") def test2 = foo(List(), ListBuffer()) 虽
我对柯里化(Currying)和非柯里化(Currying)泛型函数之间类型检查的差异有点困惑: scala> def x[T](a: T, b: T) = (a == b) x: [T](a: T,
考虑一个类A,我如何编写一个具有与相同行为的模板 A& pretty(A& x) { /* make x pretty */ return x; } A pretty(A&& x) {
Eclipse 表示由于泛型类型橡皮擦,类型参数不允许使用 instanceof 操作。 我同意在运行时不会保留任何类型信息。但是请考虑以下类的通用声明: class SomeClass{ T
在 C++14 中: 对于任何整数或枚举类型 T 以及对于任何表达式 expr: 有没有区别: struct S { T t { expr }; }; 和 struct S { T t = { exp
我是一名优秀的程序员,十分优秀!