开发过程中用不到一元一次方程吗?非也,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],
, &paramVe2); 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的更多相关文章

  1. C# 列主元素(Gauss)消去法 计算一元多次方程组

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  2. C# 顺序高斯(Gauss)消去法计算一元多次方程组

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  3. C语言简单计算一元二次方程

    #include <stdio.h> #include <math.h> /*计算一元二次方程的根*/ void Cal(double a,double b,double c) ...

  4. C++第9周(春)项目5 - 一元一次方程类

    课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目5]设计一元一次方程类.求形如ax+b= ...

  5. 通过C/C++,实现一元一次方程求解

    通过C/C++,实现一元一次方程求解: #include <bits/stdc++.h> using namespace std; string str, str_l, str_r; st ...

  6. C++:补齐函数编写递归函数计算x的y次幂(hhhh函数 !头疼!)

    编写递归函数计算x的y次幂,在主程序中输入非零整数x和整数y,输出求幂的结果(保留两位小数).考虑y为负数和0的情况. #include<iostream> #include<iom ...

  7. ACM_Plants vs. Zombies(一元一次方程)

    Plants vs. Zombies Time Limit: 2000/1000ms (Java/Others) Problem Description: There is a zombie on y ...

  8. C语言初学 计算二元一次方程的问题

    #include<stdio.h> #include<math.h> int main() { double a,b,c,disc,x1,x2; scanf("%lf ...

  9. python解一元一次方程

    将未知数看成是虚数 将常数看成是实数 最终求解. import re class Item: def __init__(self,imag=0,real=0): self.imag = imag se ...

随机推荐

  1. android拾遗——AlarmManager的使用

    AlarmManager的作用文档中的解释是:在特定的时刻为我们广播一个指定的Intent.简单的说就是我们设定一个时间,然后在该时间到来时,AlarmManager为我们广播一个我们设定的Inten ...

  2. HBase(四)HBase集群Shell操作

    一.进入HBase命令行 在你安装的随意台服务器节点上,执行命令:hbase shell,会进入到你的 hbase shell 客 户端 [admin@node21 ~]$ hbase shell S ...

  3. loadrunner日志信息

    日志分两种1.在VUGEN中运行后的日志2.在controller中运行后的日志 日志设置分两步:1.首先,在VUGEN或controller中run-time setting, 选中always s ...

  4. JavaScript对象参考手册

    1.array 属性: constructor 返回原型函数: length 数组个数: prototype 向对象添加属性和方法 方法: concat() 连接两个或多个数组,并返回结果: fill ...

  5. 回文树练习 Part1

    URAL - 1960   Palindromes and Super Abilities 回文树水题,每次插入时统计数量即可. #include<bits/stdc++.h> using ...

  6. python获取文件属性

    提供三段代码 1.os模块 import os def TestFileAttributes(): # This function is platform indepedent. statinfo = ...

  7. 复杂密码生成工具apg

    复杂密码生成工具apg   密码是身份认证的重要方式.由于密码爆破方式的存在,弱密码非常不安全.为了构建复杂密码,Kali Linux预置了一个复杂密码生成工具apg.该工具可以提供可读密码和随机字符 ...

  8. Swift2.0语言教程之Swift2.0语言中的标准函数

    Swift2.0语言教程之Swift2.0语言中的标准函数 Swift2.0中的标准函数 函数除了可以根据参数列表的有无分为无参函数和有参函数,还可以从定义角度分为用户自定义函数和标准函数两种.以上的 ...

  9. luoguP2231 [HNOI2002]跳蚤

    题目链接 bzoj1220: [HNOI2002]跳蚤 题解 根据裴蜀定理,不定方程的解为未知数的gcd,所以选取的n个数的gcd为1 那么n - 1个数保证没有公约数为m的约数,枚举质因数容斥 质因 ...

  10. BZOJ 3091: 城市旅行 lct 期望 splay

    https://www.lydsy.com/JudgeOnline/problem.php?id=3091 https://blog.csdn.net/popoqqq/article/details/ ...