xref: /AOO41X/main/winaccessibility/source/UAccCOM/AccText.h (revision ffad8df045fe8db79e3e50f731c1fa6ab6501c83)
1*3a700b0aSSteve Yin /**************************************************************
25fdc4257SSteve Yin  *
3*3a700b0aSSteve Yin  * Licensed to the Apache Software Foundation (ASF) under one
4*3a700b0aSSteve Yin  * or more contributor license agreements.  See the NOTICE file
5*3a700b0aSSteve Yin  * distributed with this work for additional information
6*3a700b0aSSteve Yin  * regarding copyright ownership.  The ASF licenses this file
7*3a700b0aSSteve Yin  * to you under the Apache License, Version 2.0 (the
8*3a700b0aSSteve Yin  * "License"); you may not use this file except in compliance
9*3a700b0aSSteve Yin  * with the License.  You may obtain a copy of the License at
105fdc4257SSteve Yin  *
11*3a700b0aSSteve Yin  *   http://www.apache.org/licenses/LICENSE-2.0
125fdc4257SSteve Yin  *
13*3a700b0aSSteve Yin  * Unless required by applicable law or agreed to in writing,
14*3a700b0aSSteve Yin  * software distributed under the License is distributed on an
15*3a700b0aSSteve Yin  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*3a700b0aSSteve Yin  * KIND, either express or implied.  See the License for the
17*3a700b0aSSteve Yin  * specific language governing permissions and limitations
18*3a700b0aSSteve Yin  * under the License.
195fdc4257SSteve Yin  *
20*3a700b0aSSteve Yin  *************************************************************/
215fdc4257SSteve Yin 
225fdc4257SSteve Yin #if !defined(AFX_ACCTEXT_H__F06C5496_9959_4C7C_873E_A8D50CFB290D__INCLUDED_)
235fdc4257SSteve Yin #define AFX_ACCTEXT_H__F06C5496_9959_4C7C_873E_A8D50CFB290D__INCLUDED_
245fdc4257SSteve Yin 
255fdc4257SSteve Yin #if _MSC_VER > 1000
265fdc4257SSteve Yin #pragma once
275fdc4257SSteve Yin #endif // _MSC_VER > 1000
285fdc4257SSteve Yin 
295fdc4257SSteve Yin #include "resource.h"       // main symbols
305fdc4257SSteve Yin 
315fdc4257SSteve Yin #include "AccTextBase.h"
325fdc4257SSteve Yin 
335fdc4257SSteve Yin /**
345fdc4257SSteve Yin  * CAccText implements IAccessibleText interface.
355fdc4257SSteve Yin  */
365fdc4257SSteve Yin class ATL_NO_VTABLE CAccText :
375fdc4257SSteve Yin             public CComObjectRoot,
385fdc4257SSteve Yin             public CComCoClass<CAccText,&CLSID_AccText>,
395fdc4257SSteve Yin             public IAccessibleText,
405fdc4257SSteve Yin             public CAccTextBase
415fdc4257SSteve Yin {
425fdc4257SSteve Yin public:
CAccText()435fdc4257SSteve Yin     CAccText()
445fdc4257SSteve Yin     {
455fdc4257SSteve Yin             }
~CAccText()465fdc4257SSteve Yin     ~CAccText()
475fdc4257SSteve Yin     {
485fdc4257SSteve Yin             }
495fdc4257SSteve Yin 
505fdc4257SSteve Yin     BEGIN_COM_MAP(CAccText)
COM_INTERFACE_ENTRY(IAccessibleText)515fdc4257SSteve Yin     COM_INTERFACE_ENTRY(IAccessibleText)
525fdc4257SSteve Yin     COM_INTERFACE_ENTRY(IUNOXWrapper)
535fdc4257SSteve Yin     COM_INTERFACE_ENTRY_FUNC_BLIND(NULL,_SmartQI)
545fdc4257SSteve Yin     END_COM_MAP()
555fdc4257SSteve Yin 
565fdc4257SSteve Yin     static HRESULT WINAPI _SmartQI(void* pv,
575fdc4257SSteve Yin                                    REFIID iid, void** ppvObject, DWORD)
585fdc4257SSteve Yin     {
595fdc4257SSteve Yin         return ((CAccText*)pv)->SmartQI(iid,ppvObject);
605fdc4257SSteve Yin     }
615fdc4257SSteve Yin 
SmartQI(REFIID iid,void ** ppvObject)625fdc4257SSteve Yin     HRESULT SmartQI(REFIID iid, void** ppvObject)
635fdc4257SSteve Yin     {
645fdc4257SSteve Yin         if( m_pOuterUnknown )
655fdc4257SSteve Yin             return OuterQueryInterface(iid,ppvObject);
665fdc4257SSteve Yin         return E_FAIL;
675fdc4257SSteve Yin     }
685fdc4257SSteve Yin 
695fdc4257SSteve Yin     DECLARE_REGISTRY_RESOURCEID(IDR_AccText)
705fdc4257SSteve Yin 
715fdc4257SSteve Yin     // IAccessibleText
725fdc4257SSteve Yin public:
735fdc4257SSteve Yin     // IAccessibleText
745fdc4257SSteve Yin 
755fdc4257SSteve Yin     // Adds a text selection.
765fdc4257SSteve Yin     STDMETHOD(addSelection)(long startOffset, long endOffset);//, unsigned char * success);
775fdc4257SSteve Yin 
785fdc4257SSteve Yin     // Gets text attributes.
795fdc4257SSteve Yin     STDMETHOD(get_attributes)(long offset, long * startOffset, long * endOffset, BSTR * textAttributes);
805fdc4257SSteve Yin 
815fdc4257SSteve Yin     // Gets caret offset.
825fdc4257SSteve Yin     STDMETHOD(get_caretOffset)(long * offset);
835fdc4257SSteve Yin 
845fdc4257SSteve Yin     // Gets total number of characters.
855fdc4257SSteve Yin     STDMETHOD(get_characterCount)(long * nCharacters);
865fdc4257SSteve Yin 
875fdc4257SSteve Yin     // Gets bounding rect containing the glyph(s) representing the character
885fdc4257SSteve Yin     // at the specified text offset
895fdc4257SSteve Yin     STDMETHOD(get_characterExtents)(long offset, IA2CoordinateType coordType, long * x, long * y, long * width, long * height);
905fdc4257SSteve Yin 
915fdc4257SSteve Yin     // Gets number of active non-contiguous selections.
925fdc4257SSteve Yin     STDMETHOD(get_nSelections)(long * nSelections);
935fdc4257SSteve Yin 
945fdc4257SSteve Yin     // Gets bounding rect for the glyph at a certain point.
955fdc4257SSteve Yin     STDMETHOD(get_offsetAtPoint)(long x, long y, IA2CoordinateType coordType, long * offset);
965fdc4257SSteve Yin 
975fdc4257SSteve Yin     // Gets character offsets of N-th active text selection.
985fdc4257SSteve Yin     STDMETHOD(get_selection)(long selection, long * startOffset, long * endOffset);
995fdc4257SSteve Yin 
1005fdc4257SSteve Yin     // Gets a range of text by offset NOTE: returned string may be longer
1015fdc4257SSteve Yin     // than endOffset-startOffset bytes if text contains multi-byte characters.
1025fdc4257SSteve Yin     STDMETHOD(get_text)(long startOffset, long endOffset, BSTR * text);
1035fdc4257SSteve Yin 
1045fdc4257SSteve Yin     // Gets a specified amount of text that ends before a specified offset.
1055fdc4257SSteve Yin     STDMETHOD(get_textBeforeOffset)(long offset, IA2TextBoundaryType boundaryType, long * startOffset, long * endOffset, BSTR * text);
1065fdc4257SSteve Yin 
1075fdc4257SSteve Yin     // Gets a specified amount of text that spans the specified offset.
1085fdc4257SSteve Yin     STDMETHOD(get_textAfterOffset)(long offset, IA2TextBoundaryType boundaryType, long * startOffset, long * endOffset, BSTR * text);
1095fdc4257SSteve Yin 
1105fdc4257SSteve Yin     // Gets a specified amount of text that starts after a specified offset.
1115fdc4257SSteve Yin     STDMETHOD(get_textAtOffset)(long offset, IA2TextBoundaryType boundaryType, long * startOffset, long * endOffset, BSTR * text);
1125fdc4257SSteve Yin 
1135fdc4257SSteve Yin     // Unselects a range of text.
1145fdc4257SSteve Yin     STDMETHOD(removeSelection)(long selectionIndex);//, unsigned char * success);
1155fdc4257SSteve Yin 
1165fdc4257SSteve Yin     // Moves text caret.
1175fdc4257SSteve Yin     STDMETHOD(setCaretOffset)(long offset);//, unsigned char * success);
1185fdc4257SSteve Yin 
1195fdc4257SSteve Yin     // Changes the bounds of an existing selection.
1205fdc4257SSteve Yin     STDMETHOD(setSelection)(long selectionIndex, long startOffset, long endOffset);//, unsigned char * success);
1215fdc4257SSteve Yin 
1225fdc4257SSteve Yin     // Gets total number of characters.
1235fdc4257SSteve Yin     // NOTE: this may be different than the total number of bytes required
1245fdc4257SSteve Yin     // to store the text, if the text contains multi-byte characters.
1255fdc4257SSteve Yin     STDMETHOD(get_nCharacters)(long * nCharacters);
1265fdc4257SSteve Yin 
1275fdc4257SSteve Yin     // Makes specific part of string visible on screen.
1285fdc4257SSteve Yin     STDMETHOD(scrollSubstringTo)(long startIndex, long endIndex,enum IA2ScrollType scrollType);
1295fdc4257SSteve Yin     STDMETHOD(scrollSubstringToPoint)(long startIndex, long endIndex,enum IA2CoordinateType coordinateType, long x, long y );
1305fdc4257SSteve Yin 
1315fdc4257SSteve Yin     STDMETHOD(get_newText)( IA2TextSegment *newText);
1325fdc4257SSteve Yin 
1335fdc4257SSteve Yin     STDMETHOD(get_oldText)( IA2TextSegment *oldText);
1345fdc4257SSteve Yin 
1355fdc4257SSteve Yin     // Overide of IUNOXWrapper.
1365fdc4257SSteve Yin     STDMETHOD(put_XInterface)(long pXInterface);
1375fdc4257SSteve Yin 
1385fdc4257SSteve Yin };
1395fdc4257SSteve Yin 
1405fdc4257SSteve Yin #endif // !defined(AFX_ACCTEXT_H__F06C5496_9959_4C7C_873E_A8D50CFB290D__INCLUDED_)
141