计算一元一次方程Y=kX+b

开发过程中用不到一元一次方程吗?非也,iOS开发中经常会遇到根据某个ScrollView动态偏移量的值来实时设置一个View的透明度,你敢说你不用一元一次方程你能搞定?
想把一个动画效果做好,经常会遇到实时设置的问题,本人遇到过多次,总结出经验,提供方法来专门计算一元一次方程的K值以及b值,方便开发.
BinaryLinearEquation.h + BinaryLinearEquation.m 提供内联函数以及类方法
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import <Foundation/Foundation.h> NS_INLINE CGFloat calculateSlope(CGFloat x1, CGFloat y1, CGFloat x2, CGFloat y2)
{
return (y2 - y1) / (x2 - x1);
} NS_INLINE CGFloat calculateConstant(CGFloat x1, CGFloat y1, CGFloat x2, CGFloat y2)
{
return (y1*(x2 - x1) - x1*(y2 - y1)) / (x2 - x1);
} @interface BinaryLinearEquation : NSObject /**
* 计算一元一次方程的斜率 K
*
* Y = kX + b,输入两个点坐标的值(x1, y1), (x2, y2)来计算斜率k的值
*
* @param 坐标值 两个点的坐标值(x1, y1), (x2, y2)
* @return 计算得出的斜率值
*/
+ (CGFloat)calculateSlopeWithX1:(CGFloat)x1 Y1:(CGFloat)y1 X2:(CGFloat)x2 Y2:(CGFloat)y2; /**
* 计算一元一次方程的常数 b
*
* Y = kX + b,输入两个点坐标的值(x1, y1), (x2, y2)来计算常数b的值
*
* @param 坐标值 两个点的坐标值(x1, y1), (x2, y2)
* @return 计算得出的常数值
*/
+ (CGFloat)calculateConstantWithX1:(CGFloat)x1 Y1:(CGFloat)y1 X2:(CGFloat)x2 Y2:(CGFloat)y2; @end
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "BinaryLinearEquation.h" @implementation BinaryLinearEquation + (CGFloat)calculateSlopeWithX1:(CGFloat)x1 Y1:(CGFloat)y1 X2:(CGFloat)x2 Y2:(CGFloat)y2
{
return (y2 - y1) / (x2 - x1);
} + (CGFloat)calculateConstantWithX1:(CGFloat)x1 Y1:(CGFloat)y1 X2:(CGFloat)x2 Y2:(CGFloat)y2
{
return (y1*(x2 - x1) - x1*(y2 - y1)) / (x2 - x1);
} @end
测试:
y = 7x - 9
k = 7
b = -9
两个点(0, -9),(9/7, 0)
---------------------------------------------------------------------------------------------
NSLog(@"%f", calculateSlope(0.f, -9.f, 9.f/7.f, 0.f));
NSLog(@"%f", calculateConstant(0.f, -9.f, 9.f/7.f, 0.f));
NSLog(@"%f", [BinaryLinearEquation calculateSlopeWithX1:0.f Y1:-9.f
X2:9.f/7.f Y2:0.f]);
NSLog(@"%f", [BinaryLinearEquation calculateConstantWithX1:0.f Y1:-9.f
X2:9.f/7.f Y2:0.f]);
---------------------------------------------------------------------------------------------
2014-03-28 09:46:00.898 woobooWall[1440:60b] 7.000000
2014-03-28 09:46:00.899 woobooWall[1440:60b] -9.000000
2014-03-28 09:46:00.899 woobooWall[1440:60b] 7.000000
2014-03-28 09:46:00.899 woobooWall[1440:60b] -9.000000
使用时请将数据转换为CGFloat型.
附录1:

