iOS開發基礎知識--碎片20

 

 iOS開發基礎知識--碎片20

1:view中的clipsTobounds屬性git

iew2添加view1到中,若是view2大於view1,或者view2的座標不全在view1的範圍內,view2是蓋着view1的,意思就是超出的部份也會畫出來,UIView有一個屬性,clipsTobounds 默認狀況下是NO。若是,咱們想要view2把超出的那部份隱藏起來的話,就得改變它的父視圖也就view1的clipsTobounds屬性值。view1.clipsTobounds = YES;
能夠很好地解決覆蓋的問題

2:UIScrollView滾動視圖加載單元格點擊事件算法

複製代碼
svView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, mainWidth, perHeight)];
        svView.bounces = NO;
        svView.contentSize = CGSizeMake(perWidth*6, perHeight);
        UITapGestureRecognizer* tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapClick:)];
        [self addGestureRecognizer:tap];
        [self addSubview:svView];

事件:

- (void)tapClick:(UITapGestureRecognizer*)tap
{
    CGPoint point = [tap locationInView:svView];
    int page = point.x / perWidth;
    HomeHostest* hot = [myData objectAtIndex:page];
    if(delegate)
    {
        [delegate adClick:[NSString stringWithFormat:@"goodsdetail,%@",[hot.goodsID stringValue]]];
    }
}

- (CGPoint)locationInView:(UIView *)view:函數返回一個CGPoint類型的值,表示觸摸在view這個視圖上的位置,這裏返回的位置是針對view的座標系的。調用時傳入的view參數爲空的話,返回的時觸摸點在整個窗口的位置。
 
(CGPoint)previousLocationInView:(UIView *)view:該方法記錄了前一個座標值,函數返回也是一個CGPoint類型的值, 表示觸摸在view這個視圖上的位置,這裏返回的位置是針對view的座標系的。調用時傳入的view參數爲空的話,返回的時觸摸點在整個窗口的位置。
複製代碼

3:對錶格中的某個節跟每一行進行單獨刷新sql

[self.myTableView reloadRowsAtIndexPaths:@[[NSIndexPath indexPathForRow:0 inSection:0]] withRowAnimation:UITableViewRowAnimationAutomatic];

4:相似微信的搜索附近的人的功能 在 服務端的實現 服務器

複製代碼
基準線預先計算法
每一個用戶在服務器端都會保留最後的經度j1 和緯度w1 的同時 保留對經度基準線的相對距離 dj1 和緯度基準線的相對距離 dw1
經度基準線能夠是中國最東邊的經度  緯度基準線能夠是中國最北邊的緯度  


當前用戶對經度基準線的相對距離 dj2 =230km 和緯度基準線的相對距離 dw2=350km
查找時sql語句能夠這麼寫(1.5千米內的用戶) 
select * from user where dj1>(230-1.5) and dj1<(230+1.5) and  dw1>(230-1.5) and dw1<(230+1.5)
至關於得到當前用戶 周圍正方形1.5千米區域的用戶


此外經過將冷熱數據分開存放及 分塊存放 用戶地理數據應該能有效的提升查詢速度
另附:(考慮把經度和緯度分紅多個表存放,好比24個經度表,每一個表按緯度分別排序,查找時只在最靠近的那個表查找,因爲是排序的因此並不須要遍歷每一個記錄,好比緯度相差多少的就不用再找了。 )
複製代碼

5:定位一些基礎內容 CLLocation微信

複製代碼
01. CLLocation
--------------------------------------------------------
CLLocationManager 定位管理者
CLLocation 表明位置(經度/緯度/高度/速度/路線等)
CLHeading  表明移動方向
CLRegion   表明一個區域
>CLCircularRegion  圓形區域
>CLBeaconRegion 藍牙信號區域

返回定位服務是否可用
[CLLocationManager locationServicesEnabled];
返回延遲定位更新是否可用
[CLLocationManager deferredLocationUpdatesAvailable];
返回重大位置改變監聽是否可用
[CLLocationManager significantLocationChangeMonitoringAvailable];
返回是否支持磁力計算方向
[CLLocationManager headingAvailable];
返回藍牙信號範圍服務是否可用
[CLLocationManager isRangingAvailable];

--------------------------------------------------------
設置是否能夠暫停定位來節省電池電量, YES不須要定位數據時自動暫停定位
// mgr.pausesLocationUpdatesAutomatically

