]>
git.saurik.com Git - wxWidgets.git/blob - src/html/m_image.cpp
bec8f9064dd690dd4ff71d3f1e030952fa1ae0dd
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxHtml module for displaying images 
   4 // Author:      Vaclav Slavik 
   6 // Copyright:   (c) 1999 Vaclav Slavik, Joel Lucsy 
   7 // Licence:     wxWindows Licence 
   8 ///////////////////////////////////////////////////////////////////////////// 
  11 #pragma implementation 
  14 #include "wx/wxprec.h" 
  27 #include "wx/html/forcelnk.h" 
  28 #include "wx/html/m_templ.h" 
  32 #include "wx/dynarray.h" 
  37 FORCE_LINK_ME(mod_image
) 
  42 WX_DECLARE_OBJARRAY(int, CoordArray
); 
  43 #include "wx/arrimpl.cpp" // this is a magic incantation which must be done! 
  44 WX_DEFINE_OBJARRAY(CoordArray
); 
  47 //-------------------------------------------------------------------------------- 
  48 // wxHtmlImageMapAreaCell 
  49 //                  0-width, 0-height cell that represents single area in imagemap 
  50 //                  (it's GetLink is called from wxHtmlImageCell's) 
  51 //-------------------------------------------------------------------------------- 
  53 class wxHtmlImageMapAreaCell 
: public wxHtmlCell
 
  56         enum celltype 
{ CIRCLE
, RECT
, POLY 
}; 
  62         wxHtmlImageMapAreaCell( celltype t
, wxString 
&coords 
); 
  63         virtual wxString 
GetLink( int x 
= 0, int y 
= 0 ) const; 
  70 wxHtmlImageMapAreaCell::wxHtmlImageMapAreaCell( wxHtmlImageMapAreaCell::celltype t
, wxString 
&incoords 
) 
  73     wxString x 
