當前位置: 首頁>>代碼示例>>C++>>正文


C++ GetMatrix函數代碼示例

本文整理匯總了C++中GetMatrix函數的典型用法代碼示例。如果您正苦於以下問題:C++ GetMatrix函數的具體用法?C++ GetMatrix怎麽用?C++ GetMatrix使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了GetMatrix函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。

示例1: string

inline void TAligner_SW<CQuery,CSubject>::x_PrintMatrix()
{
    cerr << "\x1b[31mNULL\t\x1b[32mIdentity\t\x1b[33mMismatch\t\x1b[34mInsertion\t\x1b[35mDeletion\t\x1b[36mOTHER\x1b[0m\n";
    cerr << string(78,'=') << endl;
    for( int q = -1; q < (int)((*m_matrix)[0].size() - 1); ++q ) {
        for( int s = -1; s < (int)((*m_matrix)[0].size() - 1); ++s ) {
            if( s >= 0 ) cerr << "\t";
            switch( GetMatrix( q, s, false ).second ) {
            case eNull:
                cerr << "\x1b[31m";
                break;
            case eIdentity:
                cerr << "\x1b[32m";
                break;
            case eMismatch:
                cerr << "\x1b[33m";
                break;
            case eInsertion:
                cerr << "\x1b[34m";
                break;
            case eDeletion:
                cerr << "\x1b[35m";
                break;
            default:
                cerr << "\x1b[36m";
                break;
            }
            cerr << GetMatrix( q, s, false ).first << "\x1b[0m";
        }
        cerr << "\n";
    }
}
開發者ID:jackgopack4,項目名稱:pico-blast,代碼行數:32,代碼來源:taligner_sw.hpp

示例2: vector3f_t

const CameraDesc& Camera::GetDesc() const
{
    m_desc.EyePosition = vector3f_t(GetMatrix(CoordType::Global) * vector4f_t(m_originalDesc.EyePosition, 1));
    m_desc.Direction = vector3f_t(GetMatrix(CoordType::Global) * GetMatrix(CoordType::Local) * vector4f_t(m_originalDesc.Direction, 0));
    m_desc.Up = vector3f_t(GetMatrix(CoordType::Global) * GetMatrix(CoordType::Local) * vector4f_t(m_originalDesc.Up, 0));
    return m_desc;
}
開發者ID:QueryInterface,項目名稱:RenderBase,代碼行數:7,代碼來源:CameraImpl.cpp

示例3: ForceSetWorldMatrix

void MatrixMoveable::OnUpdateWorldMatrix(Matrix4& transform, int32 dirtyFlag)
{
	if (mParentMoveable != nullptr&&mParentMoveable->IsWorldMatrixDirty())
	{
		ForceSetWorldMatrix(GetMatrix()*(mParentMoveable->WorldMatrix()));
	}
	else
	{
		ForceSetWorldMatrix(GetMatrix());
	}
}
開發者ID:johndpope,項目名稱:Medusa,代碼行數:11,代碼來源:MatrixMoveable.cpp

示例4: ForceSetWorldMatrix

void TransformMoveable::OnUpdateWorldMatrix( Matrix4& transform )
{
	TransformMoveable* parent=GetParentMoveable();
	if (parent!=NULL&&parent->IsWorldMatrixDirty())
	{
		ForceSetWorldMatrix(GetMatrix()*(parent->GetWorldMatrix()));
	}
	else
	{
		ForceSetWorldMatrix(GetMatrix());
	}
}
開發者ID:alkaidlong,項目名稱:PaperDemo,代碼行數:12,代碼來源:TransformMoveable.cpp

示例5: wxSVGRect

wxSVGRect wxSVGVideoElement::GetBBox(wxSVG_COORDINATES coordinates) {
	wxSVGRect bbox = wxSVGRect(GetX().GetAnimVal(), GetY().GetAnimVal(), GetWidth().GetAnimVal(),
			GetHeight().GetAnimVal());
	if (coordinates != wxSVG_COORDINATES_USER)
		bbox.MatrixTransform(GetMatrix(coordinates));
	return bbox;
}
開發者ID:KastB,項目名稱:OpenCPN,代碼行數:7,代碼來源:SVGVideoElement.cpp