附录2:
根据一元一次方程组计算所有的红绿蓝透明度的斜率以及常数值
CalculateColor.h + CalculateColor.m
//
// CalculateColor.h
// Animation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import <Foundation/Foundation.h> typedef struct ColorParam { CGFloat redSlope; // 红色的斜率 k
CGFloat redConstant; // 红色的常数 b CGFloat greenSlope; // 绿色的斜率 k
CGFloat greenConstant; // 绿色的常数 b CGFloat blueSlope; // 蓝色的斜率 k
CGFloat blueConstant; // 蓝色的常数 b CGFloat alphaSlope; // 透明度的斜率 k
CGFloat alphaConstant; // 透明度的常数 b } SColorParam; /**
根据一元一次方程组计算所有的红绿蓝透明度的斜率以及常数值 这是用来设计做动态设定动画效果的,需要提供起始点的UIColor,起始点的一个值,终点的UIColor,终点的一个值,然后计算
出动画过程中需要的一些设置参数. @param oldColor 起始点的color
@param oldPoint 起始点的值
@param newColor 终点的color
@param newPoint 终点的值
@param param 计算好的值存储于结构体SColorParam中 @return none
*/
void calculateUIColorAndPoint(UIColor *oldColor,CGFloat oldPoint,
UIColor *newColor, CGFloat newPoint,
SColorParam *param);
//
// CalculateColor.m
// Animation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "CalculateColor.h" #pragma mark - 计算斜率 k
CGFloat calculateSlope(CGFloat x1, CGFloat y1, CGFloat x2, CGFloat y2)
{
return (y2 - y1) / (x2 - x1);
} #pragma mark - 计算常数 b
CGFloat calculateConstant(CGFloat x1, CGFloat y1, CGFloat x2, CGFloat y2)
{
return (y1*(x2 - x1) - x1*(y2 - y1)) / (x2 - x1);
} #pragma mark - 根据一元一次方程组计算所有的红绿蓝透明度的斜率以及常数值
void calculateUIColorAndPoint(UIColor *oldColor,CGFloat oldPoint,
UIColor *newColor, CGFloat newPoint,
SColorParam *param)
{
// 获取旧颜色
CGFloat oldRed = ;
CGFloat oldGreen = ;
CGFloat oldBlue = ;
CGFloat oldAlpha = ;
[oldColor getRed:&oldRed green:&oldGreen blue:&oldBlue alpha:&oldAlpha]; // 获取新颜色
CGFloat newRed = ;
CGFloat newGreen = ;
CGFloat newBlue = ;
CGFloat newAlpha = ;
[newColor getRed:&newRed green:&newGreen blue:&newBlue alpha:&newAlpha]; // 计算每一个k值和b值
param->redSlope = calculateSlope(oldPoint, oldRed, newPoint, newRed);
param->redConstant = calculateConstant(oldPoint, oldRed, newPoint, newRed);
param->greenSlope = calculateSlope(oldPoint, oldGreen, newPoint, newGreen);
param->greenConstant = calculateConstant(oldPoint, oldGreen, newPoint, newGreen);
param->blueSlope = calculateSlope(oldPoint, oldBlue, newPoint, newBlue);
param->blueConstant = calculateConstant(oldPoint, oldBlue, newPoint, newBlue);
param->alphaSlope = calculateSlope(oldPoint, oldAlpha, newPoint, newAlpha);
param->alphaConstant = calculateConstant(oldPoint, oldAlpha, newPoint, newAlpha);
}
以下是实现动态改变颜色的方法
#import "YX_2_ViewController.h"
#import "CalculateColor.h" @interface YX_2_ViewController ()<UIScrollViewDelegate> @property (strong, nonatomic) UIScrollView *mainScrollView; @end @implementation YX_2_ViewController - (void)viewDidLoad
{
[super viewDidLoad]; _mainScrollView = [[UIScrollView alloc] initWithFrame:self.view.bounds];
_mainScrollView.contentSize = CGSizeMake(self.view.bounds.size.width * ,
self.view.bounds.size.height);
_mainScrollView.backgroundColor = [UIColor cyanColor];
_mainScrollView.delegate = self;
[self.view addSubview:_mainScrollView];
} - (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
static SColorParam paramVe2 = {}; // 只计算一次
static int flag = ;
if (flag == ) {
calculateUIColorAndPoint([UIColor cyanColor],
,
[UIColor redColor],
, ¶mVe2); flag = ;
} UIColor *color =
[UIColor colorWithRed:scrollView.contentOffset.x * paramVe2.redSlope + paramVe2.redConstant
green:scrollView.contentOffset.x * paramVe2.greenSlope + paramVe2.greenConstant
blue:scrollView.contentOffset.x * paramVe2.blueSlope + paramVe2.blueConstant
alpha:]; scrollView.backgroundColor = color;
} @end
计算一元一次方程Y=kX+b的更多相关文章
- C# 列主元素(Gauss)消去法 计算一元多次方程组
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- C# 顺序高斯(Gauss)消去法计算一元多次方程组
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- C语言简单计算一元二次方程
#include <stdio.h> #include <math.h> /*计算一元二次方程的根*/ void Cal(double a,double b,double c) ...
- C++第9周(春)项目5 - 一元一次方程类
课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目5]设计一元一次方程类.求形如ax+b= ...
- 通过C/C++,实现一元一次方程求解
通过C/C++,实现一元一次方程求解: #include <bits/stdc++.h> using namespace std; string str, str_l, str_r; st ...
- C++:补齐函数编写递归函数计算x的y次幂(hhhh函数 !头疼!)
编写递归函数计算x的y次幂,在主程序中输入非零整数x和整数y,输出求幂的结果(保留两位小数).考虑y为负数和0的情况. #include<iostream> #include<iom ...
- ACM_Plants vs. Zombies(一元一次方程)
Plants vs. Zombies Time Limit: 2000/1000ms (Java/Others) Problem Description: There is a zombie on y ...
- C语言初学 计算二元一次方程的问题
#include<stdio.h> #include<math.h> int main() { double a,b,c,disc,x1,x2; scanf("%lf ...
- python解一元一次方程
将未知数看成是虚数 将常数看成是实数 最终求解. import re class Item: def __init__(self,imag=0,real=0): self.imag = imag se ...
随机推荐
- ref:关于JAVA中一些安全漏洞示例说明及如何规避方法代码示例总结分享
ref:http://www.xwood.net/_site_domain_/_root/5870/5874/t_c268166.html 标签:安全,漏洞,健壮,java,SQL注入,SS及CSRF ...
- IAR搭建unity框架
1. 新建工程 2. 增加组 unit,并加入相应源码 3. 增加需要测试的API源文件 4. 编写相应的测试用例 编译,download and debug view->TerminalIO ...
- SpringBoot和微服务
SpringCloud SpringBoot 概念 应用 微服务CAP Consistency(数据强一致性),Availability(服务可用性),Partition-tolerance(分区容错 ...
- CSUOJ 1808 地铁
Description Bobo 居住在大城市 ICPCCamp. ICPCCamp 有 n 个地铁站,用 1,2,-,n 编号. m 段双向的地铁线路连接 n 个地铁站,其中第 i 段地铁属于 ci ...
- 使用easypoi导出excel
EasyPOI是在jeecg的poi模块基础上,继续开发独立出来的,可以说是2.0版本,EasyPoi封装的目的和jeecg一致,争取让大家write less do more ,在这个思路上easy ...
- Linux信号量同步共享内存实验.
Linux信号量同步共享内存实验. Linux信号量同步共享内存实验. 简述 程序流程 信号量和共享内存的系统函数 信号量系统函数及接口 共享内存系统函数及接口 写程序 读程序 简述 本文主要内容是自 ...
- luoguP3359 改造异或树 线段树合并
删边转化为加边 然后每次用线段树合并就行..... 确确实实很简单 然而为什么线段树合并跑不过$splay$的启发式合并,常数稍大了点... 复杂度$O(n \log n)$ #include < ...
- Lua脚本
应用场景: 游戏开发 独立应用脚本 Web 应用脚本 扩展和数据库插件如:MySQL Proxy 和 MySQL WorkBench 安全系统,如入侵检测系统 1. 在很多时候,我们可以将Lua直接嵌 ...
- Python168的学习笔记7
关于多线程操作. 对于IO操作,如访问网站,写入磁盘这种需要时间等待响应的操作,多个cpu也几乎不能提高效率. 对于CPU密集型操作,如这个格式转换,可以通过多个cpu同时去进行. 但是对于pytho ...
- python 加密方式(MD5&sha&hashlib)
1.MD5加密 import md5 m = md5.new() #或者m = md5.md5() m.update('123456') m.hexdigest() #或者md5.md5('12345 ...