--------------------------------------------------------
每隔多少米定位一次, 只有水平方向超過該值時纔會從新定位
// mgr.distanceFilter = 100;

--------------------------------------------------------
定位精確度
// mgr.desiredAccuracy;
kCLDistanceFilterNone;
kCLLocationAccuracyBestForNavigation 導航級最佳精準
kCLLocationAccuracyBest; 最佳精準
kCLLocationAccuracyNearestTenMeters; 10米偏差
kCLLocationAccuracyHundredMeters; 百米胡茬
kCLLocationAccuracyKilometer;  公里偏差
kCLLocationAccuracyThreeKilometers; 3公里偏差

--------------------------------------------------------
定位數據的用途
// mgr.activityType;
CLActivityTypeOther 做爲普通用途
CLActivityTypeAutomotiveNavigation  做爲車輛導航
CLActivityTypeFitness  做爲步行
CLActivityTypeOtherNavigation 做爲其它導航

--------------------------------------------------------
// CLLocation
location.coordinate; 座標, 包含經緯度
location.altitude; 設備海拔高度 單位是米
location.course; 設置前進方向 0表示北 90東 180南 270西
location.horizontalAccuracy; 水平精準度
location.verticalAccuracy; 垂直精準度
location.timestamp; 定位信息返回的時間
location.speed; 設備移動速度 單位是米/秒, 適用於行車速度而不太適用於步行
/*
 能夠設置模擬器模擬速度
 bicycle ride 騎車移動
 run 跑動
 freeway drive 高速公路駕車
 */

--------------------------------------------------------
// CLAuthorizationStatus
用戶從未選擇過權限
kCLAuthorizationStatusNotDetermined
沒法使用定位服務,該狀態用戶沒法改變
kCLAuthorizationStatusRestricted
用戶拒絕該應用使用定位服務,或是定位服務總開關處於關閉狀態
kCLAuthorizationStatusDenied
已經受權(廢棄)
kCLAuthorizationStatusAuthorized
用戶容許該程序不管什麼時候均可以使用地理信息
kCLAuthorizationStatusAuthorizedAlways
用戶贊成程序在可見時使用地理位置
kCLAuthorizationStatusAuthorizedWhenInUse

--------------------------------------------------------
// 計算兩個位置之間的距離, 單位是米
[newLocation distanceFromLocation:self.prevLocation];

--------------------------------------------------------
獲取方向信息不會提示用戶(不須要受權), 由於不會泄露隱私
// [self.mgr startUpdatingHeading];

magneticHeading 設備與磁北的相對角度
trueHeading 設置與真北的相對角度, 必須和定位一塊兒使用, iOS須要設置的位置來計算真北
真北始終指向地理北極點
磁北對應隨着時間變化的地球磁場北極

// 牛逼的地方
116.958776,36.721199


--------------------------------------------------------
// 錯誤:使用CoreLocation獲取地理位置信息,報錯
Error Domain=kCLErrorDomain Code=0 "The operation couldn’t be completed. (kCLErrorDomain error 0.)"

解決方法:
1.肯定模擬器(手機)已經聯網而且容許程序獲取地理位置
2.重置地理位置服務或者網絡服務

PS:若是是模擬器就果斷直接重置模擬器吧  IOS Simulator - Reset Content and Settings..。


    /*
     注意: iOS7只要開始定位, 系統就會自動要求用戶對你的應用程序受權. 可是從iOS8開始, 想要定位必須先"本身""主動"要求用戶受權
      在iOS8中不只僅要主動請求受權, 並且必須再info.plist文件中配置一項屬性才能彈出受權窗口
     NSLocationWhenInUseDescription,容許在前臺獲取GPS的描述
     NSLocationAlwaysUsageDescription,容許在後臺獲取GPS的描述
    */
複製代碼

6:CGPoint一些常見操做網絡

複製代碼
數據結構中的一個點CGPoint表明在一個二維座標系統。數據結構的位置和尺寸CGRect表明的一個長方形。數據結構的尺寸CGSize表明寬度和高度。