= incoords
, y
; 
  76     while ((i 
= x
.Find( ',' )) != -1) { 
  77         coords
.Add( wxAtoi( x
.Left( i 
).c_str() ) ); 
  80     coords
.Add( wxAtoi( x
.c_str() ) ); 
  83 wxString 
wxHtmlImageMapAreaCell::GetLink( int x
, int y 
) const 
  94                 if (x 
>= l 
&& x 
<= r 
&& y 
>= t 
&& y 
<= b
) { 
 107                 d 
= sqrt( (double) (((x 
- l
) * (x 
- l
)) + ((y 
- t
) * (y 
- t
))) ); 
 115                 if (coords
.GetCount() >= 6) { 
 119                     int totalv 
= coords
.GetCount() / 2; 
 120                     int totalc 
= totalv 
* 2; 
 121                     int xval 
= coords
[totalc 
- 2]; 
 122                     int yval 
= coords
[totalc 
- 1]; 
 126                     if ((yval 
>= wherey
) != (coords
[pointer
] >= wherey
)) { 
 127                         if ((xval 
>= wherex
) == (coords
[0] >= wherex
)) { 
 128                             intersects 
+= (xval 
>= wherex
) ? 1 : 0; 
 130                             intersects 
+= ((xval 
- (yval 
- wherey
) * 
 132                                             (coords
[pointer
] - yval
)) >= wherex
) ? 1 : 0; 
 136                     while (pointer 
< end
) { 
 137                         yval 
= coords
[pointer
]; 
 139                         if (yval 
>= wherey
) { 
 140                             while ((pointer 
< end
) && (coords
[pointer
] >= wherey
)) { 
 143                             if (pointer 
>= end
) { 
 146                             if ((coords
[pointer 
- 3] >= wherex
) == 
 147                                     (coords
[pointer 
- 1] >= wherex
)) { 
 148                                 intersects 
+= (coords
[pointer 
- 3] >= wherex
) ? 1 : 0; 
 151                                     ((coords
[pointer 
- 3] - (coords
[pointer 
- 2] - wherey
) * 
 152                                       (coords
[pointer 
- 1] - coords
[pointer 
- 3]) / 
 153                                       (coords
[pointer
] - coords
[pointer 
- 2])) >= wherex
) ? 1 : 0; 
 156                             while ((pointer 
< end
) && (coords
[pointer
] < wherey
)) { 
 159                             if (pointer 
>= end
) { 
 162                             if ((coords
[pointer 
- 3] >= wherex
) == 
 163                                     (coords
[pointer 
- 1] >= wherex
)) { 
 164                                 intersects 
+= (coords
[pointer 
- 3] >= wherex
) ? 1 : 0; 
 167                                     ((coords
[pointer 
- 3] - (coords
[pointer 
- 2] - wherey
) * 
 168                                       (coords
[pointer 
- 1] - coords
[pointer 
- 3]) / 
 169                                       (coords
[pointer
] - coords
[pointer 
- 2])) >= wherex
) ? 1 : 0; 
 173                     if ((intersects 
& 1) != 0) { 
 181         wxHtmlImageMapAreaCell  
*a 
= (wxHtmlImageMapAreaCell
*)m_Next
; 
 182         return a
->GetLink( x
, y 
); 
 184     return wxEmptyString
; 
 194 //-------------------------------------------------------------------------------- 
 195 // wxHtmlImageMapCell 
 196 //                  0-width, 0-height cell that represents map from imagemaps 
 197 //                  it is always placed before wxHtmlImageMapAreaCells 
 198 //                  It responds to Find(wxHTML_COND_ISIMAGEMAP) 
 199 //-------------------------------------------------------------------------------- 
 202 class wxHtmlImageMapCell 
: public wxHtmlCell
 
 205         wxHtmlImageMapCell( wxString 
&name 
); 
 209         virtual wxString 
GetLink( int x 
= 0, int y 
= 0 ) const; 
 210         virtual const wxHtmlCell 
*Find( int cond
, const void *param 
) const; 
 214 wxHtmlImageMapCell::wxHtmlImageMapCell( wxString 
&name 
) 
 219 wxString 
wxHtmlImageMapCell::GetLink( int x
, int y 
) const 
 221     wxHtmlImageMapAreaCell      
*a 
= (wxHtmlImageMapAreaCell
*)m_Next
; 
 223         return a
->GetLink( x
, y 
); 
 224     return wxHtmlCell::GetLink( x
, y 
); 
 227 const wxHtmlCell 
*wxHtmlImageMapCell::Find( int cond
, const void *param 
) const 
 229     if (cond 
== wxHTML_COND_ISIMAGEMAP
) { 
 230         if (m_Name 
== *((wxString
*)(param
))) 
 233     return wxHtmlCell::Find(cond
, param
); 
 240 //-------------------------------------------------------------------------------- 
 243 //-------------------------------------------------------------------------------- 
 245 class wxHtmlImageCell 
: public wxHtmlCell
 
 249         wxHtmlImageMapCell 
*m_ImageMap
; 
 252         wxHtmlImageCell(wxFSFile 
*input
, int w 
= -1, int h 
= -1, int align 
= wxHTML_ALIGN_BOTTOM
, wxString mapname 
= wxEmptyString
); 
 253         ~wxHtmlImageCell() {if (m_Image
) delete m_Image
; } 
 254         void Draw(wxDC
& dc
, int x
, int y
, int view_y1
, int view_y2
); 
 255         virtual wxString 
GetLink( int x 
= 0, int y 
= 0 ) const; 
 261 //-------------------------------------------------------------------------------- 
 263 //-------------------------------------------------------------------------------- 
 265 wxHtmlImageCell::wxHtmlImageCell(wxFSFile 
*input
, int w
, int h
, int align
, wxString mapname
) : wxHtmlCell() 
 269     wxInputStream 
*s 
= input 
-> GetStream(); 
 271     img 
= new wxImage(*s
, wxBITMAP_TYPE_ANY
); 
 274     if (img 
&& (img 
-> Ok())) { 
 275         ww 
= img 
-> GetWidth(); 
 276         hh 
= img 
-> GetHeight(); 
 277         if (w 
!= -1) m_Width 
= w
; else m_Width 
= ww
; 
 278         if (h 
!= -1) m_Height 
= h
; else m_Height 
= hh
; 
 279         if ((m_Width 
!= ww
) || (m_Height 
!= hh
)) { 
 280             wxImage img2 
= img 
-> Scale(m_Width
, m_Height
); 
 281             m_Image 
= new wxBitmap(img2
.ConvertToBitmap()); 
 283             m_Image 
= new wxBitmap(img 
-> ConvertToBitmap()); 
 287         case wxHTML_ALIGN_TOP 
: 
 288             m_Descent 
= m_Height
; 
 290         case wxHTML_ALIGN_CENTER 
: 
 291             m_Descent 
= m_Height 
/ 2; 
 293         case wxHTML_ALIGN_BOTTOM 
: 
 301     SetCanLiveOnPagebreak(FALSE
); 
 306 void wxHtmlImageCell::Draw(wxDC
& dc
, int x
, int y
, int view_y1
, int view_y2
) 
 309         dc
.DrawBitmap(*m_Image
, x 
+ m_PosX
, y 
+ m_PosY
, TRUE
); 
 310     wxHtmlCell::Draw(dc
, x
, y
, view_y1
, view_y2
); 
 313 wxString 
wxHtmlImageCell::GetLink( int x
, int y 
) const 
 315     if (m_MapName
.IsEmpty()) 
 316         return wxHtmlCell::GetLink( x
, y 
); 
 318         wxHtmlContainerCell     
*p
, *op
; 
 319         op 
= p 
= GetParent(); 
 325         wxHtmlCell 
*cell 
= (wxHtmlCell
*)p
->Find( wxHTML_COND_ISIMAGEMAP
, (const void*)(&m_MapName
)); 
 327             ((wxString
&)m_MapName
).Clear(); 
 328             return wxHtmlCell::GetLink( x
, y 
); 
 330         { // dirty hack, ask Joel why he fills m_ImageMap in this place 
 331             // THE problem is that we're in const method and we can't modify m_ImageMap 
 332             wxHtmlImageMapCell 
**cx 
= (wxHtmlImageMapCell
**)(&m_ImageMap
); 
 333             *cx 
= (wxHtmlImageMapCell
*)cell
; 
 336     return m_ImageMap
->GetLink( x
, y 
); 
 341 //-------------------------------------------------------------------------------- 
 343 //-------------------------------------------------------------------------------- 
 345 TAG_HANDLER_BEGIN(IMG
, "IMG,MAP,AREA") 
 347     TAG_HANDLER_PROC(tag
) 
 349         if (tag
.GetName() == "IMG") { 
 350             if (tag
.HasParam("SRC")) { 
 354                 wxString tmp 
= tag
.GetParam("SRC"); 
 355                 wxString mn 
= wxEmptyString
; 
 357                 str 
= m_WParser 
-> GetFS() -> OpenFile(tmp
); 
 358                 if (tag
.HasParam(wxT("WIDTH"))) tag
.ScanParam(wxT("WIDTH"), wxT("%i"), &w
); 
 359                 if (tag
.HasParam(wxT("HEIGHT"))) tag
.ScanParam(wxT("HEIGHT"), wxT("%i"), &h
); 
 360                 al 
= wxHTML_ALIGN_BOTTOM
; 
 361                 if (tag
.HasParam("ALIGN")) { 
 362                     wxString alstr 
= tag
.GetParam("ALIGN"); 
 363                     alstr
.MakeUpper();  // for the case alignment was in ".." 
 364                     if (alstr 
== "TEXTTOP") al 
= wxHTML_ALIGN_TOP
; 
 365                     else if ((alstr 
== "CENTER") || (alstr 
== "ABSCENTER")) al 
= wxHTML_ALIGN_CENTER
; 
 367                 if (tag
.HasParam("USEMAP")) { 
 368                     mn 
= tag
.GetParam( "USEMAP" ); 
 369                     if (mn
[ (unsigned int) 0 ] == '#') { 
 373                 wxHtmlImageCell 
*cel 
= NULL
; 
 375                     cel 
= new wxHtmlImageCell(str
, w
, h
, al
, mn
); 
 376                     cel 
-> SetLink(m_WParser 
-> GetLink()); 
 377                     m_WParser 
-> GetContainer() -> InsertCell(cel
); 
 382         if (tag
.GetName() == "MAP") { 
 383             m_WParser
->CloseContainer(); 
 384             m_WParser
->OpenContainer(); 
 385             if (tag
.HasParam("NAME")) { 
 386                 wxString tmp 
= tag
.GetParam("NAME"); 
 387                 wxHtmlImageMapCell 
*cel 
= new wxHtmlImageMapCell( tmp 
); 
 388                 m_WParser
->GetContainer()->InsertCell( cel 
); 
 391             m_WParser
->CloseContainer(); 
 392             m_WParser
->OpenContainer(); 
 394         if (tag
.GetName() == "AREA") { 
 395             if (tag
.HasParam("SHAPE")) { 
 396                 wxString tmp 
= tag
.GetParam("SHAPE"); 
 399                 wxHtmlImageMapAreaCell 
*cel 
= NULL
; 
 400                 if (tag
.HasParam("COORDS")) { 
 401                     coords 
= tag
.GetParam("COORDS"); 
 404                     cel 
= new wxHtmlImageMapAreaCell( wxHtmlImageMapAreaCell::POLY
, coords 
); 
 405                 } else if (tmp 
== "CIRCLE") { 
 406                     cel 
= new wxHtmlImageMapAreaCell( wxHtmlImageMapAreaCell::CIRCLE
, coords 
); 
 407                 } else if (tmp 
== "RECT") { 
 408                     cel 
= new wxHtmlImageMapAreaCell( wxHtmlImageMapAreaCell::RECT
, coords 
); 
 410                 if (cel 
!= NULL 
&& tag
.HasParam("HREF")) { 
 411                     wxString tmp 
= tag
.GetParam("HREF"); 
 414                 if (cel 
!= NULL
) m_WParser
->GetContainer()->InsertCell( cel 
); 
 425 TAGS_MODULE_BEGIN(Image
) 
 429 TAGS_MODULE_END(Image
)