日期: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