一、建立一個幾何原始數值
CGPoint  CGPointMake(CGPoint A,CGPoint B)            
返回一個指定座標點  
CGRect   CGRectMake(CGFloat x,CGFloat y,CGFloat width,CGFloat height)
根據指定的座標和大小建立一個矩形
CGSize   CGSizeMake(CGFloat width,CGFloat height)
根據指定長寬建立一個CGSize   
二、修改矩形
CGRectDivide
CGRect  CGRectInset(CGRect rect,CGFloat dx,CGFloat dy)
返回一個比原矩形大或小的矩形,可是中心點是相同的
CGRect CGRectIntegral(CGRect A)
將矩形A的值轉變成整數,獲得一個最小的矩形,
CGRect CGRectIntersection:(CGRect A,CGRect B)
獲取兩個矩形相交處所的矩形,沒有相交返回NULL,用CGRectIsNull來檢測
CGRectOffset
CGRectStandardize
CGRectUnion
三、比較數值
bool  CGPointEqualToPoint(CGPoint A,CGPoint B)     
返回兩個點是否相等
bool  CGSizeEqualToSize(CGSize A,CGSize B)
CGSizeAB是否相等
bool  CGRectEqualToRect(CGRect A,CGRect B)       
矩形AB的位置大小是否相等
bool  CGRectIntersectsRect(CGRect A,CGRect B)
矩形AB是否相交,可用來判斷精靈是否離開了屏幕
四、檢查
bool  CGRectContainsPoint(CGRect A, CGPoint B)      
檢測矩形A是否包含指定的點B
bool  CGRectContainsRect(CGRect A,CGRect B)  
檢測矩形A是否包含矩形B
五、獲取最大值、中等職和最小值
CGFloat   CGRectGetMinX(CGRect A) 
獲取矩形x座標的最小值
CGFloat   CGRectGetMinY(CGRect A)
獲取矩形y座標的最小值 
CGFloat   CGRectGetMidX(CGRect A) 
獲取矩形x座標的中間值 
CGFloat   CGRectGetMidY(CGRect A) 
獲取矩形y座標的中間值 
CGFloat   CGRectGetMaxX(CGRect A) 
獲取矩形x座標的最大值 
CGFloat   CGRectGetMaxY(CGRect A)
獲取矩形y座標的最大值  
六、獲取高和寬
CGFloat  CGRectGetHeight(CGRect A)               
獲取矩形A的高
CGFloat  CGRectGetWidth(CGRect A)            
獲取矩形A的寬
七、檢測矩形是否存在或是無窮大
bool  CGRectIsEmpty(CGRect A)
矩形A是否長和寬都是0,或者是個NULL
bool  CGRectIsNull(CGRect A)
矩形A是否爲NULL
bool  CGRectIsInfinite(CGRect A)
矩形A是否無窮大,沒有邊界
複製代碼

7:iOS7 中 boundingRectWithSize:options:attributes:context:計算文本尺寸的使用數據結構

複製代碼
以前使用了NSString類的sizeWithFont:constrainedToSize:lineBreakMode:方法,可是該方法已經被iOS7 Deprecated了,而iOS7新出了一個boudingRectWithSize:options:attributes:context方法來代替。

而具體怎麼使用呢,尤爲那個attribute

NSDictionary *attribute = @{NSFontAttributeName: [UIFont systemFontOfSize:13]};
CGSize size = [@「相關NSString」 boundingRectWithSize:CGSizeMake(100, 0) options: NSStringDrawingTruncatesLastVisibleLine | NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading attributes:attribute context:nil].size;

屬性

a:NSStringDrawingTruncatesLastVisibleLine:

若是文本內容超出指定的矩形限制,文本將被截去並在最後一個字符後加上省略號。若是沒有指定NSStringDrawingUsesLineFragmentOrigin選項,則該選項被忽略。

b:NSStringDrawingUsesLineFragmentOrigin:

繪製文本時使用 line fragement origin 而不是 baseline origin。

c:NSStringDrawingUsesFontLeading:

計算行高時使用行距。(譯者注:字體大小+行間距=行距)

d:NSStringDrawingUsesDeviceMetrics:

計算佈局時使用圖元字形(而不是印刷字體)。

