日期:2012-5-10 来源:GBin1.com
说起logo设计,到底什么样的设计才可以算得上是好的设计?是复杂多样、色彩丰富的?还是有视觉冲击力的?让我们试着回想一下我们常看到的那些 logo标识,记忆犹新的反而是那些色彩简单内容突出且不重复的设计。或许就是几个字母、几个简单的符号,组成了独具创意的设计。我们收集了下面这20款 简单独特的logo设计,希望以它们做为参考可以激发你的创意灵感,设计出属于你的独一无二的logo标识!希望大家喜欢!
.....
.....
来源:20款简洁独特的logo设计
最近的项目中用到了几个比较不常用的方法:
(1)获取设备的唯一标示,有的应用,如银行、支付、广告等可能需要绑定设备,但是苹果由于种种原因现在已经停止了使用UIDivice的uniqueIdentifier属性,所以只有改用MAC地址。
(2)有些金融类的应用出于安全对已越狱的设备进行友谊提示,所以要判断ios是否越狱。
#import <Foundation/Foundation.h> @interface UIDevice (Help) /* *根据mac地址和设备信息获取设备唯一标示(ios5以后的系统中已经停止使用设备标示uniqueIdentifier) */ - (NSString *) uniqueDeviceIdentifier; /* *根据mac地址获取设备唯一标示(ios5以后的系统中已经停止使用设备标示uniqueIdentifier) */ - (NSString *) uniqueGlobalDeviceIdentifier; /* *判断设备是否越狱 */ - (BOOL)isJailbroken; @end
#import "UIDevice+Help.h"
#import "NSString+MD5Addition.h"
#include <sys/socket.h>
#include <sys/sysctl.h>
#include <net/if.h>
#include <net/if_dl.h>
@interface UIDevice(Private)
- (NSString *) macaddress;
@end
@implementation UIDevice (Help)
#pragma mark -
#pragma mark Private Methods
/*
*获取MAC地址
*/
- (NSString *) macaddress{
int mib[6];
size_t len;
char *buf;
unsigned char *ptr;
struct if_msghdr *ifm;
struct sockaddr_dl *sdl;
mib[0] = CTL_NET;
mib[1] = AF_ROUTE;
mib[2] = 0;
mib[3] = AF_LINK;
mib[4] = NET_RT_IFLIST;
if ((mib[5] = if_nametoindex("en0")) == 0) {
printf("Error: if_nametoindex error\n");
return NULL;
}
if (sysctl(mib, 6, NULL, &len, NULL, 0) < 0) {
printf("Error: sysctl, take 1\n");
return NULL;
}
if ((buf = malloc(len)) == NULL) {
printf("Could not allocate memory. error!\n");
return NULL;
}
if (sysctl(mib, 6, buf, &len, NULL, 0) < 0) {
printf("Error: sysctl, take 2");
free(buf);
return NULL;
}
ifm = (struct if_msghdr *)buf;
sdl = (struct sockaddr_dl *)(ifm + 1);
ptr = (unsigned char *)LLADDR(sdl);
NSString *outstring = [NSString stringWithFormat:@"%02X:%02X:%02X:%02X:%02X:%02X",
*ptr, *(ptr+1), *(ptr+2), *(ptr+3), *(ptr+4), *(ptr+5)];
free(buf);
return outstring;
}
#pragma mark -
#pragma mark Public Methods
- (NSString *) uniqueDeviceIdentifier{
NSString *macaddress = [[UIDevice currentDevice] macaddress];
NSString *bundleIdentifier = [[NSBundle mainBundle] bundleIdentifier];
NSString *stringToHash = [NSString stringWithFormat:@"%@%@",macaddress,bundleIdentifier];
NSString *uniqueIdentifier = [stringToHash stringFromMD5];
return uniqueIdentifier;
}
- (NSString *) uniqueGlobalDeviceIdentifier{
NSString *macaddress = [[UIDevice currentDevice] macaddress];
NSString *uniqueIdentifier = [macaddress stringFromMD5];
return uniqueIdentifier;
}
- (BOOL)isJailbroken {
BOOL jailbroken = NO;
NSString *cydiaPath = @"/Applications/Cydia.app";
NSString *aptPath = @"/private/var/lib/apt/";
if ([[NSFileManager defaultManager] fileExistsAtPath:cydiaPath]) {
jailbroken = YES;
}
if ([[NSFileManager defaultManager] fileExistsAtPath:aptPath]) {
jailbroken = YES;
}
return jailbroken;
}
@end
MD5加密
#import <Foundation/Foundation.h> @interface NSString(MD5Addition) - (NSString *) stringFromMD5; @end
#import "NSString+MD5Addition.h"
#import <CommonCrypto/CommonDigest.h>
@implementation NSString(MD5Addition)
- (NSString *) stringFromMD5{
if(self == nil || [self length] == 0)
return nil;
const char *value = [self UTF8String];
unsigned char outputBuffer[CC_MD5_DIGEST_LENGTH];
CC_MD5(value, strlen(value), outputBuffer);
NSMutableString *outputString = [[NSMutableString alloc] initWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
for(NSInteger count = 0; count < CC_MD5_DIGEST_LENGTH; count++){
[outputString appendFormat:@"%02x",outputBuffer[count]];
}
return [outputString autorelease];
}
@end
日期:2012-5-14 来源:GBin1.com
在线演示 本地下载
是不是也考虑生成一个矢量类型的地图?今天我们将介绍的这款jQuery插件 - JQVMAP 可 以方便的帮助你生成漂亮的矢量地图。在现代浏览器中它使用了SVG(Scalable Vector Graphics)技术生成地图图片,如果你也需要支持老版本的浏览器,例如,IE6/7/8的话,它也可以通过VML来实现,非常不错的jQuery插 件,相信大家一定会喜欢!
主要特性- 支持现代浏览器,同时对于老版本浏览器也可以通过其它fallback方式支持
- 支持缩放,拖动查看
- 提供丰富的地图生成参数
- 目前支持:世界地图,美国地图,欧洲,德国地图
- 你可以自己定义自己的地图(当然,这个过程比较繁琐)
- 实时更新地图
- 需要jQuery类库支持
- 完整清晰的文档说明
JQVAMP使用非常简单,导入jQuery类库和插件类库,如下:
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" type="text/javascript"></script> <script src="/jqvmap/jquery.vmap.js" type="text/javascript"></script> <script src="/jqvmap/maps/jquery.vmap.world.js" type="text/javascript"></script> <script src="/jqvmap/data/jquery.vmap.sampledata.js" type="text/javascript"></script>
地图插件生成代码:
jQuery(document).ready(function
() {
jQuery(
'#vmap').vectorMap({
map:
'world_en',
backgroundColor:
'#202020',
color:
'#5DB0E6',
hoverOpacity:
0.7,
selectedColor:
'#333333',
enableZoom:
true
,
showTooltip:
true
,
values: sample_data,
scaleColors: [
'#C8EEFF', '#006491'],
normalizeFunction:
'polynomial',
onRegionOver:
function
(element, code, region){
$(
'#region').html(region);
},
onRegionClick:
function
(element, code, region){
$(
'#region').html('You selected "' + region + '"');
}
});
});
插件的文档非常完善,你可以很方便的查看相关的选项和callback方法。相信大家肯定有机会应用到自己的网站开发和设计中,希望大家喜欢,如果你有任何问题和建议请给我们留言,谢谢!
来源:超棒的jQuery矢量地图生成插件 - JQVAMP