示例6: MgTest

  void MGPreconditioner :: MgTest () const
  {
    cout << "Compute eigenvalues" << endl;
    const BaseMatrix & amat = GetAMatrix();
    const BaseMatrix & pre = GetMatrix();
    
    int eigenretval;
    
    EigenSystem eigen (amat, pre);
    eigen.SetPrecision(1e-30);
    eigen.SetMaxSteps(1000); 
    eigenretval = eigen.Calc();
    eigen.PrintEigenValues (*testout);
    (cout) << " Min Eigenvalue : "  << eigen.EigenValue(mgnumber) << endl; 
    (cout) << " Max Eigenvalue : " << eigen.MaxEigenValue() << endl; 
    (cout) << " Condition   " << eigen.MaxEigenValue()/eigen.EigenValue(mgnumber) << endl; 
    (*testout) << " Min Eigenvalue : "  << eigen.EigenValue(mgnumber) << endl; 
    (*testout) << " Max Eigenvalue : " << eigen.MaxEigenValue() << endl;
    (*testout) << " Condition   " << eigen.MaxEigenValue()/eigen.EigenValue(mgnumber) << endl;
    static ofstream condout (mgfile.c_str());

    // double cond;

    condout << bfa->GetFESpace()->GetNDof() << "\t" << bfa->GetFESpace()->GetOrder() << "\t" << eigen.EigenValue(mgnumber) << "\t" << eigen.MaxEigenValue() << "\t" 
	    << eigen.MaxEigenValue()/eigen.EigenValue(mgnumber) <<  "\t" << endl;
    
    if(testresult_ok) *testresult_ok = eigenretval;
    if(testresult_min) *testresult_min = eigen.EigenValue(mgnumber);
    if(testresult_max) *testresult_max = eigen.MaxEigenValue();

  }
開發者ID:ddrake,項目名稱:ngsolve,代碼行數:31,代碼來源:preconditioner.cpp

示例7: D3DXVECTOR2

/**
 @brief 바운딩박스를 계산해 돌려준다.
*/
XE::xRECT XLayerImage::GetBoundBox( const D3DXMATRIX& mParent ) const 
{
	// 이미지의 4귀퉁이를 이 매트릭스로 트랜스폼
	XSprite *pSpr = m_pSpriteCurr;
	if( pSpr ) {
		const D3DXVECTOR2 vAdj = pSpr->GetAdjust();
		const auto vSize = pSpr->GetSize();
		D3DXVECTOR2 vLT = vAdj;
		D3DXVECTOR2 vRT = D3DXVECTOR2( vAdj.x + vSize.w, vAdj.y );
		D3DXVECTOR2 vLB = D3DXVECTOR2( vAdj.x					, vAdj.y + vSize.h );
		D3DXVECTOR2 vRB = D3DXVECTOR2( vAdj.x + vSize.w, vAdj.y + vSize.h );
		XE::VEC2 vtLT, vtRT, vtLB, vtRB;
		D3DXVECTOR4 vResult;
		const auto mWorld = GetMatrix() * mParent;
		D3DXVec2Transform( &vResult, &vLT, &mWorld );	vtLT.Set( vResult.x, vResult.y );
		D3DXVec2Transform( &vResult, &vRT, &mWorld );	vtRT.Set( vResult.x, vResult.y );
		D3DXVec2Transform( &vResult, &vLB, &mWorld );	vtLB.Set( vResult.x, vResult.y );
		D3DXVec2Transform( &vResult, &vRB, &mWorld );	vtRB.Set( vResult.x, vResult.y );
		XE::xRECT rectBB;
		rectBB.UpdateBoundBox( vtLT );
		rectBB.UpdateBoundBox( vtRT );
		rectBB.UpdateBoundBox( vtLB );
		rectBB.UpdateBoundBox( vtRB );
		return rectBB;
	}
	return XE::xRECT();
}
開發者ID:xahgo,項目名稱:tama,代碼行數:30,代碼來源:XLayerImage.cpp

示例8: CheckValid