實例二:
        NSString *str = @"正在搜索附近的位置";
        UIFont *font = [UIFont systemFontOfSize:14.0];
        CGSize size = CGSizeMake(CGFLOAT_MAX, 50);
        CGRect rect = [str boundingRectWithSize:size options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:[UIFont fontWithName:font.fontName size:font.pointSize]} context:nil];
        
        CGRect buttonFrame = CGRectZero;
        buttonFrame.size.height = CGRectGetHeight(rect);
        buttonFrame.size.width = CGRectGetWidth(rect);

        UILabel *label = [[UILabel alloc]initWithFrame:buttonFrame];
複製代碼

8:一段佈局排版關於tableView.tableFooterView設置按鍵跟等待提示ide

複製代碼
- (UIView *)searchDisplayLoadingFooterView
{
    if (!_searchDisplayLoadingFooterView) {
        _searchDisplayLoadingFooterView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, CGRectGetWidth(self.tableView.bounds), 50)];
        _searchDisplayLoadingFooterView.backgroundColor = [UIColor clearColor];
        NSString *str = @"正在搜索附近的位置";
        UIFont *font = [UIFont systemFontOfSize:14.0];
        CGSize size = CGSizeMake(CGFLOAT_MAX, 50);
        CGRect rect = [str boundingRectWithSize:size options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:[UIFont fontWithName:font.fontName size:font.pointSize]} context:nil];
        
        CGRect buttonFrame = CGRectZero;
        buttonFrame.size.height = CGRectGetHeight(rect);
        buttonFrame.size.width = CGRectGetWidth(rect);
        
        UILabel *label = [[UILabel alloc]initWithFrame:buttonFrame];
        label.backgroundColor = [UIColor clearColor];
        label.text = str;
        label.font = font;
        label.textColor = [UIColor colorWithHexString:@"0x222222"];
        label.numberOfLines = 1;
        label.textAlignment = NSTextAlignmentCenter;
        label.center = _searchDisplayLoadingFooterView.center;
        [_searchDisplayLoadingFooterView addSubview:label];
        
        CGPoint indicatorCenter = CGPointZero;
        indicatorCenter.x = CGRectGetMinX(label.frame) - 20;
        indicatorCenter.y = label.center.y;
        
        UIActivityIndicatorView *indicator = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
        indicator.center = indicatorCenter;
        indicator.hidesWhenStopped = YES;
        [_searchDisplayLoadingFooterView addSubview:indicator];
        [indicator startAnimating];
        
        CGRect lineFrame = _searchDisplayLoadingFooterView.bounds;
        lineFrame.size.height = 0.5;
        
        UIView *topLine = [[UIView alloc]initWithFrame:lineFrame];
        topLine.backgroundColor = [UIColor colorWithHexString:@"0xdddddd"];
        
        lineFrame.origin.y = CGRectGetMaxY(_searchDisplayLoadingFooterView.bounds) - 0.5;
        UIView *bottomLine = [[UIView alloc]initWithFrame:lineFrame];
        bottomLine.backgroundColor = [UIColor colorWithHexString:@"0xdddddd"];
        
        [_searchDisplayLoadingFooterView addSubview:topLine];
        [_searchDisplayLoadingFooterView addSubview:bottomLine];
    }
    
    return _searchDisplayLoadingFooterView;
}
複製代碼

9:百度座標跟火星座標相互轉換函數

複製代碼
//百度轉火星座標
+ (CLLocationCoordinate2D )bdToGGEncrypt:(CLLocationCoordinate2D)coord
{
    double x = coord.longitude - 0.0065, y = coord.latitude - 0.006;
    double z = sqrt(x * x + y * y) - 0.00002 * sin(y * M_PI);
    double theta = atan2(y, x) - 0.000003 * cos(x * M_PI);
    CLLocationCoordinate2D transformLocation ;
    transformLocation.longitude = z * cos(theta);
    transformLocation.latitude = z * sin(theta);
    return transformLocation;
}

//火星座標轉百度座標
+ (CLLocationCoordinate2D )ggToBDEncrypt:(CLLocationCoordinate2D)coord
{
    double x = coord.longitude, y = coord.latitude;
    
    double z = sqrt(x * x + y * y) + 0.00002 * sin(y * M_PI);
    double theta = atan2(y, x) + 0.000003 * cos(x * M_PI);
    
    CLLocationCoordinate2D transformLocation ;
    transformLocation.longitude = z * cos(theta) + 0.0065;
    transformLocation.latitude = z * sin(theta) + 0.006;
    
    return transformLocation;
}
相關文章
相關標籤/搜索