void nuiSprite::GetSpritesAtPoint(float x, float y, std::vector<nuiSprite*>& rSprites)
{
  CheckValid();
  nuiVector ov(x, y, 0);
  nuiMatrix m;
  GetMatrix(m);
  m.Invert();
  nuiVector v = m * ov;
  x = v[0];
  y = v[1];
  
  const nuiSpriteAnimation* pAnim = mpSpriteDef->GetAnimation(mCurrentAnimation);
  const nuiSpriteFrame* pFrame = pAnim->GetFrame(ToBelow(mCurrentFrame));
  nuiRect dst(pFrame->GetRect());
  dst.Move(-pFrame->GetHandleX(), -pFrame->GetHandleY());
  
  if (dst.IsInside(x, y))
    rSprites.push_back(this);

  uint32 s = mpChildren.size();
  for (size_t i = 0; i < s; i++)
  {
    mpChildren[i]->GetSpritesAtPoint(x, y, rSprites);
  }
}
開發者ID:jbl2024,項目名稱:nui3,代碼行數:25,代碼來源:nuiSpriteView.cpp

示例9: Inversion

void Inversion(FunctionCall fc)
{
	int i, j, index, exist = 0;
	Matrix a, c;
	char name[MAXSIZE_NAME] = {0};

	index = IndexMatrix(fc->name);
	if (index==-1)
	{
		index = cur_mat;
		mats[index] = (StrMatObject*)malloc(sizeof(StrMatObject));
		
		if (mats[index] == NULL)
		{
			printf("NewMatrix(): Could not allocate the new matrix\n");
			return;
		}

		for (i = 0; i < MAXSIZE_NAME; i++)
		{
			mats[index]->name[i] = fc->name[i];
			if (fc->name[i]=='\0') break;
		}
	}
	else exist = 1;
	
	j = 0;
	// searching for matrix name
	for (i = 0; i < MAXSIZE_NAME; i++)
	{
		name[j] = fc->args[i];
		if (name[j] == '\0') break;
		j++;
	}
	
	a = GetMatrix(name);
	if (a==NULL)
	{
		printf("\tMatrix %s Not Found\n", name);
		if (!exist) free(mats[index]);
		return;
	}
	
	c = invert(a);
	
	if (c==NULL)
	{
		printf("\tMatrix %s Not Invertible\n", name);
		if (!exist) free(mats[index]);
		return;
	}
	
	if (exist) deleteMatrix(mats[index]->mat);
	mats[index]->mat = c;
	
	// test: display the result
	displayMatrix(mats[index]->mat);
	
	if (!exist) cur_mat++;
}
開發者ID:Pawamoy-Sandbox,項目名稱:minicas,代碼行數:60,代碼來源:minicas.c

示例10: SVGMatrix

already_AddRefed<SVGMatrix>
SVGMatrix::Translate(float x, float y)
{
  nsRefPtr<SVGMatrix> matrix =
    new SVGMatrix(gfxMatrix(GetMatrix()).Translate(gfxPoint(x, y)));
  return matrix.forget();
}
開發者ID:CodeSpeaker,項目名稱:gecko-dev,代碼行數:7,代碼來源:SVGMatrix.cpp

示例11: D3DXVec3Length

void CBurnBot::CollisionResponse(IBaseObject* pObj)
{
	int nType = pObj->GetID();

	Sphere tempSphere = pObj->GetSphere();
	D3DXVECTOR3 V = tempSphere.m_Center - this->GetSphere().m_Center;
	float Mag = D3DXVec3Length(&V);
	float Distance = tempSphere.m_Radius + GetSphere().m_Radius;
	float X = Distance/Mag + EPISILON;
	V = V * X;
	D3DXMATRIX tempMat = pObj->GetMatrix();
	if(nType == OBJ_TUNNEL)
		tempMat._43 *= 0.85f;
	D3DXMATRIX tempSetMat = GetMatrix();
	tempSetMat._41 = tempMat._41 - V.x;
	tempSetMat._43 = tempMat._43 - V.z;
	this->SetMatrix(tempSetMat);


	if( nType == OBJ_PLAYER )
	{
		if(!m_bCloseToTarget)
		{
			m_bCloseToTarget = true;
			m_fExplodeTimer = BURN_CHARGETIME;
			SetBeingHit(BURNEXPLODE);
			WwiseNS::PlaySFX(WwiseNS::EVENT_SOUND_BURNALERT);
			ChangeAnimation(0);
		}
	}
}
開發者ID:ianalcid08,項目名稱:FinalProject,代碼行數:31,代碼來源:BurnBot.cpp

示例12: GLCheck

////////////////////////////////////////////////////////////
/// Draw the object into the specified window
////////////////////////////////////////////////////////////
void Drawable::Draw(RenderTarget& Target) const
{
    // Save the current modelview matrix and set the new one
    GLCheck(glMatrixMode(GL_MODELVIEW));
    GLCheck(glPushMatrix());
    GLCheck(glMultMatrixf(GetMatrix().Get4x4Elements()));

    // Setup alpha-blending
    if (myBlendMode == Blend::None)
    {
        GLCheck(glDisable(GL_BLEND));
    }
    else
    {
        GLCheck(glEnable(GL_BLEND));

        switch (myBlendMode)
        {
            case Blend::Alpha :    GLCheck(glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA)); break;
            case Blend::Add :      GLCheck(glBlendFunc(GL_SRC_ALPHA, GL_ONE));                 break;
            case Blend::Multiply : GLCheck(glBlendFunc(GL_DST_COLOR, GL_ZERO));                break;
            default :                                                                          break;
        }
    }

    // Set color
    GLCheck(glColor4f(myColor.r / 255.f, myColor.g / 255.f, myColor.b / 255.f, myColor.a / 255.f));

    // Let the derived class render the object geometry
    Render(Target);

    // Restore the previous modelview matrix
    GLCheck(glMatrixMode(GL_MODELVIEW));
    GLCheck(glPopMatrix());
}
開發者ID:Aiscky,項目名稱:Zappy,代碼行數:38,代碼來源:Drawable.cpp

示例13: GetPos

void CObject::Explode()
{
    CVector pos = GetPos();
    pos.z += 0.5;
    CExplosion::AddExplosion(this, GetPlayerPed(-1), 9, pos, 100, 1, -1.0, 0);
    if (m_colDamageEffect == 202 || m_colDamageEffect == 200)
    {
        pos.z -= 1.0;
        ObjectDamage(10000.0f, pos, 0, GetPlayerPed(-1), 51);
    }
    else if (!m_disableFriction)
    {
        m_linearVelocity.z += 0.5;
        m_linearVelocity.x += (rand() - 128) * 0.000199999994947575;
        m_linearVelocity.y += (rand() - 128) * 0.000199999994947575;
        if (bIsStatic || bIsStaticWaitingForCollision)
        {
            SetIsStatic(false);
            AddToMovingList();
        }
    }
    if (m_objectInfo->fxType == 2)
    {
        CMatrix pos = GetMatrix();
        // to object space
        CVector fxObjPos = Multiply3x3(pos, m_objectInfo->fxOffset);
        fxObjPos += GetPos(); // to world space
        FxSystem_c *sys = FxManager.InitialiseFxSystem(m_objectInfo->fxSystem, fxObjPos, 0, 0);
        if (sys)
        {
            sys->Start();
        }
    }
}
開發者ID:WLSF,項目名稱:GTASA,代碼行數:34,代碼來源:CObject.cpp

示例14: SVGMatrix

already_AddRefed<SVGMatrix>
SVGMatrix::Rotate(float angle)
{
  nsRefPtr<SVGMatrix> matrix =
    new SVGMatrix(gfxMatrix(GetMatrix()).Rotate(angle*radPerDegree));
  return matrix.forget();
}
開發者ID:Kunden,項目名稱:gecko-dev,代碼行數:7,代碼來源:SVGMatrix.cpp

示例15: GetMatrix

 // TODO: This could actually be strided?
 const char* NDMask::DataBuffer() const
 {
     // First make sure that the underlying matrix is on the right device
     auto matrix = GetMatrix();
     matrix->TransferToDeviceIfNotThere(AsCNTKImplDeviceId(m_device), true);
     return matrix->Data();
 }
開發者ID:DanielMerget,項目名稱:CNTK,代碼行數:8,代碼來源:NDMask.cpp


注:本文中的GetMatrix函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。